source: NonGTP/Xerces/xercesc/dom/deprecated/RefCountedImpl.hpp @ 188

Revision 188, 4.4 KB checked in by mattausch, 20 years ago (diff)

added xercesc to support

Line 
1#ifndef RefCountedImpl_HEADER_GUARD_
2#define RefCountedImpl_HEADER_GUARD_
3/*
4 * The Apache Software License, Version 1.1
5 *
6 * Copyright (c) 1999-2002 The Apache Software Foundation.  All rights
7 * reserved.
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions
11 * are met:
12 *
13 * 1. Redistributions of source code must retain the above copyright
14 *    notice, this list of conditions and the following disclaimer.
15 *
16 * 2. Redistributions in binary form must reproduce the above copyright
17 *    notice, this list of conditions and the following disclaimer in
18 *    the documentation and/or other materials provided with the
19 *    distribution.
20 *
21 * 3. The end-user documentation included with the redistribution,
22 *    if any, must include the following acknowledgment:
23 *       "This product includes software developed by the
24 *        Apache Software Foundation (http://www.apache.org/)."
25 *    Alternately, this acknowledgment may appear in the software itself,
26 *    if and wherever such third-party acknowledgments normally appear.
27 *
28 * 4. The names "Xerces" and "Apache Software Foundation" must
29 *    not be used to endorse or promote products derived from this
30 *    software without prior written permission. For written
31 *    permission, please contact apache\@apache.org.
32 *
33 * 5. Products derived from this software may not be called "Apache",
34 *    nor may "Apache" appear in their name, without prior written
35 *    permission of the Apache Software Foundation.
36 *
37 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
38 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
39 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
40 * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
41 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
42 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
43 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
44 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
45 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
46 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
47 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
48 * SUCH DAMAGE.
49 * ====================================================================
50 *
51 * This software consists of voluntary contributions made by many
52 * individuals on behalf of the Apache Software Foundation, and was
53 * originally based on software copyright (c) 1999, International
54 * Business Machines, Inc., http://www.ibm.com .  For more information
55 * on the Apache Software Foundation, please see
56 * <http://www.apache.org/>.
57 */
58
59/*
60 * $Id: RefCountedImpl.hpp,v 1.4 2003/05/15 18:25:53 knoaman Exp $
61 */
62
63//
64//  This file is part of the internal implementation of the C++ XML DOM.
65//  It should NOT be included or used directly by application programs.
66//
67//  Applications should include the file <xercesc/dom/deprecated/DOM.hpp> for the entire
68//  DOM API, or DOM_*.hpp for individual DOM classes, where the class
69//  name is substituded for the *.
70//
71
72
73
74#include <xercesc/util/XMemory.hpp>
75
76XERCES_CPP_NAMESPACE_BEGIN
77
78
79class CDOM_EXPORT RefCountedImpl : public XMemory
80{
81public:
82    int                     nodeRefCount;
83
84                    RefCountedImpl();
85    virtual         ~RefCountedImpl();
86
87    static void     addRef(RefCountedImpl *thisNode);
88    static void     removeRef(RefCountedImpl *thisNode);
89
90    virtual void    referenced();   // This function will be called by
91                                    //  the reference counting implementation
92                                    //  whenever the reference count transitions
93                                    //  from 0 to 1.
94
95    virtual void    unreferenced(); // unreferenced() is called whenever the
96                                    //  the ref count goes from 1 to 0.  (Nodes are
97                                    //  not deleted when the ref count goes to zero
98                                    //  if they are in the doc tree and the tree
99                                    //  is still referenced, so a nodes referenced /
100                                    //  unreferenced state may switch many times
101                                    //  over its life time.)
102};
103
104XERCES_CPP_NAMESPACE_END
105
106#endif
Note: See TracBrowser for help on using the repository browser.