📄 transport.cpp
字号:
av_core->get_transport_factory (transport_protocol);
if (transport_factory == 0)
ACE_ERROR_RETURN ((LM_ERROR,
"TAO (%P|%t) (%N,%l) Unable to match protocol prefix "
"for <%s>\n",
transport_protocol),
-1);
// make an acceptor
TAO_AV_Acceptor *acceptor =
transport_factory->make_acceptor();
if (acceptor == 0)
ACE_ERROR_RETURN ((LM_ERROR,
"TAO (%P|%t) unable to create "
"an acceptor for <%d>\n",
transport_protocol),
-1);
if (acceptor->open_default (endpoint,
av_core,
entry,
flow_factory,
TAO_AV_Core::TAO_AV_DATA) == -1)
ACE_ERROR_RETURN ((LM_ERROR,
"TAO (%P|%t) unable to open "
"default acceptor for <%s>%p\n",
flow_protocol),
-1);
this->acceptors_.insert (acceptor);
const char *control_flow_factory_name = flow_factory->control_flow_factory ();
if (control_flow_factory_name != 0)
{
TAO_AV_Flow_Protocol_Factory *control_flow_factory =
av_core->get_flow_protocol_factory (control_flow_factory_name);
if (control_flow_factory == 0)
ACE_ERROR_RETURN ((LM_ERROR,
"TAO (%P|%t) Unable to match control flow "
"for <%s>\n",
control_flow_factory_name),
-1);
TAO_AV_Acceptor *control_acceptor = transport_factory->make_acceptor ();
if (control_acceptor == 0)
ACE_ERROR_RETURN ((LM_ERROR,
"TAO (%P|%t) unable to create "
"an acceptor for <%d>\n",
transport_protocol),
-1);
if (control_acceptor->open_default (endpoint,
av_core,
entry,
control_flow_factory,
TAO_AV_Core::TAO_AV_CONTROL) == -1)
ACE_ERROR_RETURN ((LM_ERROR,
"TAO (%P|%t) unable to open "
"default acceptor for <%s>%p\n",
transport_protocol),
-1);
this->acceptors_.insert (control_acceptor);
entry->protocol_object ()->control_object (entry->control_protocol_object ());
}
if (this->acceptors_.size () == 0)
{
if (TAO_debug_level > 0)
ACE_ERROR ((LM_ERROR,
"TAO (%P%t) cannot create any default acceptor\n"));
return -1;
}
return 0;
}
int
TAO_AV_Acceptor_Registry::close (TAO_AV_Acceptor *acceptor)
{
this->acceptors_.remove (acceptor);
delete acceptor;
return 0;
}
int
TAO_AV_Acceptor_Registry::close_all (void)
{
for (TAO_AV_AcceptorSetItor i = this->acceptors_.begin ();
i != this->acceptors_.end ();
++i)
{
if (*i == 0)
continue;
(*i)->close ();
delete *i;
}
this->acceptors_.reset ();
return 0;
}
//----------------------------------------------------------------------
// TAO_AV_Transport
//----------------------------------------------------------------------
TAO_AV_Transport::TAO_AV_Transport (void)
{
}
// Virtual destructor.
TAO_AV_Transport::~TAO_AV_Transport (void)
{
}
ACE_Addr*
TAO_AV_Transport::get_local_addr (void)
{
return 0;
}
//----------------------------------------------------------------------
// TAO_AV_Flow_Handler
//----------------------------------------------------------------------
//TAO_AV_Flow_Handler::TAO_AV_Flow_Handler (TAO_AV_Callback *callback)
TAO_AV_Flow_Handler::TAO_AV_Flow_Handler (void)
:transport_ (0),
callback_ (0),
protocol_object_ (0),
timer_id_ (-1)
{
}
TAO_AV_Flow_Handler::~TAO_AV_Flow_Handler(void)
{
// cancel the timer (if there is one)
this->cancel_timer();
}
int
TAO_AV_Flow_Handler::set_remote_address (ACE_Addr * /* address */)
{
return 0;
}
int
TAO_AV_Flow_Handler::start (TAO_FlowSpec_Entry::Role role)
{
this->callback_->handle_start ();
switch (role)
{
// only for producer we register for the timeout.
case TAO_FlowSpec_Entry::TAO_AV_PRODUCER:
{
this->schedule_timer ();
}
break;
default:
break;
}
return 0;
}
int
TAO_AV_Flow_Handler::schedule_timer (void)
{
ACE_Event_Handler *event_handler = this->event_handler ();
ACE_Time_Value *tv = 0;
this->callback_->get_timeout (tv, this->timeout_arg_);
if (tv == 0)
return 0;
this->timer_id_ =
TAO_AV_CORE::instance()->reactor ()->schedule_timer (event_handler,
0,
*tv);
if (this->timer_id_ < 0)
return -1;
return 0;
}
int
TAO_AV_Flow_Handler::cancel_timer (void)
{
if (this->timer_id_ != -1)
return TAO_AV_CORE::instance()->reactor ()->cancel_timer (this->timer_id_);
else
return 0;
}
int
TAO_AV_Flow_Handler::stop (TAO_FlowSpec_Entry::Role role)
{
this->callback_->handle_stop ();
switch (role)
{
case TAO_FlowSpec_Entry::TAO_AV_PRODUCER:
{
int result = this->event_handler ()->reactor ()->cancel_timer (this->timer_id_);
if (result < 0)
if (TAO_debug_level > 0) ACE_DEBUG ((LM_DEBUG,"TAO_AV_Flow_Handler::stop:cancel_timer failed\n"));
}
break;
default:
break;
}
return 0;
}
int
TAO_AV_Flow_Handler::handle_timeout (const ACE_Time_Value & /*tv*/,
const void * /*arg*/)
{
int result = this->callback_->handle_timeout (this->timeout_arg_);
if (result < 0)
return result;
ACE_Event_Handler *event_handler = this->event_handler ();
ACE_Time_Value *timeout = 0;
this->callback_->get_timeout (timeout, this->timeout_arg_);
if (timeout == 0)
return 0;
this->timer_id_ = event_handler->reactor ()->schedule_timer (event_handler,
0,
*timeout);
if (this->timer_id_ < 0)
return -1;
return 0;
}
int
TAO_AV_Flow_Handler::change_qos (AVStreams::QoS)
{
return 0;
}
TAO_AV_Transport*
TAO_AV_Flow_Handler::transport (void)
{
return this->transport_;
}
void
TAO_AV_Flow_Handler::protocol_object (TAO_AV_Protocol_Object *protocol_object)
{
this->protocol_object_ = protocol_object;
}
TAO_AV_Protocol_Object*
TAO_AV_Flow_Handler::protocol_object (void)
{
return this->protocol_object_;
}
void
TAO_AV_Flow_Handler::callback (TAO_AV_Callback *callback)
{
this->callback_ = callback;
}
// TAO_AV_Connector
TAO_AV_Connector::TAO_AV_Connector (void)
{
}
TAO_AV_Connector::~TAO_AV_Connector (void)
{
}
// TAO_AV_Acceptor
TAO_AV_Acceptor::TAO_AV_Acceptor (void)
{
}
TAO_AV_Acceptor::~TAO_AV_Acceptor (void)
{
}
TAO_AV_Transport_Factory::TAO_AV_Transport_Factory (void)
{
}
TAO_AV_Transport_Factory::~TAO_AV_Transport_Factory (void)
{
}
int
TAO_AV_Transport_Factory::init (int /* argc */,
char * /* argv */ [])
{
return -1;
}
int
TAO_AV_Transport_Factory::match_protocol (const char * /* protocol_string */)
{
return 0;
}
TAO_AV_Acceptor *
TAO_AV_Transport_Factory::make_acceptor (void)
{
return 0;
}
TAO_AV_Connector *
TAO_AV_Transport_Factory::make_connector (void)
{
return 0;
}
#if defined (ACE_HAS_EXPLICIT_TEMPLATE_INSTANTIATION)
template class ACE_Node <TAO_AV_Connector*>;
template class ACE_Node <TAO_AV_Acceptor*>;
template class ACE_Unbounded_Set<TAO_AV_Acceptor*>;
template class ACE_Unbounded_Set<TAO_AV_Connector*>;
template class ACE_Unbounded_Set_Iterator<TAO_AV_Acceptor*>;
template class ACE_Unbounded_Set_Iterator<TAO_AV_Connector*>;
#elif defined (ACE_HAS_TEMPLATE_INSTANTIATION_PRAGMA)
#pragma instantiate ACE_Node <TAO_AV_Connector*>
#pragma instantiate ACE_Node <TAO_AV_Acceptor*>
#pragma instantiate ACE_Unbounded_Set<TAO_AV_Connector*>
#pragma instantiate ACE_Unbounded_Set<TAO_AV_Acceptor*>
#pragma instantiate ACE_Unbounded_Set_Iterator<TAO_AV_Connector*>
#pragma instantiate ACE_Unbounded_Set_Iterator<TAO_AV_Acceptor*>
#endif /* ACE_HAS_EXPLICIT_TEMPLATE_INSTANTIATION */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -