ACE_Framework_Repository Class Reference

Contains all framework components used by an application. More...

#include <Framework_Component.h>

Collaboration diagram for ACE_Framework_Repository:

Collaboration graph
[legend]
List of all members.

Public Types

enum  { DEFAULT_SIZE = ACE_DEFAULT_FRAMEWORK_REPOSITORY_SIZE }

Public Member Functions

 ~ACE_Framework_Repository (void)
int open (int size=DEFAULT_SIZE)
 Initialize the repository.

int close (void)
int register_component (ACE_Framework_Component *fc)
int remove_component (const ACE_TCHAR *name)
int remove_dll_components (const ACE_TCHAR *dll_name)
 Remove all components associated with a particular dll.

int current_size (void) const
 Return the current size of the repository.

int total_size (void) const
 Return the total size of the repository.

void dump (void) const
 Dump the state of an object.


Static Public Member Functions

ACE_Framework_Repositoryinstance (int size=ACE_Framework_Repository::DEFAULT_SIZE)
 Get pointer to a process-wide .

void close_singleton (void)
 Delete the dynamically allocated Singleton.


Public Attributes

 ACE_ALLOC_HOOK_DECLARE
 Declare the dynamic allocation hooks.


Protected Member Functions

 ACE_Framework_Repository (int size=ACE_Framework_Repository::DEFAULT_SIZE)
 Initialize the repository.


Private Member Functions

int remove_dll_components_i (const ACE_TCHAR *dll_name)
 Actually removes the dll components, must be called with locks held.

void compact (void)
 ACE_Framework_Repository (const ACE_Framework_Repository &)
 Disallow copying and assignment.

ACE_Framework_Repositoryoperator= (const ACE_Framework_Repository &)

Private Attributes

ACE_Framework_Component ** component_vector_
 Contains all the framework components.

int current_size_
 Current number of components.

int total_size_
 Maximum number of components.


Static Private Attributes

ACE_Framework_Repositoryrepository_ = 0
 Pointer to a process-wide ACE_Framework_Repository.

sig_atomic_t shutting_down_ = 0

Friends

class ACE_Framework_Component

Detailed Description

Contains all framework components used by an application.

This class contains a vector of ACE_Framework_Component *'s. On destruction, framework components are destroyed in the reverse order that they were added originally.

Definition at line 101 of file Framework_Component.h.


Member Enumeration Documentation

anonymous enum
 

Enumeration values:
DEFAULT_SIZE 

Definition at line 107 of file Framework_Component.h.


Constructor & Destructor Documentation

ACE_Framework_Repository::~ACE_Framework_Repository void   ) 
 

Close down the repository and free up dynamically allocated resources.

Definition at line 37 of file Framework_Component.cpp.

References ACE_TRACE, and close().

00038 {
00039   ACE_TRACE ("ACE_Framework_Repository::~ACE_Framework_Repository");
00040   this->close ();
00041 }

ACE_Framework_Repository::ACE_Framework_Repository int  size = ACE_Framework_Repository::DEFAULT_SIZE  )  [protected]
 

Initialize the repository.

Definition at line 269 of file Framework_Component.cpp.

References ACE_ERROR, ACE_LIB_TEXT, ACE_TRACE, LM_ERROR, and open().

00270   : current_size_ (0)
00271 {
00272   ACE_TRACE ("ACE_Framework_Repository::ACE_Framework_Repository");
00273 
00274   if (this->open (size) == -1)
00275     ACE_ERROR ((LM_ERROR,
00276                 ACE_LIB_TEXT ("%p\n"),
00277                 ACE_LIB_TEXT ("ACE_Framework_Repository")));
00278 }

ACE_Framework_Repository::ACE_Framework_Repository const ACE_Framework_Repository  )  [private]
 

Disallow copying and assignment.


Member Function Documentation

int ACE_Framework_Repository::close void   ) 
 

Close down the repository and free up dynamically allocated resources, also called by dtor.

Definition at line 60 of file Framework_Component.cpp.

References ACE_GUARD_RETURN, ACE_TRACE, ACE_DLL_Manager::close_singleton(), component_vector_, and shutting_down_.

Referenced by ~ACE_Framework_Repository().

