office-gobmx/configmgr/source/inc/valuenode.hxx

310 lines
11 KiB
C++
Raw Normal View History

/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* Copyright 2008 by Sun Microsystems, Inc.
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: valuenode.hxx,v $
* $Revision: 1.31 $
*
* This file is part of OpenOffice.org.
*
* OpenOffice.org is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3
* only, as published by the Free Software Foundation.
*
* OpenOffice.org 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 version 3 for more details
* (a copy is included in the LICENSE file that accompanied this code).
*
* You should have received a copy of the GNU Lesser General Public License
* version 3 along with OpenOffice.org. If not, see
* <http://www.openoffice.org/license.html>
* for a copy of the LGPLv3 License.
*
************************************************************************/
#ifndef _CONFIGMGR_TREE_VALUENODE_HXX
#define _CONFIGMGR_TREE_VALUENODE_HXX
#include "attributes.hxx"
#include "anypair.hxx"
2000-11-15 00:14:58 -06:00
#include <com/sun/star/uno/Any.h>
#include <rtl/ustring.hxx>
#include "rttimacros.hxx"
2002-02-21 07:11:15 -06:00
#include <string.h>
#ifndef INCLUDED_MEMORY
#include <memory>
#define INCLUDED_MEMORY
2001-06-20 14:17:35 -05:00
#endif
2000-11-15 00:14:58 -06:00
namespace configmgr
{
namespace css = com::sun::star;
namespace uno = css::uno;
class INode;
class ISubtree;
class ValueNode;
using rtl::OUString;
// helper (tag) class
namespace treeop { struct NoChildCopy {}; struct DeepChildCopy {}; enum { ALL_LEVELS = -1 }; }
2000-11-15 00:14:58 -06:00
//==========================================================================
//= Visitors
//==========================================================================
struct NodeAction
{
virtual void handle(ValueNode const&) = 0;
virtual void handle(ISubtree const&) = 0;
void applyToNode(INode const&);
void applyToChildren(ISubtree const&);
protected:
virtual ~NodeAction() {}
2000-11-15 00:14:58 -06:00
};
struct NodeModification
{
virtual void handle(ValueNode&) = 0;
virtual void handle(ISubtree&) = 0;
void applyToNode(INode&);
void applyToChildren(ISubtree&);
protected:
virtual ~NodeModification() {}
2000-11-15 00:14:58 -06:00
};
class INode
{
OUString m_aName;
node::Attributes m_aAttributes;
2000-11-30 02:01:47 -06:00
protected:
INode(){}
2000-11-15 00:14:58 -06:00
void markAsDefault(bool _bDefault = true)
{
m_aAttributes.markAsDefault(_bDefault);
}
2000-11-15 00:14:58 -06:00
public:
explicit
INode(node::Attributes);
INode(OUString const& aName, node::Attributes);
2000-11-15 00:14:58 -06:00
virtual ~INode();
virtual std::auto_ptr<INode> clone() const = 0;
public:
2000-11-15 00:14:58 -06:00
const OUString& getName() const { return m_aName; }
node::Attributes getAttributes() const { return m_aAttributes; }
2000-11-15 00:14:58 -06:00
bool isDefault() const { return m_aAttributes.isDefault(); }
bool isLocalized() const { return m_aAttributes.isLocalized(); }
void modifyState(node::State _eNewState);
void modifyAccess(node::Access _aAccessLevel);
void markMandatory();
void markRemovable();
void promoteAccessToDefault();
void forceReadonlyToFinalized();
2000-11-15 00:14:58 -06:00
// to be used with caution. If the node is referenced from somewhere else under it's old name,
// you may have problems with this inconsistence
void setName(const OUString& _rNewName) { m_aName = _rNewName; }
2000-11-15 00:14:58 -06:00
virtual ValueNode* asValueNode();
virtual ValueNode const* asValueNode() const;
virtual ISubtree* asISubtree();
virtual ISubtree const* asISubtree() const;
// double dispatch support
virtual void dispatch(NodeAction&) const = 0;
virtual void dispatch(NodeModification&) = 0;
// "rtti"
RTTI_BASE(INode);
};
2001-06-20 14:17:35 -05:00
// -----------------------------------------------------------------------------
2000-11-15 00:14:58 -06:00
//==========================================================================
//= ISubtree
//==========================================================================
class ISubtree : public INode
{
sal_Int16 m_nLevel; /// determines if everything is read
sal_Int16 m_nDefaultLevels; /// determines if defaults are read
OUString m_sId;
OUString m_sTemplateName; /// path of the template for child instantiation
OUString m_sTemplateModule; /// module of the template for child instantiation
2000-11-30 02:01:47 -06:00
virtual INode* doGetChild(OUString const& name) const = 0;
2000-11-15 00:14:58 -06:00
2000-11-30 02:01:47 -06:00
protected:
ISubtree():m_nLevel(0){}
2000-11-15 00:14:58 -06:00
ISubtree(ISubtree const& other)
:INode(other)
,m_nLevel(other.m_nLevel)
,m_nDefaultLevels(other.m_nDefaultLevels)
,m_sId() // do not copy ID while cloning !
,m_sTemplateName(other.m_sTemplateName)
,m_sTemplateModule(other.m_sTemplateModule)
{}
2000-11-15 00:14:58 -06:00
public:
// Ctor for group trees
ISubtree(const rtl::OUString& aName, const node::Attributes& _rAttrs)
:INode(aName, _rAttrs)
,m_nLevel(0)
,m_nDefaultLevels(0)
{}
// Ctor for set trees
ISubtree(const rtl::OUString& aName,
const rtl::OUString& _rTemplateName,
const rtl::OUString& _rTemplateModule,
const node::Attributes& _rAttrs)
2000-11-30 02:01:47 -06:00
:INode(aName, _rAttrs)
,m_nLevel(0)
,m_nDefaultLevels(0)
,m_sTemplateName(_rTemplateName)
,m_sTemplateModule(_rTemplateModule){}
2000-11-15 00:14:58 -06:00
INode* getChild(OUString const& name) { return doGetChild(name); }
INode const* getChild(OUString const& name) const { return doGetChild(name); }
2000-11-15 00:14:58 -06:00
ISubtree* asISubtree();
ISubtree const* asISubtree() const;
using INode::markAsDefault;
2000-11-15 00:14:58 -06:00
sal_Int16 getLevel() const { return m_nLevel; }
void setLevels(sal_Int16 _nLevel,sal_Int16 _nDefaultsLevel);
bool isSetNode() const { return m_sTemplateName.getLength() != 0; }
void makeSetNode(OUString const& _sTemplateName, OUString const& _sTemplateModule)
{ m_sTemplateName = _sTemplateName; m_sTemplateModule = _sTemplateModule; }
OUString const& getElementTemplateName() const { return m_sTemplateName; }
OUString const& getElementTemplateModule() const { return m_sTemplateModule; }
2000-11-30 02:01:47 -06:00
virtual INode* addChild(std::auto_ptr<INode> node) =0; // takes ownership
virtual ::std::auto_ptr<INode> removeChild(rtl::OUString const& name) =0; // releases ownership
// Iteration support, stop if (action returns true)
virtual void forEachChild(NodeAction& anAction) const = 0;
virtual void forEachChild(NodeModification& anAction) = 0;
2000-11-15 00:14:58 -06:00
// double dispatch support
virtual void dispatch(NodeAction& anAction) const { anAction.handle(*this); }
virtual void dispatch(NodeModification& anAction) { anAction.handle(*this); }
// "rtti"
RTTI(ISubtree, INode);
};
//==========================================================================
//= ValueNode
//==========================================================================
class ValueNode : public INode
{
2001-06-20 14:17:35 -05:00
AnyPair m_aValuePair;
// uno::Type m_aType;
// uno::Any m_aValue;
// uno::Any m_aDefaultValue;
2000-11-30 02:01:47 -06:00
2000-11-15 00:14:58 -06:00
public:
//ValueNode(){}
2000-11-15 00:14:58 -06:00
//explicit ValueNode(node::Attributes _aAttrs):INode(_aAttrs){}
2000-11-30 02:01:47 -06:00
/*
ValueNode(OUString const& aName, node::Attributes _aAttrs)
: INode(aName, _aAttrs)
, m_aValuePair()
2000-11-15 00:14:58 -06:00
{}
*/
ValueNode(OUString const& aName,uno::Type const& aType, node::Attributes _aAttrs)
: INode(aName, _aAttrs)
, m_aValuePair(aType)
{
}
ValueNode(OUString const& aName,uno::Any const& anAny, node::Attributes _aAttrs)
: INode(aName, _aAttrs)
, m_aValuePair(anAny, selectMember(_aAttrs.isDefault()))
2001-06-20 14:17:35 -05:00
{
}
ValueNode(OUString const& aName,uno::Any const& anAny,uno::Any const& aDefault, node::Attributes _aAttrs)
: INode(aName, _aAttrs)
, m_aValuePair(anAny, aDefault)
2001-06-20 14:17:35 -05:00
{
}
2000-11-15 00:14:58 -06:00
bool isEmpty() const {return m_aValuePair.isEmpty();}
bool isValid() const {return !m_aValuePair.isEmpty();}
2000-11-15 00:14:58 -06:00
bool isNull() const {return m_aValuePair.isNull();}
bool hasUsableDefault() const {return getAttributes().isNullable() || m_aValuePair.hasSecond();}
2000-12-01 06:40:40 -06:00
uno::Type getValueType() const {return m_aValuePair.getValueType();}
uno::Any getValue() const {return m_aValuePair.getValue( selectMember(this->isDefault()) );}
uno::Any getUserValue() const {return m_aValuePair.getFirst();}
uno::Any getDefault() const {return m_aValuePair.getSecond();}
2000-11-15 00:14:58 -06:00
bool setValueType(uno::Type const& _aType);
bool setValue(uno::Any const& _aValue);
2000-11-15 00:14:58 -06:00
void setDefault();
bool changeDefault(uno::Any const& _aValue);
void promoteToDefault();
virtual std::auto_ptr<INode> clone() const;
2000-11-15 00:14:58 -06:00
ValueNode* asValueNode();
ValueNode const* asValueNode() const;
// double dispatch support
virtual void dispatch(NodeAction& anAction) const { anAction.handle(*this); }
virtual void dispatch(NodeModification& anAction) { anAction.handle(*this); }
// "rtti"
RTTI(ValueNode, INode);
private:
static AnyPair::SelectMember selectValue() { return AnyPair::SELECT_FIRST; }
static AnyPair::SelectMember selectDeflt() { return AnyPair::SELECT_SECOND; }
static AnyPair::SelectMember selectMember(bool bDeflt)
{ return bDeflt ? AnyPair::SELECT_SECOND : AnyPair::SELECT_FIRST; }
2000-11-15 00:14:58 -06:00
};
//==========================================================================
extern bool isLocalizedValueSet(ISubtree const& _aSubtree);
//==========================================================================
//= inlines
//==========================================================================
inline void NodeAction::applyToNode(INode const& aNode)
{ aNode.dispatch(*this); }
inline void NodeAction::applyToChildren(ISubtree const& aSubtree)
{ aSubtree.forEachChild(*this); }
inline void NodeModification::applyToNode(INode& aNode)
{ aNode.dispatch(*this); }
inline void NodeModification::applyToChildren(ISubtree& aSubtree)
{ aSubtree.forEachChild(*this); }
2000-11-15 00:14:58 -06:00
} // namespace configmgr
#endif