#include "tao/Resource_Factory.h"#include "tao/Collocation_Strategy.h"#include "tao/params.h"#include "tao/ORB_Constants.h"#include "tao/Parser_Registry.h"#include "tao/Service_Callbacks.h"#include "tao/Fault_Tolerance_Service.h"#include "tao/Cleanup_Func_Registry.h"#include "tao/Object_Ref_Table.h"#include "tao/ObjectKey_Table.h"#include "tao/Messaging_SyncScopeC.h"#include "tao/Object.h"#include "tao/Invocation_Utils.h"#include "tao/Adapter_Registry.h"#include "tao/ORB_Core_TSS_Resources.h"#include "tao/Service_Context_Handler_Registry.h"#include "ace/Array_Map.h"#include "ace/Thread_Manager.h"#include "ace/Lock_Adapter_T.h"#include "ace/TSS_T.h"#include "ace/Service_Config.h"#include "tao/ORB_Core.inl"#include "ace/Service_Config.h"
Go to the source code of this file.
Classes | |
| class | TAO_ORB_Core |
| Encapsulates the state of an ORB. More... | |
| class | TAO_ORB_Core_Static_Resources |
| The static (global) resoures of all ORB cores. More... | |
Namespaces | |
| namespace | TAO |
Define symbolic names for the ORB collocation strategies. | |
| namespace | CORBA |
FUZZ: disable check_for_include/. | |
| namespace | IOP |
| namespace | PortableInterceptor |
Typedefs | |
| typedef ServerRequestInterceptor * | PortableInterceptor::ServerRequestInterceptor_ptr |
Functions | |
| TAO_Export TAO_ORB_Core * | TAO_ORB_Core_instance (void) |
Definition in file ORB_Core.h.
| TAO_Export TAO_ORB_Core* TAO_ORB_Core_instance | ( | void | ) |
Obtain an instance of the first ORB core registered in the ORB table.
Definition at line 3580 of file ORB_Core.cpp.
{
// @@ This is a slight violation of layering, we should use
// TAO_ORB_Core_instance(), but that breaks during startup.
TAO::ORB_Table * const orb_table = TAO::ORB_Table::instance ();
if (orb_table->first_orb () == 0)
{
ACE_MT (ACE_GUARD_RETURN (TAO_SYNCH_RECURSIVE_MUTEX, guard,
*ACE_Static_Object_Lock::instance (), 0));
if (orb_table->first_orb () == 0)
{
// Calling CORBA::ORB_init() returns a duplicated ORB
// reference, so make sure that reference is stored in an
// ORB_var so that no leak occurs. The duplicate ORB
// reference isn't needed outside the scope of this function
// since the corresponding ORB Core instance will still
// exist in the ORB table after the ORB reference is
// destroyed.
try
{
int argc = 0;
ACE_TCHAR **const argv= 0;
CORBA::ORB_var orb =
CORBA::ORB_init (argc, argv);
}
catch (const ::CORBA::Exception&)
{
// @@ What should we do here?
}
}
}
return orb_table->first_orb ();
}
1.7.0