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

 DEFAULT_SIZE = ACE_DEFAULT_FRAMEWORK_REPOSITORY_SIZE
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

static ACE_Framework_Repositoryinstance (int size=ACE_Framework_Repository::DEFAULT_SIZE)
 Get pointer to a process-wide ACE_Framework_Repository.
static 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

static ACE_Framework_Repositoryrepository_ = 0
 Pointer to a process-wide ACE_Framework_Repository.
static 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

Enumerator:
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 ACE_OS::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_TEXT, ACE_TRACE, and LM_ERROR.

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_TEXT ("%p\n"),
00277                 ACE_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_, current_size_, and shutting_down_.

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 current_size_.

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, ACE_TRACE, and current_size_.

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 ACE_Framework_Repository.

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, component_vector_, and total_size_.

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_TEXT, ACE_TRACE, current_size_, 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_TEXT ("AFR::register_component: error, ")
00141                            ACE_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_TRACE, current_size_, 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_TRACE, and remove_dll_components_i().

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_TEXT, ACE_TRACE, current_size_, 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_TEXT ("AFR::remove_dll_components_i (%s) ")
00202                         ACE_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, ACE_TRACE, and total_size_.

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(), and open().

int ACE_Framework_Repository::current_size_ [private]

Current number of components.

Definition at line 179 of file Framework_Component.h.

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

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

Pointer to a process-wide ACE_Framework_Repository.

Definition at line 185 of file Framework_Component.h.

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 191 of file Framework_Component.h.

Referenced by close().

int ACE_Framework_Repository::total_size_ [private]

Maximum number of components.

Definition at line 182 of file Framework_Component.h.

Referenced by open(), and total_size().


The documentation for this class was generated from the following files:
Generated on Tue Feb 2 17:35:08 2010 for ACE by  doxygen 1.4.7