/************************************************************************* * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: anynoderef.hxx,v $ * * $Revision: 1.6 $ * * last change: $Author: rt $ $Date: 2005-09-08 03:41:26 $ * * The Contents of this file are made available subject to * the terms of GNU Lesser General Public License Version 2.1. * * * GNU Lesser General Public License Version 2.1 * ============================================= * Copyright 2005 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 * ************************************************************************/ #ifndef CONFIGMGR_CONFIGANYNODE_HXX_ #define CONFIGMGR_CONFIGANYNODE_HXX_ #ifndef CONFIGMGR_CONFIGNODE_HXX_ #include "noderef.hxx" #endif namespace configmgr { namespace configapi { class Factory; } namespace node { struct Attributes; } namespace configuration { //------------------------------------------------------------------------- class Name; //------------------------------------------------------------------------- namespace argument { struct NoValidate; } typedef com::sun::star::uno::Type UnoType; typedef com::sun::star::uno::Any UnoAny; //------------------------------------------------------------------------- class NodeRef; class ValueRef; class AnyNodeRef; class NodeID; class Tree; class TreeImpl; typedef unsigned int NodeOffset; typedef unsigned int TreeDepth; //------------------------------------------------------------------------- /// represents any node in some tree class AnyNodeRef { public: /// constructs an empty (invalid) node AnyNodeRef(); /// converts an inner node explicit AnyNodeRef(NodeRef const& aInnerNode); /// converts a value node explicit AnyNodeRef(ValueRef const& aValueNode); /// copy a node (with reference semantics) AnyNodeRef(AnyNodeRef const& rOther); /// copy a node (with reference semantics) AnyNodeRef& operator=(AnyNodeRef const& rOther); void swap(AnyNodeRef& rOther); ~AnyNodeRef(); /// checks, if this represents an existing node inline bool isValid() const; /// checks if this a node (rather than a value only) bool isNode() const; /// converts this, if it is a value ValueRef toValue() const; /// converts this, if it is a inner node NodeRef toNode() const; private: friend class Tree; friend class TreeImplHelper; AnyNodeRef(NodeOffset nParentPos, TreeDepth m_nDepth); AnyNodeRef(Name const& aName, NodeOffset nParentPos); bool checkValidState() const; private: Name m_sNodeName; NodeOffset m_nUsedPos; TreeDepth m_nDepth; }; //------------------------------------------------------------------------- /** checks whether there are any immediate children of aNode (which is in aTree) @return if a child node exists otherwise */ inline bool hasChildOrElement(Tree const& aTree, AnyNodeRef const& aNode) { return aNode.isNode() && hasChildOrElement(aTree,aNode.toNode()); } /** checks whether there is an immediate child of aNode (which is in aTree) specified by aName @return if the child node exists otherwise */ inline bool hasChildOrElement(Tree const& aTree, AnyNodeRef const& aNode, Name const& aName) { return aNode.isNode() && hasChildOrElement(aTree,aNode.toNode(),aName); } /** tries to find the immediate child of aNode (which is in aTree) specified by aName

On return aNode is modified to refer to the node found and aTree will then refer to the tree that node is in.

@return The requested child node, if it exists (then aTree refers to the tree containing the desired node), */ AnyNodeRef getChildOrElement(Tree& aTree, NodeRef const& aParentNode, Name const& aName); /** tries to find the descendant of aNode specified by aPath within aTree

This function follows the given path stepwise, until a requested node is missing in the tree.

On return aNode is modified to refer to the last inner node found and aTree will be unchanged (except for deprecated usage).

Also, aPath is modified to contain the unresolved part of the original path.

@return the requested node, if the path could be resolved completely (so aNode refers to the desired node or its parent, and aPath is empty)
an invalid node otherwise */ AnyNodeRef getLocalDescendant(Tree const& aTree, NodeRef const& aNode, RelativePath const& aPath); /** tries to find the descendant of aNode (which is in aTree) specified by aPath

This function follows the given path stepwise, until a requested node is missing in the tree.

On return aNode is modified to refer to the last inner node found and aTree will then refer to the tree that node is in.

Also, aPath is modified to contain the unresolved part of the original path.

@return the requested node, if the path could be resolved completely (so aNode and aTree refer to the desired node or its parent, and aPath is empty)
an invalid node otherwise */ AnyNodeRef getDeepDescendant(Tree& aTree, NodeRef& aNode, RelativePath& aPath); //------------------------------------------------------------------------- inline bool AnyNodeRef::isValid() const { OSL_ASSERT( m_nUsedPos == 0 || checkValidState() ); return m_nUsedPos != 0; } //------------------------------------------------------------------------- } } #endif // CONFIGMGR_CONFIGANYNODE_HXX_