xref: /aoo4110/main/rsc/inc/rscclobj.hxx (revision b1cdbd2c)
1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski #ifndef _RSCCLOBJ_HXX
24*b1cdbd2cSJim Jagielski #define _RSCCLOBJ_HXX
25*b1cdbd2cSJim Jagielski 
26*b1cdbd2cSJim Jagielski #include <rsctree.hxx>
27*b1cdbd2cSJim Jagielski #include <rscdef.hxx>
28*b1cdbd2cSJim Jagielski #include <rscall.h>
29*b1cdbd2cSJim Jagielski 
30*b1cdbd2cSJim Jagielski /****************** C L A S S E S ****************************************/
31*b1cdbd2cSJim Jagielski class RscTypCont;
32*b1cdbd2cSJim Jagielski 
33*b1cdbd2cSJim Jagielski /*********** R s c I n c o n s i s t e n t *******************************/
34*b1cdbd2cSJim Jagielski class RscInconsistent {
35*b1cdbd2cSJim Jagielski public:
36*b1cdbd2cSJim Jagielski     RscId aFirstId;   //Paar von inkonsistenten Id's
37*b1cdbd2cSJim Jagielski     RscId aSecondId;
RscInconsistent(const RscId & rFirst,const RscId & rSecond)38*b1cdbd2cSJim Jagielski     RscInconsistent( const RscId & rFirst, const RscId & rSecond ){
39*b1cdbd2cSJim Jagielski             aFirstId = rFirst;
40*b1cdbd2cSJim Jagielski             aSecondId = rSecond;
41*b1cdbd2cSJim Jagielski         };
42*b1cdbd2cSJim Jagielski };
43*b1cdbd2cSJim Jagielski 
44*b1cdbd2cSJim Jagielski DECLARE_LIST( RscInconsList, RscInconsistent * )
45*b1cdbd2cSJim Jagielski 
46*b1cdbd2cSJim Jagielski /******************* O b j N o d e ***************************************/
47*b1cdbd2cSJim Jagielski class ObjNode : public IdNode{
48*b1cdbd2cSJim Jagielski     RscId       aRscId; // Id der Resource
49*b1cdbd2cSJim Jagielski     CLASS_DATA  pRscObj;// pointer to a resourceobject
50*b1cdbd2cSJim Jagielski     sal_uLong       lFileKey;// Dateischluessel
51*b1cdbd2cSJim Jagielski protected:
52*b1cdbd2cSJim Jagielski     using NameNode::Search;
53*b1cdbd2cSJim Jagielski 
54*b1cdbd2cSJim Jagielski public:
55*b1cdbd2cSJim Jagielski     using NameNode::Insert;
56*b1cdbd2cSJim Jagielski 
57*b1cdbd2cSJim Jagielski                 ObjNode( const RscId & rId, CLASS_DATA pData, sal_uLong lKey );
58*b1cdbd2cSJim Jagielski     ObjNode *   DelObjNode( RscTop * pClass, sal_uLong lFileKey );
59*b1cdbd2cSJim Jagielski     sal_uInt32      GetId() const;
GetRscId()60*b1cdbd2cSJim Jagielski     RscId       GetRscId(){ return( aRscId ); }
GetFileKey()61*b1cdbd2cSJim Jagielski     sal_uLong       GetFileKey(){ return lFileKey; };
Search(const RscId & rName) const62*b1cdbd2cSJim Jagielski     ObjNode*    Search( const RscId &rName ) const{
63*b1cdbd2cSJim Jagielski                     // search the index in the b-tree
64*b1cdbd2cSJim Jagielski                     return( (ObjNode *)IdNode::Search( rName ) );
65*b1cdbd2cSJim Jagielski                 }
Insert(ObjNode * pTN)66*b1cdbd2cSJim Jagielski     sal_Bool        Insert( ObjNode* pTN ){
67*b1cdbd2cSJim Jagielski                     // insert a new node in the b-tree
68*b1cdbd2cSJim Jagielski                     return( IdNode::Insert( (IdNode *)pTN ) );
69*b1cdbd2cSJim Jagielski                 }
GetRscObj()70*b1cdbd2cSJim Jagielski     CLASS_DATA  GetRscObj(){
71*b1cdbd2cSJim Jagielski                     // get the Object from this Node
72*b1cdbd2cSJim Jagielski                     return( pRscObj );
73*b1cdbd2cSJim Jagielski                 }
74*b1cdbd2cSJim Jagielski     sal_Bool        IsConsistent( RscInconsList * pList = NULL );
75*b1cdbd2cSJim Jagielski };
76*b1cdbd2cSJim Jagielski 
77*b1cdbd2cSJim Jagielski /******************* R e f N o d e ***************************************/
78*b1cdbd2cSJim Jagielski class RefNode : public IdNode{
79*b1cdbd2cSJim Jagielski     Atom        nTypNameId; // index of a Name in a hashtabel
80*b1cdbd2cSJim Jagielski protected:
81*b1cdbd2cSJim Jagielski     using NameNode::Search;
82*b1cdbd2cSJim Jagielski 
83*b1cdbd2cSJim Jagielski public:
84*b1cdbd2cSJim Jagielski     using NameNode::Insert;
85*b1cdbd2cSJim Jagielski 
86*b1cdbd2cSJim Jagielski     ObjNode*    pObjBiTree; // Zeiger auf Objektbaum
87*b1cdbd2cSJim Jagielski                 RefNode( Atom nTyp );
88*b1cdbd2cSJim Jagielski     sal_uInt32      GetId() const;
Search(Atom typ) const89*b1cdbd2cSJim Jagielski     RefNode*    Search( Atom typ ) const{
90*b1cdbd2cSJim Jagielski                     // search the index in the b-tree
91*b1cdbd2cSJim Jagielski                     return( (RefNode *)IdNode::Search( typ ) );
92*b1cdbd2cSJim Jagielski                 };
Insert(RefNode * pTN)93*b1cdbd2cSJim Jagielski     sal_Bool        Insert( RefNode* pTN ){
94*b1cdbd2cSJim Jagielski                     // insert a new node in the b-tree
95*b1cdbd2cSJim Jagielski                     return( IdNode::Insert( (IdNode *)pTN ) );
96*b1cdbd2cSJim Jagielski                 };
97*b1cdbd2cSJim Jagielski     sal_Bool        PutObjNode( ObjNode * pPutObject );
98*b1cdbd2cSJim Jagielski 
99*b1cdbd2cSJim Jagielski                 // insert new node in b-tree pObjBiTree
100*b1cdbd2cSJim Jagielski     ObjNode *   GetObjNode( const RscId &rRscId );
101*b1cdbd2cSJim Jagielski 
GetObjNode()102*b1cdbd2cSJim Jagielski     ObjNode *   GetObjNode(){
103*b1cdbd2cSJim Jagielski                     // hole  pObjBiTree
104*b1cdbd2cSJim Jagielski                     return( pObjBiTree );
105*b1cdbd2cSJim Jagielski                 };
106*b1cdbd2cSJim Jagielski };
107*b1cdbd2cSJim Jagielski 
108*b1cdbd2cSJim Jagielski #endif // _RSCCLOBJ_HXX
109