00061 {
00062   ACE_TRACE ("ACE_Framework_Repository::close");
00063   ACE_MT (ACE_GUARD_RETURN (ACE_Thread_Mutex, ace_mon, this->lock_, -1));
00064 
00065   this->shutting_down_ = 1;
00066 
00067   if (this->component_vector_ != 0)
00068     {
00069       // Delete components in reverse order.
00070       for (int i = this->current_size_ - 1; i >= 0; i--)
00071         if (this->component_vector_[i])
00072           {
00073             ACE_Framework_Component *s =
00074               const_cast<ACE_Framework_Component *> (
00075                 this->component_vector_[i]);
00076 
00077             this->component_vector_[i] = 0;
00078             delete s;
00079           }
00080 
00081       delete [] this->component_vector_;
00082       this->component_vector_ = 0;
00083       this->current_size_ = 0;
00084     }
00085 
00086   ACE_DLL_Manager::close_singleton ();
00087   return 0;
00088 }

void ACE_Framework_Repository::close_singleton void   )  [static]
 

Delete the dynamically allocated Singleton.

Definition at line 116 of file Framework_Component.cpp.

References ACE_GUARD, ACE_TRACE, and repository_.

Referenced by ACE_Object_Manager::fini().

00117 {
00118   ACE_TRACE ("ACE_Framework_Repository::close_singleton");
00119 
00120   ACE_MT (ACE_GUARD (ACE_Recursive_Thread_Mutex, ace_mon,
00121                      *ACE_Static_Object_Lock::instance ()));
00122 
00123   delete ACE_Framework_Repository::repository_;
00124   ACE_Framework_Repository::repository_ = 0;
00125 }

void ACE_Framework_Repository::compact void   )  [private]
 

Compact component_vector_ after components have been removed__maintains order.

Definition at line 215 of file Framework_Component.cpp.

References ACE_TRACE, and component_vector_.

Referenced by remove_component(), and remove_dll_components_i().

00216 {
00217   ACE_TRACE ("ACE_Framework_Repository::compact");
00218 
00219   int i;
00220   int start_hole;
00221   int end_hole;
00222 
00223   do
00224     {
00225       start_hole = this->current_size_;
00226       end_hole = this->current_size_;
00227 
00228       // Find hole
00229       for (i = 0; i < this->current_size_; ++i)
00230         {
00231           if (this->component_vector_[i] == 0)
00232             {
00233               if (start_hole == this->current_size_)
00234                 {
00235                   start_hole = i;
00236                   end_hole = i;
00237                 }
00238               else
00239                 end_hole = i;
00240             }
00241           else if (end_hole != this->current_size_)
00242             break;
00243         }
00244 
00245       if (start_hole != this->current_size_)
00246         {
00247           // move the contents and reset current_size_
00248           while (end_hole + 1 < this->current_size_)
00249             {
00250               this->component_vector_[start_hole++] =
00251                 this->component_vector_[++end_hole];
00252             }
00253           // Since start_hole is now one past the last
00254           // active slot.
00255           this->current_size_ = start_hole;
00256         }
00257 
00258     } while (start_hole != this->current_size_);
00259 }

ACE_INLINE int ACE_Framework_Repository::current_size void   )  const
 

Return the current size of the repository.

Definition at line 24 of file Framework_Component.inl.

References ACE_GUARD_RETURN, and ACE_TRACE.

00025 {
00026   ACE_TRACE ("ACE_Framework_Repository::current_size");
00027   ACE_MT (ACE_GUARD_RETURN (ACE_Thread_Mutex, ace_mon, (ACE_Thread_Mutex &) this->lock_, -1));
00028   return this->current_size_;
00029 }

void ACE_Framework_Repository::dump void   )  const
 

Dump the state of an object.

Definition at line 262 of file Framework_Component.cpp.

References ACE_TRACE.

00263 {
00264 #if defined (ACE_HAS_DUMP)
00265   ACE_TRACE ("ACE_Framework_Repository::dump");
00266 #endif /* ACE_HAS_DUMP */
00267 }

ACE_Framework_Repository * ACE_Framework_Repository::instance int  size = ACE_Framework_Repository::DEFAULT_SIZE  )  [static]
 

Get pointer to a process-wide .

Definition at line 91 of file Framework_Component.cpp.

References ACE_GUARD_RETURN, ACE_NEW_RETURN, ACE_TRACE, repository_, ACE_Object_Manager::shutting_down(), and ACE_Object_Manager::starting_up().

