source: NonGTP/Xerces/xercesc/dom/impl/DOMRangeImpl.hpp @ 188

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

added xercesc to support

Line 
1#ifndef DOMRangeImpl_HEADER_GUARD_
2#define DOMRangeImpl_HEADER_GUARD_
3
4/*
5 * The Apache Software License, Version 1.1
6 *
7 * Copyright (c) 2001-2002 The Apache Software Foundation.  All rights
8 * reserved.
9 *
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
12 * are met:
13 *
14 * 1. Redistributions of source code must retain the above copyright
15 *    notice, this list of conditions and the following disclaimer.
16 *
17 * 2. Redistributions in binary form must reproduce the above copyright
18 *    notice, this list of conditions and the following disclaimer in
19 *    the documentation and/or other materials provided with the
20 *    distribution.
21 *
22 * 3. The end-user documentation included with the redistribution,
23 *    if any, must include the following acknowledgment:
24 *       "This product includes software developed by the
25 *        Apache Software Foundation (http://www.apache.org/)."
26 *    Alternately, this acknowledgment may appear in the software itself,
27 *    if and wherever such third-party acknowledgments normally appear.
28 *
29 * 4. The names "Xerces" and "Apache Software Foundation" must
30 *    not be used to endorse or promote products derived from this
31 *    software without prior written permission. For written
32 *    permission, please contact apache\@apache.org.
33 *
34 * 5. Products derived from this software may not be called "Apache",
35 *    nor may "Apache" appear in their name, without prior written
36 *    permission of the Apache Software Foundation.
37 *
38 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
39 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
40 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
41 * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
42 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
43 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
44 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
45 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
46 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
47 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
48 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
49 * SUCH DAMAGE.
50 * ====================================================================
51 *
52 * This software consists of voluntary contributions made by many
53 * individuals on behalf of the Apache Software Foundation, and was
54 * originally based on software copyright (c) 2001, International
55 * Business Machines, Inc., http://www.ibm.com .  For more information
56 * on the Apache Software Foundation, please see
57 * <http://www.apache.org/>.
58 */
59
60 /*
61 * $Id: DOMRangeImpl.hpp,v 1.7 2004/01/29 11:44:27 cargilld Exp $
62 */
63
64//
65//  This file is part of the internal implementation of the C++ XML DOM.
66//  It should NOT be included or used directly by application programs.
67//
68//  Applications should include the file <xercesc/dom/DOM.hpp> for the entire
69//  DOM API, or xercesc/dom/DOM*.hpp for individual DOM classes, where the class
70//  name is substituded for the *.
71//
72
73#include <xercesc/util/XercesDefs.hpp>
74#include <xercesc/dom/DOMRange.hpp>
75#include <xercesc/util/PlatformUtils.hpp>
76
77XERCES_CPP_NAMESPACE_BEGIN
78
79
80
81class       DOMNode;
82class       DOMDocumentFragment;
83class       DOMDocument;
84class       DOMText;
85class       MemoryManager;
86
87class CDOM_EXPORT DOMRangeImpl: public DOMRange {
88private:
89    enum TraversalType {
90        EXTRACT_CONTENTS = 1,
91        CLONE_CONTENTS   = 2,
92        DELETE_CONTENTS  = 3
93    };
94
95    enum TraversePoint {
96        BEFORE  = -1,
97        START   = 0,
98        AFTER   = 1
99    };
100
101    //private data
102
103    DOMNode*     fStartContainer;
104    XMLSize_t    fStartOffset;
105    DOMNode*     fEndContainer;
106    XMLSize_t    fEndOffset;
107    bool         fCollapsed;
108    DOMDocument* fDocument;
109    bool         fDetached;
110
111    DOMNode*     fRemoveChild;
112    MemoryManager* fMemoryManager;
113
114public:
115    //c'tor
116    DOMRangeImpl(DOMDocument* doc, MemoryManager* const manager = XMLPlatformUtils::fgMemoryManager);
117    DOMRangeImpl(const DOMRangeImpl& other);
118
119    //d'tor
120    ~DOMRangeImpl();
121
122    //getter functions
123    virtual DOMNode* getStartContainer() const;
124    virtual XMLSize_t getStartOffset() const;
125    virtual DOMNode* getEndContainer() const;
126    virtual XMLSize_t getEndOffset() const;
127    virtual bool getCollapsed() const;
128    virtual const DOMNode* getCommonAncestorContainer() const;
129
130    //setter functions
131    virtual void setStart(const DOMNode *parent, XMLSize_t offset);
132    virtual void setEnd(const DOMNode *parent, XMLSize_t offset);
133
134    virtual void setStartBefore(const DOMNode *refNode);
135    virtual void setStartAfter(const DOMNode *refNode);
136    virtual void setEndBefore(const DOMNode *refNode);
137    virtual void setEndAfter(const DOMNode *refNode);
138
139    //misc functions
140    virtual void collapse(bool toStart);
141    virtual void selectNode(const DOMNode *node);
142    virtual void selectNodeContents(const DOMNode *node);
143
144    //Functions related to comparing range Boundrary-Points
145    virtual short compareBoundaryPoints(CompareHow how, const DOMRange* range) const;
146    virtual void deleteContents();
147    virtual DOMDocumentFragment* extractContents();
148    virtual DOMDocumentFragment* cloneContents() const;
149    virtual void insertNode(DOMNode* node);
150
151    //Misc functions
152    virtual void surroundContents(DOMNode *node);
153    virtual DOMRange* cloneRange() const;
154    virtual const XMLCh* toString() const;
155    virtual void detach();
156    virtual void release();
157
158    //getter functions
159    DOMDocument*         getDocument();
160
161    // functions to inform all existing valid ranges about a change
162    void updateSplitInfo(DOMNode* oldNode, DOMNode* startNode, XMLSize_t offset);
163    void updateRangeForInsertedNode(DOMNode* node);
164    void receiveReplacedText(DOMNode* node);
165    void updateRangeForDeletedText(DOMNode* node, XMLSize_t offset, int count);
166    void updateRangeForInsertedText(DOMNode* node, XMLSize_t offset, int count);
167    void updateRangeForDeletedNode(DOMNode* node);
168
169private:
170    //setter functions
171    void        setStartContainer(const DOMNode* node);
172    void        setStartOffset(XMLSize_t offset) ;
173    void        setEndContainer(const DOMNode* node);
174    void        setEndOffset(XMLSize_t offset) ;
175
176    //misc functions
177    void        validateNode(const DOMNode* node) const;
178    bool        isValidAncestorType(const DOMNode* node) const;
179    bool        hasLegalRootContainer(const DOMNode* node) const;
180    bool        isLegalContainedNode(const DOMNode* node ) const;
181    void        checkIndex(const DOMNode* node, XMLSize_t offset) const;
182    static bool isAncestorOf(const DOMNode* a, const DOMNode* b);
183
184    XMLSize_t   indexOf(const DOMNode* child, const DOMNode* parent) const;
185
186    const DOMNode*       commonAncestorOf(const DOMNode* pointA, const DOMNode* pointB) const;
187    DOMNode*             nextNode(const DOMNode* node, bool visitChildren) const;
188    DOMDocumentFragment* traverseContents(TraversalType type);
189    void                  checkReadOnly(DOMNode* start, DOMNode* end,
190                                  XMLSize_t starOffset, XMLSize_t endOffset);
191    void                  recurseTreeAndCheck(DOMNode* start, DOMNode* end);
192    DOMNode*             removeChild(DOMNode* parent, DOMNode* child);
193
194    DOMDocumentFragment* traverseSameContainer( int how );
195    DOMDocumentFragment* traverseCommonStartContainer( DOMNode *endAncestor, int how );
196    DOMDocumentFragment* traverseCommonEndContainer( DOMNode *startAncestor, int how );
197    DOMDocumentFragment* traverseCommonAncestors( DOMNode *startAncestor, DOMNode *endAncestor, int how );
198    DOMNode*    traverseRightBoundary( DOMNode *root, int how );
199    DOMNode*    traverseLeftBoundary( DOMNode *root, int how );
200    DOMNode*    traverseNode( DOMNode *n, bool isFullySelected, bool isLeft, int how );
201    DOMNode*    traverseFullySelected( DOMNode *n, int how );
202    DOMNode*    traversePartiallySelected( DOMNode *n, int how );
203    DOMNode*    traverseTextNode( DOMNode *n, bool isLeft, int how );
204    DOMNode*    getSelectedNode( DOMNode *container, int offset );
205
206    // -----------------------------------------------------------------------
207    // Unimplemented constructors and operators
208    // -----------------------------------------------------------------------
209    DOMRangeImpl & operator = (const DOMRangeImpl &);
210};
211
212XERCES_CPP_NAMESPACE_END
213
214#endif
Note: See TracBrowser for help on using the repository browser.