aboutsummaryrefslogtreecommitdiff
path: root/dep/ACE_wrappers/ace/Cleanup.h
diff options
context:
space:
mode:
authormaximius <none@none>2009-10-17 15:51:44 -0700
committermaximius <none@none>2009-10-17 15:51:44 -0700
commite585187b248f48b3c6e9247b49fa07c6565d65e5 (patch)
tree637c5b7ddacf41040bef4ea4f75a97da64c6a9bc /dep/ACE_wrappers/ace/Cleanup.h
parent26b5e033ffde3d161382fc9addbfa99738379641 (diff)
*Backed out changeset 3be01fb200a5
--HG-- branch : trunk
Diffstat (limited to 'dep/ACE_wrappers/ace/Cleanup.h')
-rw-r--r--dep/ACE_wrappers/ace/Cleanup.h28
1 files changed, 28 insertions, 0 deletions
diff --git a/dep/ACE_wrappers/ace/Cleanup.h b/dep/ACE_wrappers/ace/Cleanup.h
index 5f38ace7276..c38db701360 100644
--- a/dep/ACE_wrappers/ace/Cleanup.h
+++ b/dep/ACE_wrappers/ace/Cleanup.h
@@ -1,4 +1,5 @@
// -*- C++ -*-
+
//=============================================================================
/**
* @file Cleanup.h
@@ -12,21 +13,29 @@
* Originally in OS.h.
*/
//=============================================================================
+
#ifndef ACE_CLEANUP_H
# define ACE_CLEANUP_H
+
# include /**/ "ace/pre.h"
+
# include "ace/config-lite.h"
+
# if !defined (ACE_LACKS_PRAGMA_ONCE)
# pragma once
# endif /* ACE_LACKS_PRAGMA_ONCE */
+
#include /**/ "ace/ACE_export.h"
+
#if (defined (ACE_HAS_VERSIONED_NAMESPACE) && ACE_HAS_VERSIONED_NAMESPACE == 1)
# include "ace/Global_Macros.h"
# define ACE_CLEANUP_DESTROYER_NAME ACE_PREPROC_CONCATENATE(ACE_VERSIONED_NAMESPACE_NAME, _ace_cleanup_destroyer)
#else
# define ACE_CLEANUP_DESTROYER_NAME ace_cleanup_destroyer
#endif /* ACE_HAS_VERSIONED_NAMESPACE == 1 */
+
ACE_BEGIN_VERSIONED_NAMESPACE_DECL
+
/**
* @class ACE_Cleanup
*
@@ -37,14 +46,18 @@ class ACE_Export ACE_Cleanup
public:
/// No-op constructor.
ACE_Cleanup (void);
+
/// Destructor.
virtual ~ACE_Cleanup (void);
+
/// Cleanup method that, by default, simply deletes itself.
virtual void cleanup (void *param = 0);
};
+
// Adapter for cleanup, used by ACE_Object_Manager.
extern "C" ACE_Export
void ACE_CLEANUP_DESTROYER_NAME (ACE_Cleanup *, void *param = 0);
+
/**
* @class ACE_Cleanup_Info
*
@@ -55,18 +68,25 @@ class ACE_Export ACE_Cleanup_Info
public:
/// Default constructor.
ACE_Cleanup_Info (void);
+
/// Equality operator.
bool operator== (const ACE_Cleanup_Info &o) const;
+
/// Inequality operator.
bool operator!= (const ACE_Cleanup_Info &o) const;
+
/// Point to object that gets passed into the <cleanup_hook_>.
void *object_;
+
/// Cleanup hook that gets called back.
ACE_CLEANUP_FUNC cleanup_hook_;
+
/// Parameter passed to the <cleanup_hook_>.
void *param_;
};
+
class ACE_Cleanup_Info_Node;
+
/**
* @class ACE_OS_Exit_Info
*
@@ -79,16 +99,21 @@ class ACE_Export ACE_OS_Exit_Info
public:
/// Default constructor.
ACE_OS_Exit_Info (void);
+
/// Destructor.
~ACE_OS_Exit_Info (void);
+
/// Use to register a cleanup hook.
int at_exit_i (void *object, ACE_CLEANUP_FUNC cleanup_hook, void *param);
+
/// Look for a registered cleanup hook object. Returns 1 if already
/// registered, 0 if not.
int find (void *object);
+
/// Call all registered cleanup hooks, in reverse order of
/// registration.
void call_hooks ();
+
private:
/**
* Keeps track of all registered objects. The last node is only
@@ -97,7 +122,9 @@ private:
*/
ACE_Cleanup_Info_Node *registered_objects_;
};
+
ACE_END_VERSIONED_NAMESPACE_DECL
+
# if defined (ACE_HAS_INLINED_OSCALLS)
# if defined (ACE_INLINE)
# undef ACE_INLINE
@@ -105,6 +132,7 @@ ACE_END_VERSIONED_NAMESPACE_DECL
# define ACE_INLINE inline
# include "ace/Cleanup.inl"
# endif /* ACE_HAS_INLINED_OSCALLS */
+
# include /**/ "ace/post.h"
#endif /* ACE_CLEANUP_H */