/************************************************************************* * * $RCSfile: rscclobj.hxx,v $ * * $Revision: 1.2 $ * * last change: $Author: pl $ $Date: 2001-10-10 11:51:13 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses * * - GNU Lesser General Public License Version 2.1 * - Sun Industry Standards Source License Version 1.1 * * Sun Microsystems Inc., October, 2000 * * GNU Lesser General Public License Version 2.1 * ============================================= * Copyright 2000 by Sun Microsystems, Inc. * 901 San Antonio Road, Palo Alto, CA 94303, USA * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software Foundation. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA * * * Sun Industry Standards Source License Version 1.1 * ================================================= * The contents of this file are subject to the Sun Industry Standards * Source License Version 1.1 (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.openoffice.org/license.html. * * Software provided under this License is provided on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS, * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING. * See the License for the specific provisions governing your rights and * obligations concerning the Software. * * The Initial Developer of the Original Code is: Sun Microsystems, Inc. * * Copyright: 2000 by Sun Microsystems, Inc. * * All Rights Reserved. * * Contributor(s): _______________________________________ * * ************************************************************************/ #ifndef _RSCCLOBJ_HXX #define _RSCCLOBJ_HXX #ifndef _RSCTREE_HXX #include #endif #ifndef _RSCDEF_HXX #include #endif #ifndef _RSCALL_H #include #endif /****************** C L A S S E S ****************************************/ class RscTypCont; /*********** R s c I n c o n s i s t e n t *******************************/ class RscInconsistent { public: RscId aFirstId; //Paar von inkonsistenten Id's RscId aSecondId; RscInconsistent( const RscId & rFirst, const RscId & rSecond ){ aFirstId = rFirst; aSecondId = rSecond; }; }; DECLARE_LIST( RscInconsList, RscInconsistent * ) /******************* O b j N o d e ***************************************/ class ObjNode : public IdNode{ RscId aRscId; // Id der Resource CLASS_DATA pRscObj;// pointer to a resourceobject ULONG lFileKey;// Dateischluessel public: ObjNode( const RscId & rId, CLASS_DATA pData, ULONG lKey ); ObjNode * DelObjNode( RscTop * pClass, ULONG lFileKey ); USHORT GetId() const; RscId GetRscId(){ return( aRscId ); } ULONG GetFileKey(){ return lFileKey; }; ObjNode* Search( const RscId &rName ) const{ // search the index in the b-tree return( (ObjNode *)IdNode::Search( rName ) ); } BOOL Insert( ObjNode* pTN ){ // insert a new node in the b-tree return( IdNode::Insert( (IdNode *)pTN ) ); } CLASS_DATA GetRscObj(){ // get the Object from this Node return( pRscObj ); } BOOL IsConsistent( RscInconsList * pList = NULL ); }; /******************* R e f N o d e ***************************************/ class RefNode : public IdNode{ HASHID nTypNameId; // index of a Name in a hashtabel public: ObjNode* pObjBiTree; // Zeiger auf Objektbaum RefNode( HASHID nTyp ); USHORT GetId() const; RefNode* Search( HASHID typ ) const{ // search the index in the b-tree return( (RefNode *)IdNode::Search( typ ) ); }; BOOL Insert( RefNode* pTN ){ // insert a new node in the b-tree return( IdNode::Insert( (IdNode *)pTN ) ); }; BOOL PutObjNode( ObjNode * pPutObject ); // insert new node in b-tree pObjBiTree ObjNode * GetObjNode( const RscId &rRscId ); ObjNode * GetObjNode(){ // hole pObjBiTree return( pObjBiTree ); }; }; #endif // _RSCCLOBJ_HXX