Referenced by ACE_DLL_Handle::close(), and ACE_DLL_Singleton_T< TYPE, ACE_LOCK >::instance().

00092 {
00093   ACE_TRACE ("ACE_Framework_Repository::instance");
00094 
00095   if (ACE_Framework_Repository::repository_ == 0)
00096     {
00097       // Perform Double-Checked Locking Optimization.
00098       ACE_MT (ACE_GUARD_RETURN (ACE_Recursive_Thread_Mutex, ace_mon,
00099                                 *ACE_Static_Object_Lock::instance (), 0));
00100       if (ACE_Framework_Repository::repository_ == 0)
00101         {
00102           if (ACE_Object_Manager::starting_up () ||
00103               !ACE_Object_Manager::shutting_down ())
00104             {
00105               ACE_NEW_RETURN (ACE_Framework_Repository::repository_,
00106                               ACE_Framework_Repository (size),
00107                               0);
00108             }
00109         }
00110     }
00111 
00112   return ACE_Framework_Repository::repository_;
00113 }

int ACE_Framework_Repository::open int  size = DEFAULT_SIZE  ) 
 

Initialize the repository.

Definition at line 44 of file Framework_Component.cpp.

References ACE_NEW_RETURN, ACE_TRACE, and component_vector_.

Referenced by ACE_Framework_Repository().

00045 {
00046   ACE_TRACE ("ACE_Framework_Repository::open");
00047 
00048   ACE_Framework_Component **temp = 0;
00049 
00050   ACE_NEW_RETURN (temp,
00051                   ACE_Framework_Component *[size],
00052                   -1);
00053 
00054   this->component_vector_ = temp;
00055   this->total_size_ = size;
00056   return 0;
00057 }

ACE_Framework_Repository& ACE_Framework_Repository::operator= const ACE_Framework_Repository  )  [private]
 

int ACE_Framework_Repository::register_component ACE_Framework_Component fc  ) 
 

Insert a new component. Returns -1 when the repository is full and 0 on success.

Definition at line 128 of file Framework_Component.cpp.

References ACE_ERROR_RETURN, ACE_GUARD_RETURN, ACE_LIB_TEXT, ACE_TRACE, component_vector_, LM_ERROR, and ACE_Framework_Component::this_.

Referenced by ACE_DLL_Singleton_T< TYPE, ACE_LOCK >::instance().

00129 {
00130   ACE_TRACE ("ACE_Framework_Repository::register_component");
00131   ACE_MT (ACE_GUARD_RETURN (ACE_Thread_Mutex, ace_mon, this->lock_, -1));
00132   int i;
00133 
00134   // Check to see if it's already registered
00135   for (i = 0; i < this->current_size_; i++)
00136     if (this->component_vector_[i] &&
00137         fc->this_ == this->component_vector_[i]->this_)
00138       {
00139         ACE_ERROR_RETURN ((LM_ERROR,
00140                            ACE_LIB_TEXT ("AFR::register_component: error, ")
00141                            ACE_LIB_TEXT ("compenent already registered\n")),
00142                           -1);
00143       }
00144 
00145   if (i < this->total_size_)
00146     {
00147       this->component_vector_[i] = fc;
00148       this->current_size_++;
00149       return 0;
00150     }
00151 
00152   return -1;
00153 }

int ACE_Framework_Repository::remove_component const ACE_TCHAR name  ) 
 

Remove a component. Returns -1 on error or if component not found and 0 on success.

Definition at line 156 of file Framework_Component.cpp.

References ACE_GUARD_RETURN, ACE_TCHAR, ACE_TRACE, compact(), component_vector_, and ACE_OS::strcmp().

00157 {
00158   ACE_TRACE ("ACE_Framework_Repository::remove_component");
00159   ACE_MT (ACE_GUARD_RETURN (ACE_Thread_Mutex, ace_mon, this->lock_, -1));
00160   int i;
00161 
00162   for (i = 0; i < this->current_size_; i++)
00163     if (this->component_vector_[i] &&
00164         ACE_OS::strcmp (this->component_vector_[i]->name_, name) == 0)
00165       {
00166         delete this->component_vector_[i];
00167         this->component_vector_[i] = 0;
00168         this->compact ();
00169         return 0;
00170       }
00171 
00172   return -1;
00173 }

int ACE_Framework_Repository::remove_dll_components const ACE_TCHAR dll_name  ) 
 

Remove all components associated with a particular dll.

Definition at line 176 of file Framework_Component.cpp.

References ACE_GUARD_RETURN, ACE_TCHAR, ACE_TRACE, remove_dll_components_i(), and shutting_down_.

Referenced by ACE_DLL_Handle::close().

00177 {
00178   ACE_TRACE ("ACE_Framework_Repository::remove_dll_components");
00179 
00180   if (this->shutting_down_)
00181     return this->remove_dll_components_i (dll_name);
00182   ACE_MT (ACE_GUARD_RETURN (ACE_Thread_Mutex, ace_mon, this->lock_, -1));
00183 
00184   return this->remove_dll_components_i (dll_name);
00185 }

int ACE_Framework_Repository::remove_dll_components_i const ACE_TCHAR dll_name  )  [private]
 

Actually removes the dll components, must be called with locks held.

Definition at line 188 of file Framework_Component.cpp.

References ACE_DEBUG, ACE_LIB_TEXT, ACE_TCHAR, ACE_TRACE, compact(), component_vector_, ACE::debug(), LM_DEBUG, and ACE_OS::strcmp().

Referenced by remove_dll_components().

00189 {
00190   ACE_TRACE ("ACE_Framework_Repository::remove_dll_components_i");
00191 
00192   int i;
00193   int retval = -1;
00194 
00195   for (i = 0; i < this->current_size_; i++)
00196     if (this->component_vector_[i] &&
00197         ACE_OS::strcmp (this->component_vector_[i]->dll_name_, dll_name) == 0)
00198       {
00199           if (ACE::debug ())
00200             ACE_DEBUG ((LM_DEBUG,
00201                         ACE_LIB_TEXT ("AFR::remove_dll_components_i (%s) ")
00202                         ACE_LIB_TEXT ("component \"%s\"\n"),
00203                         dll_name, this->component_vector_[i]->name_));
00204         delete this->component_vector_[i];
00205         this->component_vector_[i] = 0;
00206         ++retval;
00207       }
00208 
00209   this->compact ();
00210 
00211   return retval == -1 ? -1 : 0;
00212 }

ACE_INLINE int ACE_Framework_Repository::total_size void   )  const
 

Return the total size of the repository.

Definition at line 32 of file Framework_Component.inl.

References ACE_GUARD_RETURN, and ACE_TRACE.

00033 {
00034   ACE_TRACE ("ACE_Framework_Repository::total_size");
00035   ACE_MT (ACE_GUARD_RETURN (ACE_Thread_Mutex, ace_mon, (ACE_Thread_Mutex &) this->lock_, -1));
00036   return this->total_size_;
00037 }


Friends And Related Function Documentation

friend class ACE_Framework_Component [friend]
 

Definition at line 105 of file Framework_Component.h.


Member Data Documentation

ACE_Framework_Repository::ACE_ALLOC_HOOK_DECLARE
 

Declare the dynamic allocation hooks.

Definition at line 153 of file Framework_Component.h.

ACE_Framework_Component** ACE_Framework_Repository::component_vector_ [private]
 

Contains all the framework components.

Definition at line 176 of file Framework_Component.h.

Referenced by close(), compact(), open(), register_component(), remove_component(), and remove_dll_components_i().

int ACE_Framework_Repository::current_size_ [private]
 

Current number of components.

Definition at line 179 of file Framework_Component.h.

ACE_Framework_Repository * ACE_Framework_Repository::repository_ = 0 [static, private]
 

Pointer to a process-wide ACE_Framework_Repository.

Definition at line 35 of file Framework_Component.cpp.

Referenced by close_singleton(), and instance().

sig_atomic_t ACE_Framework_Repository::shutting_down_ = 0 [static, private]
 

Flag set when repository is the process of shutting down. This is necessary to keep from self-deadlocking since some of the components might make calls back to the repository to unload their components, e.g., ACE_DLL_Manager.

Definition at line 32 of file Framework_Component.cpp.

Referenced by close(), and remove_dll_components().

int ACE_Framework_Repository::total_size_ [private]
 

Maximum number of components.

Definition at line 182 of file Framework_Component.h.


The documentation for this class was generated from the following files:
Generated on Thu Nov 9 11:22:26 2006 for ACE by doxygen 1.3.6