/************************************************************************* * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: apinodeupdate.hxx,v $ * * $Revision: 1.9 $ * * last change: $Author: rt $ $Date: 2005-09-08 03:07:54 $ * * 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_API_NODEUPDATE_HXX_ #define CONFIGMGR_API_NODEUPDATE_HXX_ #ifndef CONFIGMGR_API_NODEACCESS_HXX_ #include "apinodeaccess.hxx" #endif #ifndef CONFIGMGR_ACCESSOR_HXX #include "accessor.hxx" #endif #ifndef CONFIGMGR_UTILITY_HXX_ #include "utility.hxx" #endif namespace configmgr { namespace configuration { class GroupUpdater; class GroupDefaulter; class TreeSetUpdater; class ValueSetUpdater; class SetDefaulter; class SetElementFactory; class ElementTree; class NodeUpdate; } namespace configapi { class SetElement; typedef uno::XInterface UnoInterface; typedef uno::Any UnoAny; // API object implementation wrappers // these objects just provide the pieces needed to navigate and manipulate trees and nodes // Updating access for Group Nodes class NodeGroupAccess : public NodeGroupInfoAccess { public: typedef configuration::GroupUpdater NodeUpdater; typedef configuration::GroupDefaulter NodeDefaulter; NodeUpdater getNodeUpdater(memory::Accessor const& _aAccessor); NodeDefaulter getNodeDefaulter(memory::Accessor const& _aAccessor); /** ensures that the default data for a group is loaded (if possible)

Must be called outside of any locks !

*/ friend NodeGroupAccess& withDefaultData(NodeGroupAccess& aGroup); }; // Updating access for Set Nodes class NodeSetAccess : public NodeSetInfoAccess { public: typedef struct SetUpdater_PlaceHolder NodeUpdater; typedef configuration::SetDefaulter NodeDefaulter; NodeDefaulter getNodeDefaulter(memory::Accessor const& _aAccessor); }; // Updating access for Set Nodes containing whole trees class NodeTreeSetAccess : public NodeSetAccess { public: typedef configuration::TreeSetUpdater NodeUpdater; NodeUpdater getNodeUpdater(memory::Accessor const& _aAccessor); configuration::SetElementFactory getElementFactory(memory::Accessor const& _aAccessor); }; // Updating access for Set Nodes containing simple values class NodeValueSetAccess : public NodeSetAccess { public: typedef configuration::ValueSetUpdater NodeUpdater; NodeUpdater getNodeUpdater(memory::Accessor const& _aAccessor); }; /// informs a SetElement that it should now link to the given SetElement void attachSetElement(NodeTreeSetAccess& aSet, SetElement& aElement); /// informs a SetElement that it should now link to the given SetElement bool attachSetElement(NodeTreeSetAccess& aSet, configuration::ElementTree const& aElementTree); /// informs a SetElement that it should now unlink from its owning SetElement void detachSetElement(SetElement& aElement); /// informs a SetElement that it should now unlink from its owning SetElement bool detachSetElement(Factory& rFactory, configuration::ElementRef const& aElementTree); // Guarding and locking implementations /// guards a NodeGroupAccess, or NodeSetAccess; provides an object (write)/provider(read) lock; ensures object was not disposed class UpdateGuardImpl : Noncopyable { memory::Accessor m_aDataAccess; osl::MutexGuard m_aViewLock; NodeAccess& m_rNode; public: UpdateGuardImpl(NodeGroupAccess& rNode); UpdateGuardImpl(NodeSetAccess& rNode); ~UpdateGuardImpl() throw (); public: NodeAccess& get() const { return m_rNode; } void downgrade() { } memory::Accessor const& accessor() const { return m_aDataAccess; } }; // Thin Wrappers around NodeAccesses: Provide guarding and convenient access /// wraps a NodeAccess; provides an object (write)/provider(read) lock, ensures object was not disposed template class GuardedNodeUpdate { UpdateGuardImpl m_aImpl; public: GuardedNodeUpdate(Access& rNode) : m_aImpl(rNode) {} public: Access& get() const { return static_cast(m_aImpl.get()); } configuration::Tree getTree() const; configuration::NodeRef getNode() const; typedef typename Access::NodeUpdater Updater; typedef typename Access::NodeDefaulter Defaulter; Updater getNodeUpdater() const; Defaulter getNodeDefaulter() const; memory::Accessor const& getDataAccessor() const { return m_aImpl.accessor(); } void clearForBroadcast() { m_aImpl.downgrade(); } }; template configuration::Tree GuardedNodeUpdate::getTree() const { return get().getTree(this->getDataAccessor()); } template configuration::NodeRef GuardedNodeUpdate::getNode() const { return get().getNodeRef(); } template typename GuardedNodeUpdate::Updater GuardedNodeUpdate::getNodeUpdater() const { return get().getNodeUpdater(this->getDataAccessor()); } template typename GuardedNodeUpdate::Defaulter GuardedNodeUpdate::getNodeDefaulter() const { return get().getNodeDefaulter(this->getDataAccessor()); } /// wraps a NodeGroupAccess; provides an object (write) lock, ensures object was not disposed typedef GuardedNodeUpdate GuardedGroupUpdateAccess; typedef GuardedNodeUpdate GuardedSetUpdateAccess; typedef GuardedNodeUpdate GuardedTreeSetUpdateAccess; typedef GuardedNodeUpdate GuardedValueSetUpdateAccess; } } #endif // CONFIGMGR_API_NODEUPDATE_HXX_