secureswitools/swisistools/source/xmlparser/xerces/include/xercesc/util/XMLRegisterCleanup.hpp
changeset 0 ba25891c3a9e
child 1 c42dffbd5b4f
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/secureswitools/swisistools/source/xmlparser/xerces/include/xercesc/util/XMLRegisterCleanup.hpp	Thu Dec 17 08:51:10 2009 +0200
@@ -0,0 +1,101 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description: 
+*
+*/
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ * 
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ * 
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+/*
+ * $Id: XMLRegisterCleanup.hpp 568078 2007-08-21 11:43:25Z amassari $
+ */
+
+#if !defined(XMLREGISTERCLEANUP_HPP)
+#define XMLREGISTERCLEANUP_HPP
+
+#include <xercesc/util/Mutexes.hpp>
+
+XERCES_CPP_NAMESPACE_BEGIN
+
+//
+//  For internal use only.
+//
+//  This class is used by the platform utilities class to support
+//  reinitialisation of global/static data which is lazily created.
+//  Since that data is widely spread out the platform utilities
+//  class cannot know about them directly. So, the code that creates such
+//  objects creates an registers a cleanup for the object. The platform
+//  termination call will iterate the list and delete the objects.
+//
+//  N.B. These objects need to be statically allocated.  I couldn't think
+//  of a neat way of ensuring this - can anyone else?
+
+class XMLUTIL_EXPORT XMLRegisterCleanup
+{
+public :
+	// The cleanup function to be called on XMLPlatformUtils::Terminate()
+	typedef void (*XMLCleanupFn)();
+	
+	void doCleanup(); 
+
+	// This function is called during initialisation of static data to
+	// register a function to be called on XMLPlatformUtils::Terminate.
+	// It gives an object that uses static data an opportunity to reset
+	// such data.
+	void registerCleanup(XMLCleanupFn cleanupFn);
+
+	// This function can be called either from XMLPlatformUtils::Terminate
+	// to state that the cleanup has been performed and should not be
+	// performed again, or from code that you have written that determines
+	// that cleanup is no longer necessary.
+	void unregisterCleanup();
+
+	// The default constructor sets a state that ensures that this object
+	// will do nothing
+	XMLRegisterCleanup();
+
+private:
+    // -----------------------------------------------------------------------
+    //  Unimplemented constructors and operators
+    // -----------------------------------------------------------------------
+	XMLRegisterCleanup(const XMLRegisterCleanup&);
+    XMLRegisterCleanup& operator=(const XMLRegisterCleanup&);
+
+	// This is the cleanup function to be called
+	XMLCleanupFn m_cleanupFn;
+
+	// These are list pointers to the next/prev cleanup function to be called
+	XMLRegisterCleanup *m_nextCleanup, *m_prevCleanup;
+
+	// This function reinitialises the object to the default state
+	void resetCleanup();
+};
+
+XERCES_CPP_NAMESPACE_END
+
+#endif