/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0 . */ /****************** I N C L U D E S **************************************/ // C and C++ Includes. #include #include #include // Programmabh�ngige Includes. #include #include /****************** C O D E **********************************************/ /****************** B i N o d e ******************************************/ /************************************************************************* |* |* BiNode::BiNode() |* *************************************************************************/ BiNode::BiNode(){ pLeft = pRight = NULL; } /************************************************************************* |* |* BiNode::~BiNode() |* *************************************************************************/ BiNode::~BiNode(){ } /************************************************************************* |* |* BiNode::EnumNodes() |* *************************************************************************/ void BiNode::EnumNodes( Link aLink ) const{ if( Left() ) Left()->EnumNodes( aLink ); aLink.Call( (BiNode *)this ); if( Right() ) Right()->EnumNodes( aLink ); } /************************************************************************* |* |* BiNode::ChangeDLListBTree() |* *************************************************************************/ BiNode * BiNode::ChangeDLListBTree( BiNode * pList ){ BiNode * pRightNode; BiNode * pMiddle; BiNode * pTmp; sal_uInt32 nEle, i; if( pList ){ while( pList->Left() ) pList = pList->Left(); pTmp = pList; for( nEle = 0; pTmp->Right(); nEle++ ) pTmp = pTmp->Right(); pMiddle = pList; if( nEle / 2 ) for( i = 0; i < (nEle / 2); i++ ) pMiddle = pMiddle->Right(); else pList = (BiNode *)0; if( NULL != (pTmp = pMiddle->Left()) ) // rechten Zeiger auf Null pTmp->pRight = (BiNode *)0; // linken Zeiger auf Null if( NULL != (pRightNode = pMiddle->Right()) ) pRightNode->pLeft = (BiNode *)0; pMiddle->pLeft = ChangeDLListBTree( pList ); pMiddle->pRight = ChangeDLListBTree( pRightNode ); return( pMiddle ); } return( pList ); } /************************************************************************* |* |* BiNode::ChangeBTreeDLList() |* *************************************************************************/ BiNode * BiNode::ChangeBTreeDLList(){ BiNode * pList; BiNode * pLL_RN; // linke Liste rechter Knoten if( Right() ){ pList = Right()->ChangeBTreeDLList(); pRight = pList; pList->pLeft = this; } pList = this; if( Left() ){ pLL_RN = pList = Left()->ChangeBTreeDLList(); while( pLL_RN->Right() ) pLL_RN = pLL_RN->Right(); pLeft = pLL_RN; pLL_RN->pRight = this; } return( pList ); } /****************** N a m e N o d e **************************************/ /************************************************************************* |* |* NameNode::Remove() |* *************************************************************************/ NameNode * NameNode::Remove( NameNode * pRemove ){ NameNode * pRoot = this; NameNode * pParent = SearchParent( pRemove ); if( pParent ){ if( pParent->Left() && (EQUAL == pRemove->Compare( pParent->Left() ) ) ){ pParent->pLeft = pRemove->Left(); if( pRemove->Right() ) pParent->Insert( pRemove->Right() ); } else if( pParent->Right() && (EQUAL == pRemove->Compare( pParent->Right() ) ) ){ pParent->pRight = pRemove->Right(); if( pRemove->Left() ) pParent->Insert( pRemove->Left() ); } } else if( EQUAL == this->Compare( pRemove ) ){ if( Right() ){ pRoot = Right(); if( Left() ) Right()->Insert( Left() ); } else{ pRoot = Left(); } } pRemove->pLeft = pRemove->pRight = NULL; return pRoot; } /************************************************************************* |* |* NameNode::Compare |* *************************************************************************/ COMPARE NameNode::Compare( const NameNode * pCompare ) const{ if( (long)this < (long)pCompare ) return LESS; else if( (long)this > (long)pCompare ) return GREATER; else return EQUAL; } COMPARE NameNode::Compare( const void * pCompare ) const{ if( (long)this < (long)pCompare ) return LESS; else if( (long)this > (long)pCompare ) return GREATER; else return EQUAL; } /************************************************************************* |* |* NameNode::SearchParent |* *************************************************************************/ NameNode* NameNode::SearchParent( const NameNode * pSearch ) const{ // search for a parent node. // return a pointer to the parent node if found. // otherwise return 0. int nCmp = Compare( pSearch ); if( nCmp == GREATER ){ if( Left() ){ if( ((NameNode *)Left())->Compare( pSearch ) == EQUAL ) return (NameNode *)this; return ((NameNode *)Left())->SearchParent( pSearch ); }; } else if( nCmp == LESS ){ if( Right() ){ if( ((NameNode *)Right())->Compare( pSearch ) == EQUAL ) return (NameNode *)this; return ((NameNode *)Right())->SearchParent( pSearch ); } }; return( (NameNode *)NULL ); } /************************************************************************* |* |* NameNode::Search |* *************************************************************************/ NameNode* NameNode::Search( const NameNode * pSearch ) const{ // search for a node. // return a pointer to the node if found. // otherwise return 0. int nCmp = Compare( pSearch ); if( nCmp == GREATER ){ if( Left() ) return ((NameNode *)Left())->Search( pSearch ); } else if( nCmp == LESS ){ if( Right() ) return ((NameNode *)Right())->Search( pSearch ); } else return( (NameNode *)this ); return( NULL ); } NameNode* NameNode::Search( const void * pSearch ) const{ // search for a node. // return a pointer to the node if found. // otherwise return 0. int nCmp = Compare( pSearch ); if( nCmp == GREATER ){ if( Left() ) return ((NameNode *)Left())->Search( pSearch ); } else if( nCmp == LESS ){ if( Right() ) return ((NameNode *)Right())->Search( pSearch ); } else return( (NameNode *)this ); return( NULL ); } /************************************************************************* |* |* NameNode::Insert() |* *************************************************************************/ sal_Bool NameNode::Insert( NameNode * pTN, sal_uInt32* pnDepth ){ // Ein Knoten wird in den Baum eingefuegt // Gibt es einen Knoten mit dem gleichen Namen, dann return sal_False // sonst return sal_True. Der Knoten wird auf jeden Fall eingefuegt. sal_Bool bRet = sal_True; int nCmp = Compare( pTN ); *pnDepth += 1; if( nCmp == GREATER ){ if( Left() ) bRet = ((NameNode *)Left())->Insert( pTN, pnDepth ); else pLeft = pTN; } else{ if( Right() ) bRet = ((NameNode *)Right())->Insert( pTN, pnDepth ); else pRight = pTN; if( nCmp == EQUAL ) bRet = sal_False; }; return( bRet ); } /************************************************************************* |* |* NameNode::Insert() |* *************************************************************************/ sal_Bool NameNode::Insert( NameNode * pTN ){ // insert a node in the tree. // if the node with the same name is in, return sal_False and no insert. // if not return true. sal_uInt32 nDepth = 0; sal_Bool bRet; bRet = Insert( pTN, &nDepth ); if( bRet ){ if( nDepth > 20 ){ if( Left() ) pLeft = ChangeDLListBTree( Left()->ChangeBTreeDLList() ); if( Right() ) pRight = ChangeDLListBTree( Right()->ChangeBTreeDLList() ); } } return( bRet ); } /************************************************************************* |* |* NameNode::OrderTree() |* *************************************************************************/ void NameNode::OrderTree(){ NameNode * pTmpLeft = (NameNode *)Left(); NameNode * pTmpRight = (NameNode *)Right(); pLeft = NULL; pRight = NULL; SubOrderTree( pTmpLeft ); SubOrderTree( pTmpRight ); } void NameNode::SubOrderTree( NameNode * pOrderNode ){ if( pOrderNode ){ NameNode * pTmpLeft = (NameNode *)pOrderNode->Left(); NameNode * pTmpRight = (NameNode *)pOrderNode->Right(); pOrderNode->pLeft = NULL; pOrderNode->pRight = NULL; Insert( pOrderNode ); SubOrderTree( pTmpLeft ); SubOrderTree( pTmpRight ); } } /****************** I d N o d e ******************************************/ /************************************************************************* |* |* IdNode::Search() |* *************************************************************************/ IdNode * IdNode::Search( sal_uInt32 nTypeName ) const{ return( (IdNode *)NameNode::Search( (const void *)&nTypeName ) ); } /************************************************************************* |* |* IdNode::Compare() |* *************************************************************************/ COMPARE IdNode::Compare( const NameNode * pSearch ) const { if( GetId() < (sal_uInt32)(((const IdNode *)pSearch)->GetId()) ) return LESS; else if( GetId() > (sal_uInt32)(((const IdNode *)pSearch)->GetId()) ) return GREATER; else return EQUAL; } COMPARE IdNode::Compare( const void * pSearch ) const{ // pSearch ist ein Zeiger auf sal_uInt32 if( GetId() < *((const sal_uInt32 *)pSearch) ) return LESS; else if( GetId() > *((const sal_uInt32 *)pSearch) ) return GREATER; else return EQUAL; } /************************************************************************* |* |* IdNode::GetId() |* *************************************************************************/ sal_uInt32 IdNode::GetId() const { return( 0xFFFFFFFF ); } /************************************************************************* |* |* StringNode::Search() |* *************************************************************************/ StringNode * StringNode::Search( const char * pSearch ) const{ return (StringNode *)NameNode::Search( (const void *)pSearch ); } /************************************************************************* |* |* StringNode::Compare() |* *************************************************************************/ COMPARE StringNode::Compare( const NameNode * pSearch ) const { int nCmp = strcmp( m_aName.getStr(), ((const StringNode *)pSearch)->m_aName.getStr() ); if( nCmp < 0 ) return LESS; else if( nCmp > 0 ) return GREATER; else return EQUAL; } COMPARE StringNode::Compare( const void * pSearch ) const { // pSearch ist ein Zeiger auf const char * int nCmp = strcmp( m_aName.getStr(), (const char *)pSearch ); if( nCmp < 0 ) return LESS; else if( nCmp > 0 ) return GREATER; else return EQUAL; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */