xref: /trunk/main/connectivity/source/inc/dbase/dindexnode.hxx (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir  *
5*cdf0e10cSrcweir  * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir  *
7*cdf0e10cSrcweir  * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir  *
11*cdf0e10cSrcweir  * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir  * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir  * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir  *
15*cdf0e10cSrcweir  * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir  * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir  * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir  * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir  * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir  * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir  *
26*cdf0e10cSrcweir  ************************************************************************/
27*cdf0e10cSrcweir #ifndef _CONNECTIVITY_DBASE_INDEXNODE_HXX_
28*cdf0e10cSrcweir #define _CONNECTIVITY_DBASE_INDEXNODE_HXX_
29*cdf0e10cSrcweir 
30*cdf0e10cSrcweir #include "file/fcode.hxx"
31*cdf0e10cSrcweir #include "file/FTable.hxx"
32*cdf0e10cSrcweir #include "dbase/DIndexPage.hxx"
33*cdf0e10cSrcweir #include "connectivity/FValue.hxx"
34*cdf0e10cSrcweir #include <tools/ref.hxx>
35*cdf0e10cSrcweir 
36*cdf0e10cSrcweir #define NODE_NOTFOUND 0xFFFF
37*cdf0e10cSrcweir #define PAGE_SIZE 512
38*cdf0e10cSrcweir 
39*cdf0e10cSrcweir namespace connectivity
40*cdf0e10cSrcweir {
41*cdf0e10cSrcweir     namespace dbase
42*cdf0e10cSrcweir     {
43*cdf0e10cSrcweir 
44*cdf0e10cSrcweir         class ONDXNode;
45*cdf0e10cSrcweir         class ODbaseIndex;
46*cdf0e10cSrcweir         //==================================================================
47*cdf0e10cSrcweir         // Index Key
48*cdf0e10cSrcweir         //==================================================================
49*cdf0e10cSrcweir         typedef file::OOperand ONDXKey_BASE;
50*cdf0e10cSrcweir         class ONDXKey : public ONDXKey_BASE
51*cdf0e10cSrcweir         {
52*cdf0e10cSrcweir             friend class ONDXNode;
53*cdf0e10cSrcweir             sal_uInt32          nRecord;                /* Satzzeiger               */
54*cdf0e10cSrcweir             ORowSetValue    xValue;                 /* Schluesselwert           */
55*cdf0e10cSrcweir 
56*cdf0e10cSrcweir         public:
57*cdf0e10cSrcweir             ONDXKey(sal_uInt32 nRec=0);
58*cdf0e10cSrcweir             ONDXKey(const ORowSetValue& rVal, sal_Int32 eType, sal_uInt32 nRec);
59*cdf0e10cSrcweir             ONDXKey(const rtl::OUString& aStr, sal_uInt32 nRec = 0);
60*cdf0e10cSrcweir             ONDXKey(double aVal, sal_uInt32 nRec = 0);
61*cdf0e10cSrcweir 
62*cdf0e10cSrcweir             inline ONDXKey(const ONDXKey& rKey);
63*cdf0e10cSrcweir 
64*cdf0e10cSrcweir             inline ONDXKey& operator= (const ONDXKey& rKey);
65*cdf0e10cSrcweir             virtual void setValue(const ORowSetValue& _rVal);
66*cdf0e10cSrcweir 
67*cdf0e10cSrcweir             virtual const ORowSetValue& getValue() const;
68*cdf0e10cSrcweir 
69*cdf0e10cSrcweir             sal_uInt32 GetRecord() const        { return nRecord;   }
70*cdf0e10cSrcweir             void setRecord(sal_uInt32 _nRec)    { nRecord = _nRec;  }
71*cdf0e10cSrcweir             void   ResetRecord()            { nRecord = 0;      }
72*cdf0e10cSrcweir 
73*cdf0e10cSrcweir             sal_Bool operator == (const ONDXKey& rKey) const;
74*cdf0e10cSrcweir             sal_Bool operator != (const ONDXKey& rKey) const;
75*cdf0e10cSrcweir             sal_Bool operator <  (const ONDXKey& rKey) const;
76*cdf0e10cSrcweir             sal_Bool operator <= (const ONDXKey& rKey) const;
77*cdf0e10cSrcweir             sal_Bool operator >  (const ONDXKey& rKey) const;
78*cdf0e10cSrcweir             sal_Bool operator >= (const ONDXKey& rKey) const;
79*cdf0e10cSrcweir 
80*cdf0e10cSrcweir             sal_Bool Load (SvFileStream& rStream, sal_Bool bText);
81*cdf0e10cSrcweir             sal_Bool Write(SvFileStream& rStream, sal_Bool bText);
82*cdf0e10cSrcweir 
83*cdf0e10cSrcweir             static sal_Bool IsText(sal_Int32 eType);
84*cdf0e10cSrcweir 
85*cdf0e10cSrcweir         private:
86*cdf0e10cSrcweir             StringCompare Compare(const ONDXKey& rKey) const;
87*cdf0e10cSrcweir         };
88*cdf0e10cSrcweir 
89*cdf0e10cSrcweir 
90*cdf0e10cSrcweir 
91*cdf0e10cSrcweir 
92*cdf0e10cSrcweir         //==================================================================
93*cdf0e10cSrcweir         // Index Seitenverweis
94*cdf0e10cSrcweir         //==================================================================
95*cdf0e10cSrcweir         SV_DECL_REF(ONDXPage) // Basisklasse da weitere Informationen gehalten werden muessen
96*cdf0e10cSrcweir 
97*cdf0e10cSrcweir 
98*cdf0e10cSrcweir         class ONDXPagePtr : public ONDXPageRef
99*cdf0e10cSrcweir         {
100*cdf0e10cSrcweir             friend  SvStream& operator << (SvStream &rStream, const ONDXPagePtr&);
101*cdf0e10cSrcweir             friend  SvStream& operator >> (SvStream &rStream, ONDXPagePtr&);
102*cdf0e10cSrcweir 
103*cdf0e10cSrcweir             sal_uInt32  nPagePos;       // Position in der Indexdatei
104*cdf0e10cSrcweir 
105*cdf0e10cSrcweir         public:
106*cdf0e10cSrcweir             ONDXPagePtr(sal_uInt32 nPos = 0):nPagePos(nPos){}
107*cdf0e10cSrcweir             ONDXPagePtr(const ONDXPagePtr& rRef);
108*cdf0e10cSrcweir             ONDXPagePtr(ONDXPage* pRefPage);
109*cdf0e10cSrcweir 
110*cdf0e10cSrcweir             ONDXPagePtr& operator=(const ONDXPagePtr& rRef);
111*cdf0e10cSrcweir             ONDXPagePtr& operator=(ONDXPage* pPageRef);
112*cdf0e10cSrcweir 
113*cdf0e10cSrcweir             sal_uInt32 GetPagePos() const {return nPagePos;}
114*cdf0e10cSrcweir             sal_Bool HasPage() const {return nPagePos != 0;}
115*cdf0e10cSrcweir             //  sal_Bool Is() const { return isValid(); }
116*cdf0e10cSrcweir         };
117*cdf0e10cSrcweir         //==================================================================
118*cdf0e10cSrcweir         // Index Seite
119*cdf0e10cSrcweir         //==================================================================
120*cdf0e10cSrcweir         class ONDXPage : public SvRefBase
121*cdf0e10cSrcweir         {
122*cdf0e10cSrcweir             friend class ODbaseIndex;
123*cdf0e10cSrcweir 
124*cdf0e10cSrcweir             friend  SvStream& operator << (SvStream &rStream, const ONDXPage&);
125*cdf0e10cSrcweir             friend  SvStream& operator >> (SvStream &rStream, ONDXPage&);
126*cdf0e10cSrcweir 
127*cdf0e10cSrcweir             sal_uInt32      nPagePos;               // Position in der Indexdatei
128*cdf0e10cSrcweir             sal_Bool        bModified : 1;
129*cdf0e10cSrcweir             sal_uInt16      nCount;
130*cdf0e10cSrcweir 
131*cdf0e10cSrcweir             ONDXPagePtr aParent,            // VaterSeite
132*cdf0e10cSrcweir                         aChild;             // Zeiger auf rechte ChildPage
133*cdf0e10cSrcweir             ODbaseIndex& rIndex;
134*cdf0e10cSrcweir             ONDXNode*  ppNodes;             // array von Knoten
135*cdf0e10cSrcweir 
136*cdf0e10cSrcweir         public:
137*cdf0e10cSrcweir             // Knoten Operationen
138*cdf0e10cSrcweir             sal_uInt16  Count() const {return nCount;}
139*cdf0e10cSrcweir 
140*cdf0e10cSrcweir             sal_Bool    Insert(ONDXNode& rNode, sal_uInt32 nRowsLeft = 0);
141*cdf0e10cSrcweir             sal_Bool    Insert(sal_uInt16 nIndex, ONDXNode& rNode);
142*cdf0e10cSrcweir             sal_Bool    Append(ONDXNode& rNode);
143*cdf0e10cSrcweir             sal_Bool    Delete(sal_uInt16);
144*cdf0e10cSrcweir             void    Remove(sal_uInt16);
145*cdf0e10cSrcweir             void    Release(sal_Bool bSave = sal_True);
146*cdf0e10cSrcweir             void    ReleaseFull(sal_Bool bSave = sal_True);
147*cdf0e10cSrcweir 
148*cdf0e10cSrcweir             // Aufteilen und Zerlegen
149*cdf0e10cSrcweir             ONDXNode Split(ONDXPage& rPage);
150*cdf0e10cSrcweir             void Merge(sal_uInt16 nParentNodePos, ONDXPagePtr xPage);
151*cdf0e10cSrcweir 
152*cdf0e10cSrcweir             // Zugriffsoperationen
153*cdf0e10cSrcweir             ONDXNode& operator[] (sal_uInt16 nPos);
154*cdf0e10cSrcweir             const ONDXNode& operator[] (sal_uInt16 nPos) const;
155*cdf0e10cSrcweir 
156*cdf0e10cSrcweir             sal_Bool IsRoot() const;
157*cdf0e10cSrcweir             sal_Bool IsLeaf() const;
158*cdf0e10cSrcweir             sal_Bool IsModified() const;
159*cdf0e10cSrcweir             sal_Bool HasParent();
160*cdf0e10cSrcweir             sal_Bool HasChild() const;
161*cdf0e10cSrcweir 
162*cdf0e10cSrcweir             sal_Bool IsFull() const;
163*cdf0e10cSrcweir 
164*cdf0e10cSrcweir             sal_uInt32 GetPagePos() const {return nPagePos;}
165*cdf0e10cSrcweir             ONDXPagePtr& GetChild(ODbaseIndex* pIndex = 0);
166*cdf0e10cSrcweir 
167*cdf0e10cSrcweir             // Parent braucht nicht nachgeladen zu werden
168*cdf0e10cSrcweir             ONDXPagePtr GetParent();
169*cdf0e10cSrcweir             ODbaseIndex& GetIndex() {return rIndex;}
170*cdf0e10cSrcweir             const ODbaseIndex& GetIndex() const {return rIndex;}
171*cdf0e10cSrcweir 
172*cdf0e10cSrcweir             // Setzen des Childs, ueber Referenz, um die PagePos zu erhalten
173*cdf0e10cSrcweir             void SetChild(ONDXPagePtr aCh);
174*cdf0e10cSrcweir             void SetParent(ONDXPagePtr aPa);
175*cdf0e10cSrcweir 
176*cdf0e10cSrcweir             sal_uInt16 Search(const ONDXKey& rSearch);
177*cdf0e10cSrcweir             sal_uInt16 Search(const ONDXPage* pPage);
178*cdf0e10cSrcweir             void   SearchAndReplace(const ONDXKey& rSearch, ONDXKey& rReplace);
179*cdf0e10cSrcweir 
180*cdf0e10cSrcweir         protected:
181*cdf0e10cSrcweir             ONDXPage(ODbaseIndex& rIndex, sal_uInt32 nPos, ONDXPage* = NULL);
182*cdf0e10cSrcweir             ~ONDXPage();
183*cdf0e10cSrcweir 
184*cdf0e10cSrcweir             virtual void QueryDelete();
185*cdf0e10cSrcweir 
186*cdf0e10cSrcweir             void SetModified(sal_Bool bMod) {bModified = bMod;}
187*cdf0e10cSrcweir             void SetPagePos(sal_uInt32 nPage) {nPagePos = nPage;}
188*cdf0e10cSrcweir 
189*cdf0e10cSrcweir             sal_Bool Find(const ONDXKey&);  // rek. Abstieg
190*cdf0e10cSrcweir             sal_uInt16 FindPos(const ONDXKey& rKey) const;
191*cdf0e10cSrcweir 
192*cdf0e10cSrcweir #if OSL_DEBUG_LEVEL > 1
193*cdf0e10cSrcweir             void PrintPage();
194*cdf0e10cSrcweir #endif
195*cdf0e10cSrcweir         };
196*cdf0e10cSrcweir 
197*cdf0e10cSrcweir         SV_IMPL_REF(ONDXPage);
198*cdf0e10cSrcweir 
199*cdf0e10cSrcweir         SvStream& operator << (SvStream &rStream, const ONDXPagePtr&);
200*cdf0e10cSrcweir         SvStream& operator >> (SvStream &rStream, ONDXPagePtr&);
201*cdf0e10cSrcweir 
202*cdf0e10cSrcweir         inline sal_Bool ONDXPage::IsRoot() const {return !aParent.Is();}
203*cdf0e10cSrcweir         inline sal_Bool ONDXPage::IsLeaf() const {return !aChild.HasPage();}
204*cdf0e10cSrcweir         inline sal_Bool ONDXPage::IsModified() const {return bModified;}
205*cdf0e10cSrcweir         inline sal_Bool ONDXPage::HasParent() {return aParent.Is();}
206*cdf0e10cSrcweir         inline sal_Bool ONDXPage::HasChild() const {return aChild.HasPage();}
207*cdf0e10cSrcweir         inline ONDXPagePtr ONDXPage::GetParent() {return aParent;}
208*cdf0e10cSrcweir 
209*cdf0e10cSrcweir         inline void ONDXPage::SetParent(ONDXPagePtr aPa = ONDXPagePtr())
210*cdf0e10cSrcweir         {
211*cdf0e10cSrcweir             aParent = aPa;
212*cdf0e10cSrcweir         }
213*cdf0e10cSrcweir 
214*cdf0e10cSrcweir         inline void ONDXPage::SetChild(ONDXPagePtr aCh = ONDXPagePtr())
215*cdf0e10cSrcweir         {
216*cdf0e10cSrcweir             aChild = aCh;
217*cdf0e10cSrcweir             if (aChild.Is())
218*cdf0e10cSrcweir                 aChild->SetParent(this);
219*cdf0e10cSrcweir         }
220*cdf0e10cSrcweir         SvStream& operator >> (SvStream &rStream, ONDXPage& rPage);
221*cdf0e10cSrcweir         SvStream& operator << (SvStream &rStream, const ONDXPage& rPage);
222*cdf0e10cSrcweir 
223*cdf0e10cSrcweir 
224*cdf0e10cSrcweir         typedef ::std::vector<ONDXPage*>    ONDXPageList;
225*cdf0e10cSrcweir 
226*cdf0e10cSrcweir         //==================================================================
227*cdf0e10cSrcweir         // Index Knoten
228*cdf0e10cSrcweir         //==================================================================
229*cdf0e10cSrcweir         class ONDXNode
230*cdf0e10cSrcweir         {
231*cdf0e10cSrcweir             friend class ONDXPage;
232*cdf0e10cSrcweir             ONDXPagePtr aChild;             /* naechster Seitenverweis  */
233*cdf0e10cSrcweir             ONDXKey   aKey;
234*cdf0e10cSrcweir 
235*cdf0e10cSrcweir         public:
236*cdf0e10cSrcweir             ONDXNode(){}
237*cdf0e10cSrcweir             ONDXNode(const ONDXKey& rKey,
238*cdf0e10cSrcweir                        ONDXPagePtr aPagePtr = ONDXPagePtr())
239*cdf0e10cSrcweir                        :aChild(aPagePtr),aKey(rKey) {}
240*cdf0e10cSrcweir 
241*cdf0e10cSrcweir             // verweist der Knoten auf eine Seite
242*cdf0e10cSrcweir             sal_Bool            HasChild() const {return aChild.HasPage();}
243*cdf0e10cSrcweir             // Ist ein Index angegeben, kann gegebenfalls die Seite nachgeladen werden
244*cdf0e10cSrcweir             ONDXPagePtr&    GetChild(ODbaseIndex* pIndex = NULL, ONDXPage* = NULL);
245*cdf0e10cSrcweir 
246*cdf0e10cSrcweir             const ONDXKey& GetKey() const   { return aKey;}
247*cdf0e10cSrcweir             ONDXKey&       GetKey()         { return aKey;}
248*cdf0e10cSrcweir 
249*cdf0e10cSrcweir             // Setzen des Childs, ueber Referenz, um die PagePos zu erhalten
250*cdf0e10cSrcweir             void            SetChild(ONDXPagePtr aCh = ONDXPagePtr(), ONDXPage* = NULL);
251*cdf0e10cSrcweir             void            SetKey(ONDXKey& rKey) {aKey = rKey;}
252*cdf0e10cSrcweir 
253*cdf0e10cSrcweir             void Write(SvStream &rStream, const ONDXPage& rPage) const;
254*cdf0e10cSrcweir             void Read(SvStream &rStream, ODbaseIndex&);
255*cdf0e10cSrcweir         };
256*cdf0e10cSrcweir         //==================================================================
257*cdf0e10cSrcweir         // inline implementation
258*cdf0e10cSrcweir         //==================================================================
259*cdf0e10cSrcweir //      inline ONDXKey::ONDXKey(const ORowSetValue& rVal, sal_Int32 eType, sal_uInt32 nRec)
260*cdf0e10cSrcweir //          : ONDXKey_BASE(eType)
261*cdf0e10cSrcweir //          , nRecord(nRec),xValue(rVal)
262*cdf0e10cSrcweir //      {
263*cdf0e10cSrcweir //      }
264*cdf0e10cSrcweir 
265*cdf0e10cSrcweir 
266*cdf0e10cSrcweir //      inline ONDXKey::ONDXKey(const rtl::OUString& aStr, sal_uInt32 nRec)
267*cdf0e10cSrcweir //                  : ONDXKey_BASE(::com::sun::star::sdbc::DataType::VARCHAR)
268*cdf0e10cSrcweir //                   ,nRecord(nRec)
269*cdf0e10cSrcweir //      {
270*cdf0e10cSrcweir //          if (aStr.len())
271*cdf0e10cSrcweir //              xValue = aStr;
272*cdf0e10cSrcweir //      }
273*cdf0e10cSrcweir 
274*cdf0e10cSrcweir //      inline ONDXKey::ONDXKey(double aVal, sal_uInt32 nRec)
275*cdf0e10cSrcweir //                   : ONDXKey_BASE(::com::sun::star::sdbc::DataType::DOUBLE)
276*cdf0e10cSrcweir //                   ,nRecord(nRec)
277*cdf0e10cSrcweir //                   ,xValue(aVal)
278*cdf0e10cSrcweir //      {
279*cdf0e10cSrcweir //      }
280*cdf0e10cSrcweir 
281*cdf0e10cSrcweir //      inline ONDXKey::ONDXKey(sal_uInt32 nRec)
282*cdf0e10cSrcweir //                   :nRecord(nRec)
283*cdf0e10cSrcweir //      {
284*cdf0e10cSrcweir //      }
285*cdf0e10cSrcweir 
286*cdf0e10cSrcweir         inline ONDXKey::ONDXKey(const ONDXKey& rKey)
287*cdf0e10cSrcweir                      : ONDXKey_BASE(rKey.getDBType())
288*cdf0e10cSrcweir                      ,nRecord(rKey.nRecord)
289*cdf0e10cSrcweir                      ,xValue(rKey.xValue)
290*cdf0e10cSrcweir         {
291*cdf0e10cSrcweir         }
292*cdf0e10cSrcweir 
293*cdf0e10cSrcweir         inline ONDXKey& ONDXKey::operator=(const ONDXKey& rKey)
294*cdf0e10cSrcweir         {
295*cdf0e10cSrcweir             if(&rKey == this)
296*cdf0e10cSrcweir                 return *this;
297*cdf0e10cSrcweir 
298*cdf0e10cSrcweir             xValue = rKey.xValue;
299*cdf0e10cSrcweir             nRecord = rKey.nRecord;
300*cdf0e10cSrcweir             m_eDBType = rKey.getDBType();
301*cdf0e10cSrcweir             return *this;
302*cdf0e10cSrcweir         }
303*cdf0e10cSrcweir 
304*cdf0e10cSrcweir         inline sal_Bool ONDXKey::operator == (const ONDXKey& rKey) const
305*cdf0e10cSrcweir         {
306*cdf0e10cSrcweir             if(&rKey == this)
307*cdf0e10cSrcweir                 return sal_True;
308*cdf0e10cSrcweir             return Compare(rKey) == COMPARE_EQUAL;
309*cdf0e10cSrcweir         }
310*cdf0e10cSrcweir         inline sal_Bool ONDXKey::operator != (const ONDXKey& rKey) const
311*cdf0e10cSrcweir         {
312*cdf0e10cSrcweir             return !operator== (rKey);
313*cdf0e10cSrcweir         }
314*cdf0e10cSrcweir         inline sal_Bool ONDXKey::operator <  (const ONDXKey& rKey) const
315*cdf0e10cSrcweir         {
316*cdf0e10cSrcweir             return Compare(rKey) == COMPARE_LESS;
317*cdf0e10cSrcweir         }
318*cdf0e10cSrcweir         inline sal_Bool ONDXKey::operator >  (const ONDXKey& rKey) const
319*cdf0e10cSrcweir         {
320*cdf0e10cSrcweir             return Compare(rKey) == COMPARE_GREATER;
321*cdf0e10cSrcweir         }
322*cdf0e10cSrcweir         inline sal_Bool ONDXKey::operator <= (const ONDXKey& rKey) const
323*cdf0e10cSrcweir         {
324*cdf0e10cSrcweir             return !operator > (rKey);
325*cdf0e10cSrcweir         }
326*cdf0e10cSrcweir         inline sal_Bool ONDXKey::operator >= (const ONDXKey& rKey) const
327*cdf0e10cSrcweir         {
328*cdf0e10cSrcweir             return !operator< (rKey);
329*cdf0e10cSrcweir         }
330*cdf0e10cSrcweir 
331*cdf0e10cSrcweir         inline void ONDXNode::SetChild(ONDXPagePtr aCh, ONDXPage* pParent)
332*cdf0e10cSrcweir         {
333*cdf0e10cSrcweir             aChild = aCh;
334*cdf0e10cSrcweir             if (aChild.Is())
335*cdf0e10cSrcweir                 aChild->SetParent(pParent);
336*cdf0e10cSrcweir         }
337*cdf0e10cSrcweir 
338*cdf0e10cSrcweir     }
339*cdf0e10cSrcweir 
340*cdf0e10cSrcweir }
341*cdf0e10cSrcweir 
342*cdf0e10cSrcweir 
343*cdf0e10cSrcweir 
344*cdf0e10cSrcweir 
345*cdf0e10cSrcweir #endif // _CONNECTIVITY_DBASE_INDEXNODE_HXX_
346*cdf0e10cSrcweir 
347*cdf0e10cSrcweir 
348