office-gobmx/configmgr/source/api2/apitreeaccess.hxx
Rüdiger Timm 6090dd6b8f INTEGRATION: CWS changefileheader (1.11.16); FILE MERGED
2008/04/01 12:27:10 thb 1.11.16.2: #i85898# Stripping all external header guards
2008/03/31 12:22:36 rt 1.11.16.1: #i87441# Change license header to LPGL v3.
2008-04-11 10:51:22 +00:00

194 lines
6.6 KiB
C++

/*************************************************************************
*
* 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: apitreeaccess.hxx,v $
* $Revision: 1.12 $
*
* 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_API_TREEACCESS_HXX_
#define CONFIGMGR_API_TREEACCESS_HXX_
#include "options.hxx"
#include "utility.hxx"
namespace osl { class Mutex; }
namespace configmgr
{
//-----------------------------------------------------------------------------
struct ServiceImplementationInfo;
//-----------------------------------------------------------------------------
namespace configuration
{
class Name;
class Tree;
class TreeRef;
class ElementRef;
class TemplateInfo;
}
//-----------------------------------------------------------------------------
namespace configapi
{
//-----------------------------------------------------------------------------
namespace uno = com::sun::star::uno;
typedef uno::XInterface UnoInterface;
typedef uno::Any UnoAny;
//-----------------------------------------------------------------------------
class Factory;
class Notifier;
class Committer;
class NodeSetInfoAccess;
//-----------------------------------------------------------------------------
// API object implementation wrappers
//-------------------------------------------------------------------------
class ApiTreeImpl;
class ApiRootTreeImpl;
// these objects just provide the pieces needed to navigate and manipulate trees and nodes
// A common base class for 'element' classes
class NodeElement : Noncopyable
{
public:
typedef ServiceImplementationInfo ServiceInfo;
public:
virtual ~NodeElement() {}
// self-locked methods for dispose handling
void checkAlive() const;
// api object handling
UnoInterface* getUnoInstance() const
{ return doGetUnoInstance(); }
ServiceInfo const * getServiceInfo() const
{ return doGetServiceInfo(); }
private:
virtual UnoInterface* doGetUnoInstance() const = 0;
virtual ServiceInfo const* doGetServiceInfo() const = 0;
virtual ApiTreeImpl& getApiTree() const = 0;
friend class Factory;
};
//-----------------------------------------------------------------------------
// A class for tagging inner nodes
class InnerElement : public NodeElement
{
public:
// Only used as a tag
};
//-----------------------------------------------------------------------------
// A common base class for tree-owning elemnt classes
class TreeElement : public NodeElement
{
public:
// model access
configuration::TreeRef getTreeRef() const;
configuration::Tree getTree() const;
// api object handling
Factory& getFactory();
Notifier getNotifier();
protected:
virtual ApiTreeImpl& getApiTree() const = 0;
};
//-----------------------------------------------------------------------------
// Info interfaces for Set Elements
class SetElement : public TreeElement
{
public:
// self-locked methods for dispose handling
bool disposeTree(bool bForceDispose);
void haveNewParent(NodeSetInfoAccess* pNewParent);
configuration::ElementRef getElementRef() const;
configuration::TemplateInfo getTemplateInfo() const;
};
//-----------------------------------------------------------------------------
// Info interfaces for Set Elements
class RootElement : public TreeElement
{
public:
bool disposeTree();
protected:
virtual ApiRootTreeImpl& getRootTree() = 0;
};
//-----------------------------------------------------------------------------
// Info interfaces for Set Elements
class UpdateRootElement : public RootElement
{
public:
Committer getCommitter();
};
//-----------------------------------------------------------------------------
/// guards a TreeElement; provides an object (read) lock, ensures object was not disposed
// FIXME: bin this ...
class TreeReadGuardImpl : Noncopyable
{
TreeElement& m_rTree;
public:
TreeReadGuardImpl(TreeElement& rTree);
~TreeReadGuardImpl() throw ();
public:
TreeElement& get() const { return m_rTree; }
};
// Thin Wrappers around TreeElements: Provide guarding and convenient access
/// wraps a TreeElement; provides an object (read) lock, ensures object was not disposed
class GuardedTreeElement
{
UnoApiLock m_aLock;
TreeReadGuardImpl m_aImpl;
public:
GuardedTreeElement(TreeElement& rTree) : m_aImpl(rTree) {}
public:
TreeElement& get() const { return m_aImpl.get(); }
};
class GuardedRootElement
{
UnoApiLock m_aLock;
TreeReadGuardImpl m_aImpl;
public:
GuardedRootElement(RootElement& rTree);
public:
RootElement& get() const { return static_cast<RootElement&>(m_aImpl.get()); }
configuration::Tree getTree() const;
};
//-----------------------------------------------------------------------------
}
}
#endif // CONFIGMGR_API_TREEACCESS_HXX_