2000-09-18 23:16:46 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
|
|
|
* $RCSfile: definitioncontainer.cxx,v $
|
|
|
|
*
|
2002-08-21 05:39:14 +00:00
|
|
|
* $Revision: 1.16 $
|
2000-09-18 23:16:46 +00:00
|
|
|
*
|
2002-08-21 05:39:14 +00:00
|
|
|
* last change: $Author: oj $ $Date: 2002-08-21 06:39:14 $
|
2000-09-18 23:16:46 +00:00
|
|
|
*
|
|
|
|
* The Contents of this file are made available subject to the terms of
|
|
|
|
* either of the following licenses
|
|
|
|
*
|
|
|
|
* - GNU Lesser General Public License Version 2.1
|
|
|
|
* - Sun Industry Standards Source License Version 1.1
|
|
|
|
*
|
|
|
|
* Sun Microsystems Inc., October, 2000
|
|
|
|
*
|
|
|
|
* GNU Lesser General Public License Version 2.1
|
|
|
|
* =============================================
|
|
|
|
* Copyright 2000 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
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Sun Industry Standards Source License Version 1.1
|
|
|
|
* =================================================
|
|
|
|
* The contents of this file are subject to the Sun Industry Standards
|
|
|
|
* Source License Version 1.1 (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.openoffice.org/license.html.
|
|
|
|
*
|
|
|
|
* Software provided under this License is provided on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
|
|
|
|
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
|
|
|
|
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
|
|
|
|
* See the License for the specific provisions governing your rights and
|
|
|
|
* obligations concerning the Software.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
|
|
|
|
*
|
|
|
|
* Copyright: 2000 by Sun Microsystems, Inc.
|
|
|
|
*
|
|
|
|
* All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s): _______________________________________
|
|
|
|
*
|
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
#ifndef _DBA_CORE_DEFINITIONCONTAINER_HXX_
|
|
|
|
#include "definitioncontainer.hxx"
|
|
|
|
#endif
|
2000-10-25 06:42:28 +00:00
|
|
|
#ifndef DBACCESS_SHARED_DBASTRINGS_HRC
|
|
|
|
#include "dbastrings.hrc"
|
2000-09-18 23:16:46 +00:00
|
|
|
#endif
|
|
|
|
#ifndef _DBA_CORE_CONTAINERELEMENT_HXX_
|
|
|
|
#include "containerelement.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _DBASHARED_APITOOLS_HXX_
|
|
|
|
#include "apitools.hxx"
|
|
|
|
#endif
|
2001-04-26 10:23:48 +00:00
|
|
|
#ifndef _DBA_CORE_RESOURCE_HXX_
|
|
|
|
#include "core_resource.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _DBA_CORE_RESOURCE_HRC_
|
|
|
|
#include "core_resource.hrc"
|
|
|
|
#endif
|
2000-09-18 23:16:46 +00:00
|
|
|
|
|
|
|
#ifndef _TOOLS_DEBUG_HXX
|
|
|
|
#include <tools/debug.hxx>
|
|
|
|
#endif
|
2000-10-11 10:21:40 +00:00
|
|
|
#ifndef _COMPHELPER_SEQUENCE_HXX_
|
|
|
|
#include <comphelper/sequence.hxx>
|
2000-09-18 23:16:46 +00:00
|
|
|
#endif
|
2000-10-11 10:21:40 +00:00
|
|
|
#ifndef _COMPHELPER_ENUMHELPER_HXX_
|
|
|
|
#include <comphelper/enumhelper.hxx>
|
2000-09-18 23:16:46 +00:00
|
|
|
#endif
|
2001-03-15 07:29:16 +00:00
|
|
|
#ifndef _COMPHELPER_EXTRACT_HXX_
|
|
|
|
#include <comphelper/extract.hxx>
|
2000-09-18 23:16:46 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef _COM_SUN_STAR_UTIL_XFLUSHABLE_HPP_
|
|
|
|
#include <com/sun/star/util/XFlushable.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_LANG_XCOMPONENT_HPP_
|
|
|
|
#include <com/sun/star/lang/XComponent.hpp>
|
|
|
|
#endif
|
2000-10-25 06:42:28 +00:00
|
|
|
#ifndef _COM_SUN_STAR_LANG_XUNOTUNNEL_HPP_
|
|
|
|
#include <com/sun/star/lang/XUnoTunnel.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COMPHELPER_TYPES_HXX_
|
|
|
|
#include <comphelper/types.hxx>
|
|
|
|
#endif
|
2000-09-18 23:16:46 +00:00
|
|
|
|
|
|
|
using namespace ::com::sun::star::uno;
|
|
|
|
using namespace ::com::sun::star::lang;
|
|
|
|
using namespace ::com::sun::star::util;
|
|
|
|
using namespace ::com::sun::star::beans;
|
|
|
|
using namespace ::com::sun::star::container;
|
|
|
|
using namespace ::osl;
|
2000-10-11 10:21:40 +00:00
|
|
|
using namespace ::comphelper;
|
2000-09-18 23:16:46 +00:00
|
|
|
using namespace ::cppu;
|
2001-06-18 10:50:01 +00:00
|
|
|
using namespace ::utl;
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
//........................................................................
|
|
|
|
namespace dbaccess
|
|
|
|
{
|
|
|
|
//........................................................................
|
|
|
|
|
2000-09-18 23:16:46 +00:00
|
|
|
//==========================================================================
|
|
|
|
//= ODefinitionContainer
|
|
|
|
//==========================================================================
|
|
|
|
DBG_NAME(ODefinitionContainer)
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
ODefinitionContainer::ODefinitionContainer(OWeakObject& _rParent, Mutex& _rMutex)
|
2000-10-18 15:16:39 +00:00
|
|
|
:OConfigurationFlushable(_rMutex)
|
|
|
|
,m_aContainerListeners(_rMutex)
|
2000-09-18 23:16:46 +00:00
|
|
|
,m_rParent(_rParent)
|
|
|
|
,m_bInitialized(sal_False)
|
|
|
|
{
|
|
|
|
DBG_CTOR(ODefinitionContainer, NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
2000-10-18 15:16:39 +00:00
|
|
|
void ODefinitionContainer::initialize(const OConfigurationTreeRoot& _rConfigurationRoot, sal_Bool _bRead)
|
2000-09-18 23:16:46 +00:00
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
2000-10-18 15:16:39 +00:00
|
|
|
m_aConfigurationNode = _rConfigurationRoot;
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
DBG_ASSERT(m_aConfigurationNode.isValid(), "ODefinitionContainer::initialize : need a starting point within the configuration !");
|
2000-09-18 23:16:46 +00:00
|
|
|
DBG_ASSERT(!m_bInitialized, "ODefinitionContainer::initialize : already initialized !");
|
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
if (m_aConfigurationNode.isValid())
|
|
|
|
{
|
|
|
|
DBG_ASSERT(m_aConfigurationNode.isSetNode(), "ODefinitionContainer::initialize: our config node should be a set node!");
|
|
|
|
m_aConfigurationNode.setEscape(sal_True);
|
2000-09-18 23:16:46 +00:00
|
|
|
initializeFromConfiguration();
|
2000-10-18 15:16:39 +00:00
|
|
|
}
|
2000-09-18 23:16:46 +00:00
|
|
|
|
|
|
|
m_bInitialized = sal_True;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
void ODefinitionContainer::dispose()
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
|
|
|
DBG_ASSERT(m_bInitialized, "ODefinitionContainer::dispose : not initialized !");
|
|
|
|
|
|
|
|
// say our listeners goobye
|
|
|
|
EventObject aEvt(*this);
|
|
|
|
m_aContainerListeners.disposeAndClear(aEvt);
|
|
|
|
|
|
|
|
// dispose our elements
|
|
|
|
for ( ConstDocumentsIterator aLoop = m_aDocuments.begin();
|
2002-06-27 07:06:09 +00:00
|
|
|
aLoop != m_aDocuments.end();
|
2000-09-18 23:16:46 +00:00
|
|
|
++aLoop
|
|
|
|
)
|
|
|
|
{
|
2001-10-30 08:55:07 +00:00
|
|
|
Reference<XPropertySet> xProp = aLoop->xObject;
|
2002-08-21 05:39:14 +00:00
|
|
|
if ( xProp.is() )
|
|
|
|
{
|
|
|
|
removeObjectListener(xProp);
|
|
|
|
::comphelper::disposeComponent(xProp);
|
|
|
|
}
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// remove our elements
|
|
|
|
m_aDocumentMap.clear();
|
|
|
|
m_aDocuments.clear();
|
|
|
|
m_aDocumentObjectKeys.clear();
|
2000-10-18 15:16:39 +00:00
|
|
|
m_aConfigurationNode.clear();
|
2000-09-18 23:16:46 +00:00
|
|
|
|
|
|
|
m_bInitialized = sal_False;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
2000-10-18 15:16:39 +00:00
|
|
|
void ODefinitionContainer::flush_NoBroadcast_NoCommit()
|
2000-09-18 23:16:46 +00:00
|
|
|
{
|
2000-10-18 15:16:39 +00:00
|
|
|
DBG_ASSERT(m_aConfigurationNode.isValid(), "ODefinitionContainer::flush : need a starting point within the configuration !");
|
2000-09-18 23:16:46 +00:00
|
|
|
DBG_ASSERT(m_bInitialized, "ODefinitionContainer::flush : not initialized !");
|
|
|
|
|
|
|
|
for ( ConstDocumentsIterator aLoop = m_aDocuments.begin();
|
2002-06-27 07:06:09 +00:00
|
|
|
aLoop != m_aDocuments.end();
|
2000-09-18 23:16:46 +00:00
|
|
|
++aLoop
|
|
|
|
)
|
|
|
|
{
|
2002-06-27 07:06:09 +00:00
|
|
|
if (aLoop->xObject.get().is())
|
2000-09-18 23:16:46 +00:00
|
|
|
{
|
2000-10-18 15:16:39 +00:00
|
|
|
// TODO: perhaps we should use the flush_NoBroadcast_NoCommit of the implementations of the objects
|
|
|
|
// the method here is called flush_NoBroadcast_NoCommit, which is contradicted by a direct flush call ...
|
2002-06-27 07:06:09 +00:00
|
|
|
Reference< XFlushable > xFlush(aLoop->xObject.get(), UNO_QUERY);
|
2000-09-18 23:16:46 +00:00
|
|
|
DBG_ASSERT(xFlush.is(), "ODefinitionContainer::flush : have a living object which is not flushable !");
|
|
|
|
if (xFlush.is())
|
|
|
|
try
|
|
|
|
{
|
|
|
|
xFlush->flush();
|
|
|
|
}
|
|
|
|
catch(Exception&)
|
|
|
|
{
|
|
|
|
DBG_ERROR("ODefinitionContainer::flush : could not write one of my objects !");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
ODefinitionContainer::~ODefinitionContainer()
|
|
|
|
{
|
|
|
|
DBG_DTOR(ODefinitionContainer, NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
// XServiceInfo
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ODefinitionContainer::getImplementationName( ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
return ::rtl::OUString::createFromAscii("com.sun.star.sdb.ODefinitionContainer");
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODefinitionContainer::supportsService( const ::rtl::OUString& _rServiceName ) throw (RuntimeException)
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
|
|
|
checkValid(sal_False);
|
|
|
|
return findValue(getSupportedServiceNames(), _rServiceName, sal_True).getLength() != 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
Sequence< ::rtl::OUString > SAL_CALL ODefinitionContainer::getSupportedServiceNames( ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
Sequence< ::rtl::OUString > aReturn(1);
|
|
|
|
aReturn.getArray()[0] = ::rtl::OUString::createFromAscii("com.sun.star.sdb.DefinitionContainer");
|
|
|
|
return aReturn;
|
|
|
|
}
|
|
|
|
|
|
|
|
// XNameContainer
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ODefinitionContainer::insertByName( const ::rtl::OUString& _rName, const Any& aElement ) throw(IllegalArgumentException, ElementExistException, WrappedTargetException, RuntimeException)
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
2001-09-25 12:28:23 +00:00
|
|
|
|
|
|
|
implInsert(_rName,aElement);
|
|
|
|
|
|
|
|
// notify the listeners
|
|
|
|
if (m_aContainerListeners.getLength())
|
|
|
|
{
|
|
|
|
Reference< XPropertySet > xNewElement;
|
|
|
|
aElement >>= xNewElement;
|
|
|
|
|
|
|
|
ContainerEvent aEvent(*this, makeAny(_rName), makeAny(xNewElement), Any());
|
|
|
|
OInterfaceIteratorHelper aListenerIterator(m_aContainerListeners);
|
|
|
|
while (aListenerIterator.hasMoreElements())
|
|
|
|
static_cast< XContainerListener* >(aListenerIterator.next())->elementInserted(aEvent);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
void ODefinitionContainer::implInsert(const ::rtl::OUString& _rName, const Any& aElement)
|
|
|
|
{
|
2000-09-18 23:16:46 +00:00
|
|
|
checkValid(sal_True);
|
|
|
|
|
|
|
|
if (checkExistence(_rName))
|
|
|
|
throw ElementExistException();
|
|
|
|
|
|
|
|
// approve the new object
|
|
|
|
Reference< XPropertySet > xNewElement;
|
|
|
|
::cppu::extractInterface(xNewElement, aElement);
|
|
|
|
if (!approveNewObject(xNewElement))
|
|
|
|
throw IllegalArgumentException();
|
|
|
|
|
|
|
|
// get the implementation which allows us to set the new name and the new configuration location
|
|
|
|
// TODO : think about doing all this without implementation access, e.g. by calling setParent on
|
|
|
|
// a XChild and storeAs on an XStorable
|
|
|
|
// or maybe we should allow such objects : they're not persistent, then, and know nothing about their name
|
|
|
|
OContainerElement* pNewElement = NULL;
|
|
|
|
if (!getImplementation(pNewElement, Reference< XInterface >(xNewElement)))
|
|
|
|
throw IllegalArgumentException();
|
|
|
|
|
|
|
|
// for storing the new element
|
|
|
|
Reference< XFlushable > xNewFlushable(xNewElement, UNO_QUERY);
|
|
|
|
if (!xNewFlushable.is())
|
|
|
|
throw IllegalArgumentException();
|
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
OConfigurationNode aObjectNode = m_aConfigurationNode.createNode(_rName);
|
|
|
|
OSL_VERIFY(m_aConfigurationNode.commit());
|
|
|
|
|
|
|
|
if (!aObjectNode.isValid())
|
2000-09-18 23:16:46 +00:00
|
|
|
{ // something went wrong
|
|
|
|
DBG_ERROR("ODefinitionContainer::insertByName : could not create the new configuration nodes !");
|
|
|
|
throw RuntimeException(::rtl::OUString(), *this);
|
|
|
|
}
|
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
implAppend(_rName, xNewElement, aObjectNode);
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
pNewElement->inserted(static_cast<OWeakObject*>(this), _rName, aObjectNode.cloneAsRoot());
|
2000-09-18 23:16:46 +00:00
|
|
|
xNewFlushable->flush();
|
|
|
|
}
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ODefinitionContainer::removeByName( const ::rtl::OUString& _rName ) throw(NoSuchElementException, WrappedTargetException, RuntimeException)
|
|
|
|
{
|
2000-10-18 15:16:39 +00:00
|
|
|
Reference< XPropertySet > xOldElement;
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
|
|
|
checkValid(sal_True);
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
// check the arguments
|
|
|
|
if (!_rName.getLength())
|
|
|
|
throw IllegalArgumentException();
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
if (!checkExistence(_rName))
|
|
|
|
throw NoSuchElementException();
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
// the old element (for the notifications)
|
|
|
|
xOldElement = implGetByName(_rName, (m_aContainerListeners.getLength() != 0));
|
|
|
|
// as this is potentially expensive (if the object is not already created and initialized from the registry)
|
|
|
|
// we load the element only if we have listeners which may be interested in
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
// do the removal
|
|
|
|
implRemove(_rName);
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
OContainerElement* pOldElement = NULL;
|
|
|
|
getImplementation(pOldElement, Reference< XInterface >(xOldElement));
|
|
|
|
DBG_ASSERT(pOldElement, "ODefinitionContainer::removeByName : have an invalid object !");
|
|
|
|
// we never should have inserted this when it's no OContainerElement
|
|
|
|
if (pOldElement)
|
|
|
|
pOldElement->removed();
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
disposeComponent(xOldElement);
|
|
|
|
}
|
2000-09-18 23:16:46 +00:00
|
|
|
|
|
|
|
// notify the listeners
|
|
|
|
if (m_aContainerListeners.getLength())
|
|
|
|
{
|
|
|
|
ContainerEvent aEvent(*this, makeAny(_rName), makeAny(xOldElement), Any());
|
|
|
|
OInterfaceIteratorHelper aListenerIterator(m_aContainerListeners);
|
|
|
|
while (aListenerIterator.hasMoreElements())
|
|
|
|
static_cast< XContainerListener* >(aListenerIterator.next())->elementRemoved(aEvent);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// XNameReplace
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ODefinitionContainer::replaceByName( const ::rtl::OUString& _rName, const Any& aElement ) throw(IllegalArgumentException, NoSuchElementException, WrappedTargetException, RuntimeException)
|
|
|
|
{
|
2000-10-18 15:16:39 +00:00
|
|
|
ClearableMutexGuard aGuard(m_rMutex);
|
2000-09-18 23:16:46 +00:00
|
|
|
checkValid(sal_True);
|
|
|
|
|
|
|
|
// check the arguments
|
|
|
|
if (!_rName.getLength())
|
|
|
|
throw IllegalArgumentException();
|
|
|
|
|
|
|
|
// let derived classes approve the new object
|
|
|
|
Reference< XPropertySet > xNewElement;
|
|
|
|
::cppu::extractInterface(xNewElement, aElement);
|
|
|
|
if (!approveNewObject(xNewElement))
|
|
|
|
throw IllegalArgumentException();
|
|
|
|
|
|
|
|
// get the implementation so we can notify the new object about it's new name and locations
|
|
|
|
// TODO : think about doing all this without implementation access, e.g. by calling setParent on
|
|
|
|
// a XChild and storeAs on an XStorable
|
|
|
|
// or maybe we should allow such objects : they're not persistent, then, and know nothing about their name
|
|
|
|
OContainerElement* pNewElement = NULL;
|
|
|
|
if (!getImplementation(pNewElement, Reference< XInterface >(xNewElement)))
|
|
|
|
throw IllegalArgumentException();
|
|
|
|
|
|
|
|
// for storing the new element
|
|
|
|
Reference< XFlushable > xNewFlushable(xNewElement, UNO_QUERY);
|
|
|
|
if (!xNewFlushable.is())
|
|
|
|
throw IllegalArgumentException();
|
|
|
|
|
|
|
|
// the old element (for the notifications)
|
|
|
|
Reference< XPropertySet > xOldElement = implGetByName(_rName, m_aContainerListeners.getLength() != 0);
|
|
|
|
// as this is potentially expensive (if the object is not already created and initialized from the registry)
|
|
|
|
// we get the element only if we have listeners which may be interested in
|
|
|
|
|
|
|
|
// do the replace
|
2000-10-18 15:16:39 +00:00
|
|
|
OConfigurationNode aObjectDescription;
|
|
|
|
implReplace(_rName, xNewElement, aObjectDescription);
|
2000-09-18 23:16:46 +00:00
|
|
|
|
|
|
|
// tell the old element it has been removed
|
|
|
|
OContainerElement* pOldElement = NULL;
|
|
|
|
if (getImplementation(pOldElement, Reference< XInterface >(xOldElement)))
|
|
|
|
pOldElement->removed();
|
|
|
|
|
|
|
|
// and dispose it
|
|
|
|
disposeComponent(xOldElement);
|
|
|
|
|
|
|
|
// tell the new element it's new name/location and flush it
|
2000-10-18 15:16:39 +00:00
|
|
|
pNewElement->inserted(static_cast<OWeakObject*>(this), _rName, aObjectDescription.cloneAsRoot());
|
2000-09-18 23:16:46 +00:00
|
|
|
xNewFlushable->flush();
|
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
aGuard.clear();
|
2000-09-18 23:16:46 +00:00
|
|
|
// notify the listeners
|
|
|
|
if (m_aContainerListeners.getLength())
|
|
|
|
{
|
|
|
|
ContainerEvent aEvent(*this, makeAny(_rName), makeAny(xNewElement), makeAny(xOldElement));
|
|
|
|
OInterfaceIteratorHelper aListenerIterator(m_aContainerListeners);
|
|
|
|
while (aListenerIterator.hasMoreElements())
|
|
|
|
static_cast< XContainerListener* >(aListenerIterator.next())->elementReplaced(aEvent);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ODefinitionContainer::addContainerListener( const Reference< XContainerListener >& _rxListener ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
|
|
|
if (_rxListener.is())
|
|
|
|
m_aContainerListeners.addInterface(_rxListener);
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ODefinitionContainer::removeContainerListener( const Reference< XContainerListener >& _rxListener ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
|
|
|
if (_rxListener.is())
|
|
|
|
m_aContainerListeners.removeInterface(_rxListener);
|
|
|
|
}
|
|
|
|
|
|
|
|
// XElementAccess
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
Type SAL_CALL ODefinitionContainer::getElementType( ) throw (RuntimeException)
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
|
|
|
checkValid(sal_False);
|
|
|
|
return ::getCppuType( static_cast< Reference< XPropertySet >* >(NULL) );
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODefinitionContainer::hasElements( ) throw (RuntimeException)
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
|
|
|
checkValid(sal_False);
|
|
|
|
return m_aDocuments.size() != 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
// XEnumerationAccess
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
Reference< XEnumeration > SAL_CALL ODefinitionContainer::createEnumeration( ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
|
|
|
checkValid(sal_False);
|
2000-10-11 10:21:40 +00:00
|
|
|
return new ::comphelper::OEnumerationByIndex(static_cast<XIndexAccess*>(this));
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
// XIndexAccess
|
|
|
|
sal_Int32 SAL_CALL ODefinitionContainer::getCount( ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
|
|
|
checkValid(sal_False);
|
|
|
|
return m_aDocuments.size();
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
Any SAL_CALL ODefinitionContainer::getByIndex( sal_Int32 _nIndex ) throw(IndexOutOfBoundsException, WrappedTargetException, RuntimeException)
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
|
|
|
checkValid(sal_False);
|
|
|
|
|
2001-02-07 12:15:00 +00:00
|
|
|
if ((_nIndex < 0) || (_nIndex >= (sal_Int32)m_aDocuments.size()))
|
2000-09-18 23:16:46 +00:00
|
|
|
throw IndexOutOfBoundsException();
|
|
|
|
|
|
|
|
DocumentsIterator aPos = m_aDocuments.begin() + _nIndex;
|
2002-06-27 07:06:09 +00:00
|
|
|
Reference<XPropertySet> xProp = aPos->xObject;
|
|
|
|
if (!xProp.is())
|
2000-09-18 23:16:46 +00:00
|
|
|
{ // that's the first access to the object
|
|
|
|
// -> create it
|
2002-06-27 07:06:09 +00:00
|
|
|
xProp = createObject(aPos->sName, m_aDocumentObjectKeys[aPos->sName]);
|
|
|
|
aPos->xObject = xProp;
|
2000-09-18 23:16:46 +00:00
|
|
|
// and update the name-access map
|
|
|
|
m_aDocumentMap[aPos->sName] = aPos->xObject;
|
|
|
|
|
|
|
|
#if DBG_UTIL
|
2002-06-27 07:06:09 +00:00
|
|
|
Reference< XFlushable > xFlushable(aPos->xObject.get(), UNO_QUERY);
|
2000-09-18 23:16:46 +00:00
|
|
|
DBG_ASSERT(xFlushable.is(), "ODefinitionContainer::getByIndex : createObject returned an invalid object (no XFlushable) !");
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2002-06-27 07:06:09 +00:00
|
|
|
return makeAny(xProp);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
Any SAL_CALL ODefinitionContainer::getByName( const ::rtl::OUString& _rName ) throw(NoSuchElementException, WrappedTargetException, RuntimeException)
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
|
|
|
checkValid(sal_False);
|
|
|
|
|
|
|
|
return makeAny(implGetByName(_rName));
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
Reference< XPropertySet > ODefinitionContainer::implGetByName(const ::rtl::OUString& _rName, sal_Bool _bReadIfNeccessary) throw (NoSuchElementException)
|
|
|
|
{
|
|
|
|
PropertySetMapIterator aMapPos = m_aDocumentMap.find(_rName);
|
|
|
|
if (aMapPos == m_aDocumentMap.end())
|
|
|
|
throw NoSuchElementException();
|
|
|
|
|
2002-06-27 07:06:09 +00:00
|
|
|
Reference< XPropertySet > xProp = aMapPos->second;
|
|
|
|
|
|
|
|
if (_bReadIfNeccessary && !aMapPos->second.get().is())
|
2000-09-18 23:16:46 +00:00
|
|
|
{ // the object has never been accessed before, so we have to read it now
|
|
|
|
// (that's the expensive part)
|
|
|
|
|
|
|
|
// create the object and insert it into the map
|
2002-06-27 07:06:09 +00:00
|
|
|
xProp = createObject(_rName, m_aDocumentObjectKeys[_rName]);
|
|
|
|
aMapPos->second = xProp;
|
2000-09-18 23:16:46 +00:00
|
|
|
|
|
|
|
// update the vector for the index access
|
|
|
|
for ( DocumentsIterator aSearch = m_aDocuments.begin();
|
|
|
|
aSearch != m_aDocuments.end();
|
|
|
|
++aSearch
|
|
|
|
)
|
|
|
|
{
|
|
|
|
if (aSearch->sName.equals(_rName))
|
|
|
|
{
|
2002-06-27 07:06:09 +00:00
|
|
|
aSearch->xObject = xProp;
|
2001-10-30 08:55:07 +00:00
|
|
|
addObjectListener(aSearch->xObject);
|
2000-09-18 23:16:46 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-06-27 07:06:09 +00:00
|
|
|
return xProp;
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
Sequence< ::rtl::OUString > SAL_CALL ODefinitionContainer::getElementNames( ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
|
|
|
checkValid(sal_False);
|
|
|
|
|
|
|
|
Sequence< ::rtl::OUString > aNames(m_aDocumentMap.size());
|
|
|
|
::rtl::OUString* pNames = aNames.getArray();
|
|
|
|
;
|
|
|
|
for ( ConstPropertySetMapIterator aNameIter = m_aDocumentMap.begin();
|
|
|
|
aNameIter != m_aDocumentMap.end();
|
|
|
|
++pNames, ++aNameIter
|
|
|
|
)
|
|
|
|
{
|
|
|
|
*pNames = aNameIter->first;
|
|
|
|
}
|
|
|
|
|
|
|
|
return aNames;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ODefinitionContainer::hasByName( const ::rtl::OUString& _rName ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
|
|
|
checkValid(sal_False);
|
|
|
|
|
|
|
|
return (m_aDocumentMap.find(_rName) != m_aDocumentMap.end());
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ODefinitionContainer::disposing( const EventObject& _rSource ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
Reference< XPropertySet > xSource(_rSource.Source, UNO_QUERY);
|
|
|
|
// it's one of our documents ....
|
|
|
|
for ( DocumentsIterator aLoop = m_aDocuments.begin();
|
2002-06-27 07:06:09 +00:00
|
|
|
aLoop != m_aDocuments.end();
|
2000-09-18 23:16:46 +00:00
|
|
|
++aLoop
|
|
|
|
)
|
|
|
|
{
|
2002-06-27 07:06:09 +00:00
|
|
|
if (xSource == aLoop->xObject.get().get())
|
2000-09-18 23:16:46 +00:00
|
|
|
{
|
2001-10-30 08:55:07 +00:00
|
|
|
removeObjectListener(aLoop->xObject);
|
2000-09-18 23:16:46 +00:00
|
|
|
// and clear our document map/vector, so the object will be recreated on next access
|
2002-06-27 07:06:09 +00:00
|
|
|
aLoop->xObject = PropertySetRef();//.clear();
|
|
|
|
m_aDocumentMap[aLoop->sName] = PropertySetRef();//.clear();
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
void ODefinitionContainer::initializeFromConfiguration()
|
|
|
|
{
|
2000-10-18 15:16:39 +00:00
|
|
|
if (!m_aConfigurationNode.isValid())
|
2000-09-18 23:16:46 +00:00
|
|
|
{
|
|
|
|
DBG_ERROR("ODefinitionContainer::initializeFromConfiguration : invalid configuration key !");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
Sequence< ::rtl::OUString > aDefinitionNames = m_aConfigurationNode.getNodeNames();
|
|
|
|
const ::rtl::OUString* pDefinitionNames = aDefinitionNames.getConstArray();
|
|
|
|
for (sal_Int32 i=0; i<aDefinitionNames.getLength(); ++i, ++pDefinitionNames)
|
2000-09-18 23:16:46 +00:00
|
|
|
{
|
2000-10-18 15:16:39 +00:00
|
|
|
// get the node under which the object is stored
|
|
|
|
OConfigurationNode aObjectNode = m_aConfigurationNode.openNode(*pDefinitionNames);
|
|
|
|
|
|
|
|
if ((0 == pDefinitionNames->getLength()) || !aObjectNode.isValid())
|
2000-09-18 23:16:46 +00:00
|
|
|
{
|
2000-10-18 15:16:39 +00:00
|
|
|
DBG_ERROR("ODefinitionContainer::initializeFromConfiguration : invalid structure within the configuration !");
|
|
|
|
continue;
|
|
|
|
}
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
Reference< XPropertySet > xNewObject;
|
|
|
|
// we don't read this new object here, this may be much to expensive. We read it only on request.
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
m_aDocuments.push_back(Document(*pDefinitionNames, xNewObject));
|
|
|
|
m_aDocumentMap[*pDefinitionNames] = xNewObject;
|
|
|
|
m_aDocumentObjectKeys[*pDefinitionNames] = aObjectNode;
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
sal_Bool ODefinitionContainer::isReadOnly() const
|
|
|
|
{
|
2000-10-18 15:16:39 +00:00
|
|
|
return !m_aConfigurationNode.isValid() || m_aConfigurationNode.isReadonly();
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
void ODefinitionContainer::implRemove(const ::rtl::OUString& _rName)
|
|
|
|
{
|
|
|
|
// from the object maps
|
|
|
|
m_aDocumentMap.erase(_rName);
|
|
|
|
for ( DocumentsIterator aSearch = m_aDocuments.begin();
|
|
|
|
aSearch != m_aDocuments.end();
|
|
|
|
++aSearch
|
|
|
|
)
|
|
|
|
{
|
|
|
|
if (aSearch->sName.equals(_rName))
|
|
|
|
{
|
|
|
|
m_aDocuments.erase(aSearch);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
m_aDocumentObjectKeys.erase(_rName);
|
2000-10-18 15:16:39 +00:00
|
|
|
m_aConfigurationNode.removeNode(_rName);
|
|
|
|
OSL_VERIFY(m_aConfigurationNode.commit());
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
2000-10-18 15:16:39 +00:00
|
|
|
void ODefinitionContainer::implAppend(const ::rtl::OUString& _rName, const Reference< XPropertySet >& _rxNewObject, const OConfigurationNode& _rObjectNode)
|
2000-09-18 23:16:46 +00:00
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
2001-10-30 08:55:07 +00:00
|
|
|
OSL_ENSURE(_rxNewObject.is(),"Object is null!");
|
2000-09-18 23:16:46 +00:00
|
|
|
try
|
|
|
|
{
|
|
|
|
// now update our structures
|
2001-10-30 08:55:07 +00:00
|
|
|
if(_rxNewObject.is())
|
|
|
|
{
|
|
|
|
m_aDocuments.push_back(Document(_rName, _rxNewObject));
|
|
|
|
m_aDocumentMap[_rName] = _rxNewObject;
|
|
|
|
m_aDocumentObjectKeys[_rName] = _rObjectNode;
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2001-10-30 08:55:07 +00:00
|
|
|
addObjectListener(_rxNewObject);
|
|
|
|
}
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
catch(Exception&)
|
|
|
|
{
|
|
|
|
DBG_ERROR("ODefinitionContainer::implAppend : catched something !");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
2000-10-18 15:16:39 +00:00
|
|
|
void ODefinitionContainer::implReplace(const ::rtl::OUString& _rName, const Reference< XPropertySet >& _rxNewObject, OConfigurationNode& _rNewObjectNode)
|
2000-09-18 23:16:46 +00:00
|
|
|
{
|
|
|
|
DBG_ASSERT(checkExistence(_rName), "ODefinitionContainer::implReplace : invalid name !");
|
|
|
|
|
|
|
|
m_aDocumentMap[_rName] = _rxNewObject;
|
|
|
|
for ( DocumentsIterator aSearch = m_aDocuments.begin();
|
|
|
|
aSearch != m_aDocuments.end();
|
|
|
|
++aSearch
|
|
|
|
)
|
|
|
|
{
|
|
|
|
if (aSearch->sName.equals(_rName))
|
|
|
|
{
|
2001-10-30 08:55:07 +00:00
|
|
|
removeObjectListener(aSearch->xObject);
|
2000-09-18 23:16:46 +00:00
|
|
|
aSearch->xObject = _rxNewObject;
|
2001-10-30 08:55:07 +00:00
|
|
|
addObjectListener(aSearch->xObject);
|
2000-09-18 23:16:46 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
_rNewObjectNode.clear();
|
2000-09-18 23:16:46 +00:00
|
|
|
// update the configuration
|
2000-10-18 15:16:39 +00:00
|
|
|
// clear all old data
|
|
|
|
m_aConfigurationNode.removeNode(_rName);
|
|
|
|
OSL_VERIFY(m_aConfigurationNode.commit());
|
|
|
|
|
|
|
|
_rNewObjectNode = m_aDocumentObjectKeys[_rName] = m_aConfigurationNode.createNode(_rName);
|
|
|
|
OSL_VERIFY(m_aConfigurationNode.commit());
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
void ODefinitionContainer::checkValid(sal_Bool _bIntendWriteAccess) const throw (RuntimeException, DisposedException)
|
|
|
|
{
|
|
|
|
if (!m_bInitialized)
|
2000-10-18 15:16:39 +00:00
|
|
|
throw DisposedException();
|
2000-09-18 23:16:46 +00:00
|
|
|
|
|
|
|
if (_bIntendWriteAccess && isReadOnly())
|
2001-05-04 07:41:22 +00:00
|
|
|
{
|
|
|
|
::rtl::OUString sMessage = DBACORE_RESSTRING( RID_STR_NEED_CONFIG_WRITE_ACCESS);
|
2000-10-18 15:16:39 +00:00
|
|
|
DisposedException(
|
2001-05-04 07:41:22 +00:00
|
|
|
sMessage,
|
2001-04-26 10:23:48 +00:00
|
|
|
Reference< XInterface >(const_cast<XServiceInfo*>(static_cast<const XServiceInfo*>(this)))
|
|
|
|
);
|
2001-05-04 07:41:22 +00:00
|
|
|
}
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
DBG_ASSERT( (m_aDocuments.size() == m_aDocumentObjectKeys.size()) &&
|
2000-09-18 23:16:46 +00:00
|
|
|
(m_aDocuments.size() == m_aDocumentMap.size()),
|
|
|
|
"ODefinitionContainer::checkValid : inconsistent state !");
|
|
|
|
}
|
|
|
|
|
2001-02-07 12:15:00 +00:00
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
Reference< XInterface > SAL_CALL ODefinitionContainer::createInstance( ) throw(Exception, RuntimeException)
|
|
|
|
{
|
|
|
|
Reference< XPropertySet > xNew = createObject();
|
|
|
|
OSL_ENSURE(approveNewObject(xNew), "ODefinitionContainer::createInstance: createObject returned nonsense!");
|
|
|
|
return xNew.get();
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
Reference< XInterface > SAL_CALL ODefinitionContainer::createInstanceWithArguments( const Sequence< Any >& /* aArguments */ ) throw(Exception, RuntimeException)
|
|
|
|
{
|
|
|
|
return createInstance();
|
|
|
|
}
|
|
|
|
|
2000-09-18 23:16:46 +00:00
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
sal_Bool ODefinitionContainer::approveNewObject(const Reference< XPropertySet >& _rxObject) const
|
|
|
|
{
|
|
|
|
return _rxObject.is();
|
|
|
|
}
|
|
|
|
|
2001-04-25 11:43:09 +00:00
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
Reference< XInterface > SAL_CALL ODefinitionContainer::getParent( ) throw (RuntimeException)
|
|
|
|
{
|
|
|
|
return m_rParent;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ODefinitionContainer::setParent( const Reference< XInterface >& Parent ) throw (NoSupportException, RuntimeException)
|
|
|
|
{
|
|
|
|
throw NoSupportException();
|
|
|
|
}
|
2001-09-25 12:28:23 +00:00
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
// XPropertyChangeListener
|
|
|
|
void SAL_CALL ODefinitionContainer::propertyChange( const PropertyChangeEvent& evt ) throw (RuntimeException)
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
|
|
|
checkValid(sal_True);
|
2001-09-28 08:37:31 +00:00
|
|
|
if(evt.PropertyName == (rtl::OUString) PROPERTY_NAME)
|
2001-09-25 12:28:23 +00:00
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
::rtl::OUString sNewName,sOldName;
|
|
|
|
evt.OldValue >>= sOldName;
|
|
|
|
evt.NewValue >>= sNewName;
|
2001-10-30 08:55:07 +00:00
|
|
|
Reference<XPropertySet> xProp(evt.Source,UNO_QUERY);
|
|
|
|
removeObjectListener(xProp);
|
2001-09-25 12:28:23 +00:00
|
|
|
implRemove(sOldName);
|
|
|
|
implInsert(sNewName,makeAny(evt.Source));
|
|
|
|
}
|
|
|
|
catch(const Exception&)
|
|
|
|
{
|
|
|
|
OSL_ENSURE(0,"Exception catched!");
|
|
|
|
throw RuntimeException();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
// XVetoableChangeListener
|
|
|
|
void SAL_CALL ODefinitionContainer::vetoableChange( const PropertyChangeEvent& aEvent ) throw (PropertyVetoException, RuntimeException)
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_rMutex);
|
|
|
|
checkValid(sal_True);
|
2001-09-28 08:37:31 +00:00
|
|
|
if(aEvent.PropertyName == (rtl::OUString) PROPERTY_NAME)
|
2001-09-25 12:28:23 +00:00
|
|
|
{
|
|
|
|
::rtl::OUString sNewName;
|
|
|
|
aEvent.NewValue >>= sNewName;
|
|
|
|
if(hasByName(sNewName))
|
|
|
|
throw PropertyVetoException();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
2001-10-30 08:55:07 +00:00
|
|
|
void ODefinitionContainer::addObjectListener(const Reference< XPropertySet >& _xNewObject)
|
|
|
|
{
|
|
|
|
OSL_ENSURE(_xNewObject.is(),"ODefinitionContainer::addObjectListener: Object is null!");
|
|
|
|
_xNewObject->addPropertyChangeListener(PROPERTY_NAME, this);
|
|
|
|
_xNewObject->addVetoableChangeListener(PROPERTY_NAME, this);
|
|
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
void ODefinitionContainer::removeObjectListener(const Reference< XPropertySet >& _xNewObject)
|
|
|
|
{
|
|
|
|
OSL_ENSURE(_xNewObject.is(),"ODefinitionContainer::addObjectListener: Object is null!");
|
|
|
|
_xNewObject->removePropertyChangeListener(PROPERTY_NAME, this);
|
|
|
|
_xNewObject->removeVetoableChangeListener(PROPERTY_NAME, this);
|
|
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
2001-04-25 11:43:09 +00:00
|
|
|
|
2000-10-18 15:16:39 +00:00
|
|
|
//........................................................................
|
|
|
|
} // namespace dbaccess
|
|
|
|
//........................................................................
|