diff options
author | William R. Otte <wotte@dre.vanderbilt.edu> | 2006-07-24 15:50:21 +0000 |
---|---|---|
committer | William R. Otte <wotte@dre.vanderbilt.edu> | 2006-07-24 15:50:21 +0000 |
commit | 3aff90f4a822fcf5d902bbfbcc9fa931d6191a8c (patch) | |
tree | 197c810e5f5bce17b1233a7cb8d7b50c0bcd25e2 /TAO/tao/FlResource | |
parent | 6b846cf03c0bcbd8c276cb0af61a181e5f98eaae (diff) | |
download | ATCD-3aff90f4a822fcf5d902bbfbcc9fa931d6191a8c.tar.gz |
Repo restructuring
Diffstat (limited to 'TAO/tao/FlResource')
-rw-r--r-- | TAO/tao/FlResource/FlResource_Factory.cpp | 39 | ||||
-rw-r--r-- | TAO/tao/FlResource/FlResource_Factory.h | 62 | ||||
-rw-r--r-- | TAO/tao/FlResource/FlResource_Loader.cpp | 29 | ||||
-rw-r--r-- | TAO/tao/FlResource/FlResource_Loader.h | 59 | ||||
-rw-r--r-- | TAO/tao/FlResource/TAO_FlResource_Export.h | 58 |
5 files changed, 247 insertions, 0 deletions
diff --git a/TAO/tao/FlResource/FlResource_Factory.cpp b/TAO/tao/FlResource/FlResource_Factory.cpp new file mode 100644 index 00000000000..a280383b065 --- /dev/null +++ b/TAO/tao/FlResource/FlResource_Factory.cpp @@ -0,0 +1,39 @@ +//$Id$ + +#include "tao/FlResource/FlResource_Factory.h" +#include "tao/debug.h" +#include "ace/FlReactor.h" + +ACE_RCSID( TAO_FlResource, + FlResource_Factory, + "$Id$"); + +TAO_BEGIN_VERSIONED_NAMESPACE_DECL + +namespace TAO +{ + FlResource_Factory::FlResource_Factory (void) + : reactor_impl_( 0 ) + { + } + + ACE_Reactor_Impl * + FlResource_Factory::reactor_impl (void) + { + // synchronized by external locks + if (!this->reactor_impl_) + { + ACE_NEW_RETURN (this->reactor_impl_, + ACE_FlReactor (), + 0); + + if (TAO_debug_level > 0) + ACE_DEBUG ((LM_DEBUG, + "TAO (%P|%t) - ACE_FlReactor created \n")); + } + + return this->reactor_impl_; + } +} + +TAO_END_VERSIONED_NAMESPACE_DECL diff --git a/TAO/tao/FlResource/FlResource_Factory.h b/TAO/tao/FlResource/FlResource_Factory.h new file mode 100644 index 00000000000..28da6ab9341 --- /dev/null +++ b/TAO/tao/FlResource/FlResource_Factory.h @@ -0,0 +1,62 @@ +// -*- C++ -*- + +//============================================================================= +/** + * @file FlResource_Factory.h + * + * $Id$ + * + * @author Balachandran Natarajan <bala@cs.wustl.edu> + * @author Marek Brudka <mbrudka@aster.pl> + */ +//============================================================================= +#ifndef TAO_FLRESOURCE_FACTORY_H +#define TAO_FLRESOURCE_FACTORY_H +#include /**/ "ace/pre.h" + +#include "tao/FlResource/TAO_FlResource_Export.h" + +#if !defined (ACE_LACKS_PRAGMA_ONCE) +# pragma once +#endif /* ACE_LACKS_PRAGMA_ONCE */ + +#include "ace/FlReactor.h" +#include "tao/GUIResource_Factory.h" + +TAO_BEGIN_VERSIONED_NAMESPACE_DECL + +namespace TAO +{ + /** + * @class FlResource_Factory + * + * @brief TAO_GUI_Resource_Factory for creating FlReactor. + * + * This factory is intended for creating FlReactor for ORB. This + * factory can be feed into ORB using + * TAO_ORB_Core::set_gui_resource_factory method which is usually + * done by TAO_FlResource_Loader. + */ + + class TAO_FlResource_Export FlResource_Factory : public GUIResource_Factory + { + public: + + FlResource_Factory (); + + protected: + + /// Create or obtain current reactor implementation + virtual ACE_Reactor_Impl *reactor_impl (void); + + private: + + /// Reactor created by this factory. + ACE_FlReactor *reactor_impl_; + }; +} + +TAO_END_VERSIONED_NAMESPACE_DECL + +#include /**/ "ace/post.h" +#endif /* TAO_FLRESOURCE_FACTORY_H */ diff --git a/TAO/tao/FlResource/FlResource_Loader.cpp b/TAO/tao/FlResource/FlResource_Loader.cpp new file mode 100644 index 00000000000..f004941bddb --- /dev/null +++ b/TAO/tao/FlResource/FlResource_Loader.cpp @@ -0,0 +1,29 @@ +//$Id$ +#include "tao/FlResource/FlResource_Loader.h" +#include "tao/ORB_Core.h" +#include "tao/FlResource/FlResource_Factory.h" + +ACE_RCSID( TAO_FlResource, + FlResource_Loader, + "$Id$"); + +TAO_BEGIN_VERSIONED_NAMESPACE_DECL + +namespace TAO +{ + FlResource_Loader::FlResource_Loader (void) + { + FlResource_Factory *tmp = 0; + + ACE_NEW (tmp, + FlResource_Factory ()); + + TAO_ORB_Core::set_gui_resource_factory (tmp); + } + + FlResource_Loader::~FlResource_Loader (void) + { + } +} + +TAO_END_VERSIONED_NAMESPACE_DECL diff --git a/TAO/tao/FlResource/FlResource_Loader.h b/TAO/tao/FlResource/FlResource_Loader.h new file mode 100644 index 00000000000..09b6ef2ce4d --- /dev/null +++ b/TAO/tao/FlResource/FlResource_Loader.h @@ -0,0 +1,59 @@ +// -*- C++ -*- + +//============================================================================= +/** + * @file FlResource_Loader.h + * + * $Id$ + * + * @author Balachandran Natarajan <bala@cs.wustl.edu> + * @author Marek Brudka <mbrudka@aster.pl> + */ +//============================================================================= + +#ifndef TAO_FLRESOURCE_LOADER_H +#define TAO_FLRESOURCE_LOADER_H +#include /**/ "ace/pre.h" + +#include "tao/FlResource/TAO_FlResource_Export.h" + +#if !defined (ACE_LACKS_PRAGMA_ONCE) +# pragma once +#endif /* ACE_LACKS_PRAGMA_ONCE */ + +#include "tao/Versioned_Namespace.h" + +TAO_BEGIN_VERSIONED_NAMESPACE_DECL + +namespace TAO +{ + + /** + * @class FlResource_Loader + * + * @brief Loads TAO resources related with Fl. + * + * This class changes the default reactor implementation into + * ACE_FlReactor one by calling TAO_ORB_Core::set_gui_resource_factory. + * User should create an instance of this class before ORB_init + * when the TAO server has has to be integrated within Fl event loop. + * + * Please notice, this class has to be created in the main Fl thread, + * because set_gui_resource_factory creates a variable in TSS. This way + * FlReactor is instantiated only in Qt event loop thread. + */ + class TAO_FlResource_Export FlResource_Loader + { + + public: + FlResource_Loader (void); + + virtual ~FlResource_Loader (void); + }; +} + +TAO_END_VERSIONED_NAMESPACE_DECL + +#include /**/ "ace/post.h" + +#endif /* TAO_FLRESOURCE_LOADER_H */ diff --git a/TAO/tao/FlResource/TAO_FlResource_Export.h b/TAO/tao/FlResource/TAO_FlResource_Export.h new file mode 100644 index 00000000000..e63890b54a6 --- /dev/null +++ b/TAO/tao/FlResource/TAO_FlResource_Export.h @@ -0,0 +1,58 @@ + +// -*- C++ -*- +// $Id$ +// Definition for Win32 Export directives. +// This file is generated automatically by generate_export_file.pl -s TAO_FlResource +// ------------------------------ +#ifndef TAO_FLRESOURCE_EXPORT_H +#define TAO_FLRESOURCE_EXPORT_H + +#include "ace/config-all.h" + +#if defined (ACE_AS_STATIC_LIBS) && !defined (TAO_FLRESOURCE_HAS_DLL) +# define TAO_FLRESOURCE_HAS_DLL 0 +#endif /* ACE_AS_STATIC_LIBS && TAO_FLRESOURCE_HAS_DLL */ + +#if !defined (TAO_FLRESOURCE_HAS_DLL) +# define TAO_FLRESOURCE_HAS_DLL 1 +#endif /* ! TAO_FLRESOURCE_HAS_DLL */ + +#if defined (TAO_FLRESOURCE_HAS_DLL) && (TAO_FLRESOURCE_HAS_DLL == 1) +# if defined (TAO_FLRESOURCE_BUILD_DLL) +# define TAO_FlResource_Export ACE_Proper_Export_Flag +# define TAO_FLRESOURCE_SINGLETON_DECLARATION(T) ACE_EXPORT_SINGLETON_DECLARATION (T) +# define TAO_FLRESOURCE_SINGLETON_DECLARE(SINGLETON_TYPE, CLASS, LOCK) ACE_EXPORT_SINGLETON_DECLARE(SINGLETON_TYPE, CLASS, LOCK) +# else /* TAO_FLRESOURCE_BUILD_DLL */ +# define TAO_FlResource_Export ACE_Proper_Import_Flag +# define TAO_FLRESOURCE_SINGLETON_DECLARATION(T) ACE_IMPORT_SINGLETON_DECLARATION (T) +# define TAO_FLRESOURCE_SINGLETON_DECLARE(SINGLETON_TYPE, CLASS, LOCK) ACE_IMPORT_SINGLETON_DECLARE(SINGLETON_TYPE, CLASS, LOCK) +# endif /* TAO_FLRESOURCE_BUILD_DLL */ +#else /* TAO_FLRESOURCE_HAS_DLL == 1 */ +# define TAO_FlResource_Export +# define TAO_FLRESOURCE_SINGLETON_DECLARATION(T) +# define TAO_FLRESOURCE_SINGLETON_DECLARE(SINGLETON_TYPE, CLASS, LOCK) +#endif /* TAO_FLRESOURCE_HAS_DLL == 1 */ + +// Set TAO_FLRESOURCE_NTRACE = 0 to turn on library specific tracing even if +// tracing is turned off for ACE. +#if !defined (TAO_FLRESOURCE_NTRACE) +# if (ACE_NTRACE == 1) +# define TAO_FLRESOURCE_NTRACE 1 +# else /* (ACE_NTRACE == 1) */ +# define TAO_FLRESOURCE_NTRACE 0 +# endif /* (ACE_NTRACE == 1) */ +#endif /* !TAO_FLRESOURCE_NTRACE */ + +#if (TAO_FLRESOURCE_NTRACE == 1) +# define TAO_FLRESOURCE_TRACE(X) +#else /* (TAO_FLRESOURCE_NTRACE == 1) */ +# if !defined (ACE_HAS_TRACE) +# define ACE_HAS_TRACE +# endif /* ACE_HAS_TRACE */ +# define TAO_FLRESOURCE_TRACE(X) ACE_TRACE_IMPL(X) +# include "ace/Trace.h" +#endif /* (TAO_FLRESOURCE_NTRACE == 1) */ + +#endif /* TAO_FLRESOURCE_EXPORT_H */ + +// End of auto generated file. |