Files
libreoffice/dbaccess/source/core/dataaccess/documentcontainer.cxx
Jens-Heiner Rechtien 58a2847b3a INTEGRATION: CWS dba201b (1.13.2); FILE MERGED
2005/09/21 07:02:30 oj 1.13.2.2: RESYNC: (1.13-1.14); FILE MERGED
2005/07/22 06:02:06 oj 1.13.2.1: #i52171# don't insert impl struct in createInstance call
2005-09-23 11:06:11 +00:00

682 lines
28 KiB
C++

/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: documentcontainer.cxx,v $
*
* $Revision: 1.15 $
*
* last change: $Author: hr $ $Date: 2005-09-23 12:06:11 $
*
* 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 _DBA_COREDATAACCESS_DOCUMENTCONTAINER_HXX_
#include "documentcontainer.hxx"
#endif
#ifndef DBACCESS_SHARED_DBASTRINGS_HRC
#include "dbastrings.hrc"
#endif
#ifndef _DBA_COREDATAACCESS_DOCUMENTDEFINITION_HXX_
#include "documentdefinition.hxx"
#endif
#ifndef _COM_SUN_STAR_UCB_OPENCOMMANDARGUMENT2_HPP_
#include <com/sun/star/ucb/OpenCommandArgument2.hpp>
#endif
#ifndef _COM_SUN_STAR_UCB_OPENMODE_HPP_
#include <com/sun/star/ucb/OpenMode.hpp>
#endif
#ifndef _TOOLS_DEBUG_HXX
#include <tools/debug.hxx>
#endif
#ifndef _CONNECTIVITY_DBTOOLS_HXX_
#include <connectivity/dbtools.hxx>
#endif
#ifndef DBA_UCPRESULTSET_HXX
#include "myucp_resultset.hxx"
#endif
#ifndef _UCBHELPER_CANCELCOMMANDEXECUTION_HXX_
#include <ucbhelper/cancelcommandexecution.hxx>
#endif
#ifndef _COM_SUN_STAR_UCB_UNSUPPORTEDOPENMODEEXCEPTION_HPP_
#include <com/sun/star/ucb/UnsupportedOpenModeException.hpp>
#endif
#ifndef _COM_SUN_STAR_UCB_INSERTCOMMANDARGUMENT_HPP_
#include <com/sun/star/ucb/InsertCommandArgument.hpp>
#endif
#ifndef _COM_SUN_STAR_BEANS_PROPERTYATTRIBUTE_HPP_
#include <com/sun/star/beans/PropertyAttribute.hpp>
#endif
#ifndef _DBA_COREDATAACCESS_DATASOURCE_HXX_
#include "datasource.hxx"
#endif
using namespace ::com::sun::star::uno;
using namespace ::com::sun::star::lang;
using namespace ::com::sun::star::embed;
using namespace ::com::sun::star::beans;
using namespace ::com::sun::star::container;
using namespace ::com::sun::star::ucb;
using namespace ::com::sun::star::sdbc;
using namespace ::com::sun::star::io;
using namespace ::osl;
using namespace ::comphelper;
using namespace ::cppu;
//........................................................................
namespace dbaccess
{
//........................................................................
//==========================================================================
//= ODocumentContainer
//==========================================================================
DBG_NAME(ODocumentContainer)
//--------------------------------------------------------------------------
ODocumentContainer::ODocumentContainer(const Reference< XMultiServiceFactory >& _xORB
,const Reference< XInterface >& _xParentContainer
,const TContentPtr& _pImpl
, sal_Bool _bFormsContainer
)
:ODefinitionContainer(_xORB,_xParentContainer,_pImpl)
,OPropertyStateContainer(m_aBHelper)
,m_bFormsContainer(_bFormsContainer)
{
DBG_CTOR(ODocumentContainer, NULL);
registerProperty(PROPERTY_NAME, PROPERTY_ID_NAME, PropertyAttribute::BOUND | PropertyAttribute::READONLY | PropertyAttribute::CONSTRAINED,
&m_pImpl->m_aProps.aTitle, ::getCppuType(&m_pImpl->m_aProps.aTitle));
}
//--------------------------------------------------------------------------
ODocumentContainer::~ODocumentContainer()
{
DBG_DTOR(ODocumentContainer, NULL);
if ( !m_aBHelper.bInDispose && !m_aBHelper.bDisposed )
{
acquire();
dispose();
}
}
// -----------------------------------------------------------------------------
IMPLEMENT_FORWARD_XINTERFACE3( ODocumentContainer,ODefinitionContainer,ODocumentContainer_Base,OPropertyStateContainer)
IMPLEMENT_TYPEPROVIDER3(ODocumentContainer,ODefinitionContainer,OPropertyStateContainer,ODocumentContainer_Base);
IMPLEMENT_SERVICE_INFO_IMPLNAME(ODocumentContainer, "com.sun.star.comp.dba.ODocumentContainer");
IMPLEMENT_SERVICE_INFO_SUPPORTS(ODocumentContainer);
IMPLEMENT_PROPERTYCONTAINER_DEFAULTS(ODocumentContainer)
Sequence< ::rtl::OUString > SAL_CALL ODocumentContainer::getSupportedServiceNames( ) throw(RuntimeException)
{
Sequence< ::rtl::OUString > aSupported(1);
aSupported[0] = m_bFormsContainer ? SERVICE_NAME_FORM_COLLECTION : SERVICE_NAME_REPORT_COLLECTION;
return aSupported;
}
// -----------------------------------------------------------------------------
//--------------------------------------------------------------------------
Reference< XContent > ODocumentContainer::createObject( const ::rtl::OUString& _rName)
{
ODefinitionContainer_Impl* pItem = static_cast<ODefinitionContainer_Impl*>(m_pImpl.get());
ODefinitionContainer_Impl::Documents::iterator aFind = pItem->m_aDocumentMap.find(_rName);
OSL_ENSURE( aFind != pItem->m_aDocumentMap.end() ," Invalid entry in map!");
if ( aFind->second->m_aProps.bIsFolder )
return new ODocumentContainer(m_xORB,*this,aFind->second,m_bFormsContainer);
return new ODocumentDefinition(*this, m_xORB,aFind->second,m_bFormsContainer);
}
// -----------------------------------------------------------------------------
Reference< XInterface > SAL_CALL ODocumentContainer::createInstance( const ::rtl::OUString& aServiceSpecifier ) throw (Exception, RuntimeException)
{
return Reference< XInterface >();
}
// -----------------------------------------------------------------------------
Reference< XInterface > SAL_CALL ODocumentContainer::createInstanceWithArguments( const ::rtl::OUString& ServiceSpecifier, const Sequence< Any >& _aArguments ) throw (Exception, RuntimeException)
{
Reference< XInterface > xRet;
Reference< XContent > xContent;
if ( ServiceSpecifier == SERVICE_SDB_DOCUMENTDEFINITION )
{
MutexGuard aGuard(m_aMutex);
::rtl::OUString sName,sPersistentName,sURL;
Reference< XCommandProcessor > xCopyFrom;
Reference<XConnection> xConnection;
Sequence<sal_Int8> aClassID;
sal_Bool bAsTemplate = sal_False;
const Any* pBegin = _aArguments.getConstArray();
const Any* pEnd = pBegin + _aArguments.getLength();
PropertyValue aValue;
for(;pBegin != pEnd;++pBegin)
{
*pBegin >>= aValue;
if ( aValue.Name.equalsAscii(PROPERTY_NAME) )
{
aValue.Value >>= sName;
}
else if ( aValue.Name.equalsAscii(PROPERTY_PERSISTENT_NAME) )
{
aValue.Value >>= sPersistentName;
m_aObjectList.insert(PersistentNames::value_type(sPersistentName,true));
}
else if ( aValue.Name.equalsAscii(PROPERTY_EMBEDDEDOBJECT) )
{
xCopyFrom.set(aValue.Value,UNO_QUERY);
}
else if ( aValue.Name.equalsAscii(PROPERTY_URL) )
{
aValue.Value >>= sURL;
}
else if ( aValue.Name.equalsAscii(PROPERTY_ACTIVECONNECTION) )
{
xConnection.set(aValue.Value,UNO_QUERY);
}
else if ( aValue.Name.equalsAscii("ClassID") )
{
aValue.Value >>= aClassID;
}
else if ( aValue.Name.equalsAscii(PROPERTY_AS_TEMPLATE) )
{
aValue.Value >>= bAsTemplate;
}
}
ODefinitionContainer_Impl* pItem = static_cast<ODefinitionContainer_Impl*>(m_pImpl.get());
sal_Bool bNew;
if ( bNew = (0 == sPersistentName.getLength()) )
{
const static ::rtl::OUString sBaseName(RTL_CONSTASCII_USTRINGPARAM("Obj"));
// -----------------------------------------------------------------------------
sPersistentName = sBaseName;
sPersistentName += ::rtl::OUString::valueOf(sal_Int32(pItem->m_aDocumentMap.size() + 1));
Reference<XNameAccess> xElements(getStorage(),UNO_QUERY);
if ( xElements.is() )
sPersistentName = ::dbtools::createUniqueName(xElements,sPersistentName);
if ( xCopyFrom.is() )
{
Sequence<Any> aIni(2);
aIni[0] <<= getStorage();
aIni[1] <<= sPersistentName;
Command aCommand;
aCommand.Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("copyTo"));
aCommand.Argument <<= aIni;
xCopyFrom->execute(aCommand,-1,Reference< XCommandEnvironment >());
Reference<XPropertySet> xProp(xCopyFrom,UNO_QUERY);
if ( xProp.is() && xProp->getPropertySetInfo().is() && xProp->getPropertySetInfo()->hasPropertyByName(PROPERTY_AS_TEMPLATE) )
xProp->getPropertyValue(PROPERTY_AS_TEMPLATE) >>= bAsTemplate;
}
}
ODefinitionContainer_Impl::Documents::iterator aFind = pItem->m_aDocumentMap.find(sName);
TContentPtr pElementImpl;
if ( bNew || ( aFind == pItem->m_aDocumentMap.end() ) )
{
pElementImpl.reset( new OContentHelper_Impl );
if ( !bNew )
pElementImpl->m_aProps.aTitle = sName;
pElementImpl->m_aProps.sPersistentName = sPersistentName;
pElementImpl->m_aProps.bAsTemplate = bAsTemplate;
pElementImpl->m_pDataSource = m_pImpl->m_pDataSource;
}
else
pElementImpl = aFind->second;
xContent = new ODocumentDefinition(*this, m_xORB,pElementImpl,m_bFormsContainer,aClassID,xConnection);
if ( sURL.getLength() )
{
Sequence<Any> aIni(2);
aIni[0] <<= sURL;
Command aCommand;
aCommand.Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("insert"));
aCommand.Argument <<= aIni;
Reference< XCommandProcessor > xCommandProcessor(xContent,UNO_QUERY);
if ( xContent.is() )
{
xCommandProcessor->execute(aCommand,-1,Reference< XCommandEnvironment >());
}
}
// xRet = xContent;
}
else if ( ServiceSpecifier == SERVICE_NAME_FORM_COLLECTION || SERVICE_NAME_REPORT_COLLECTION == ServiceSpecifier )
{
const Any* pBegin = _aArguments.getConstArray();
const Any* pEnd = pBegin + _aArguments.getLength();
PropertyValue aValue;
::rtl::OUString sName;
Reference<XNameAccess> xCopyFrom;
for(;pBegin != pEnd;++pBegin)
{
*pBegin >>= aValue;
if ( aValue.Name.equalsAscii(PROPERTY_NAME) )
{
aValue.Value >>= sName;
}
else if ( aValue.Name.equalsAscii(PROPERTY_EMBEDDEDOBJECT) )
{
xCopyFrom.set(aValue.Value,UNO_QUERY);
}
}
OSL_ENSURE(sName.getLength(),"Invalid name for a document container!");
ODefinitionContainer_Impl* pItem = static_cast<ODefinitionContainer_Impl*>(m_pImpl.get());
ODefinitionContainer_Impl::Documents::iterator aFind = pItem->m_aDocumentMap.find(sName);
if ( aFind == pItem->m_aDocumentMap.end() )
{
aFind = pItem->m_aDocumentMap.insert(ODefinitionContainer_Impl::Documents::value_type(sName,ODefinitionContainer_Impl::Documents::mapped_type(new ODefinitionContainer_Impl))).first;
aFind->second->m_aProps.aTitle = sName;
aFind->second->m_pDataSource = m_pImpl->m_pDataSource;
}
OSL_ENSURE( aFind != pItem->m_aDocumentMap.end() ," Invalid entry in map!");
xContent = new ODocumentContainer(m_xORB,*this,aFind->second,ServiceSpecifier == SERVICE_NAME_FORM_COLLECTION);
// copy children
if ( xCopyFrom.is() )
{
Sequence< ::rtl::OUString> aSeq = xCopyFrom->getElementNames();
const ::rtl::OUString* pIter = aSeq.getConstArray();
const ::rtl::OUString* pEnd = pIter + aSeq.getLength();
Reference<XContent> xObjectToCopy;
Reference<XMultiServiceFactory> xORB(xContent,UNO_QUERY);
OSL_ENSURE(xORB.is(),"No service factory given");
if ( xORB.is() )
{
for(;pIter != pEnd;++pIter)
{
xCopyFrom->getByName(*pIter) >>= xObjectToCopy;
Sequence< Any > aArguments(3);
PropertyValue aValue;
// set as folder
aValue.Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("Name"));
aValue.Value <<= *pIter;
aArguments[0] <<= aValue;
//parent
aValue.Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("Parent"));
aValue.Value <<= xContent;
aArguments[1] <<= aValue;
aValue.Name = PROPERTY_EMBEDDEDOBJECT;
aValue.Value <<= xObjectToCopy;
aArguments[2] <<= aValue;
::rtl::OUString sServiceName =
(Reference<XNameAccess>(xObjectToCopy,UNO_QUERY).is() ? (m_bFormsContainer ? SERVICE_NAME_FORM_COLLECTION : SERVICE_NAME_REPORT_COLLECTION) : SERVICE_SDB_DOCUMENTDEFINITION);
Reference<XContent > xNew(xORB->createInstanceWithArguments(sServiceName,aArguments),UNO_QUERY);
Reference<XNameContainer> xNameContainer(xContent,UNO_QUERY);
if ( xNameContainer.is() )
xNameContainer->insertByName(*pIter,makeAny(xNew));
}
}
}
}
xRet = xContent;
return xRet;
}
// -----------------------------------------------------------------------------
Sequence< ::rtl::OUString > SAL_CALL ODocumentContainer::getAvailableServiceNames( ) throw (RuntimeException)
{
Sequence< ::rtl::OUString > aSe(3);
aSe[0] = SERVICE_SDB_DOCUMENTDEFINITION;
aSe[1] = SERVICE_NAME_FORM_COLLECTION;
aSe[2] = SERVICE_NAME_REPORT_COLLECTION;
return aSe;
}
// -----------------------------------------------------------------------------
Any SAL_CALL ODocumentContainer::execute( const Command& aCommand, sal_Int32 CommandId, const Reference< XCommandEnvironment >& Environment ) throw (Exception, CommandAbortedException, RuntimeException)
{
Any aRet;
if ( aCommand.Name.compareToAscii( "open" ) == 0 )
{
//////////////////////////////////////////////////////////////////
// open command for a folder content
//////////////////////////////////////////////////////////////////
OpenCommandArgument2 aOpenCommand;
if ( !( aCommand.Argument >>= aOpenCommand ) )
{
OSL_ENSURE( sal_False, "Wrong argument type!" );
ucbhelper::cancelCommandExecution(
makeAny( IllegalArgumentException(
rtl::OUString(),
static_cast< cppu::OWeakObject * >( this ),
-1 ) ),
Environment );
// Unreachable
}
sal_Bool bOpenFolder =
( ( aOpenCommand.Mode == OpenMode::ALL ) ||
( aOpenCommand.Mode == OpenMode::FOLDERS ) ||
( aOpenCommand.Mode == OpenMode::DOCUMENTS ) );
if ( bOpenFolder )
{
// open as folder - return result set
Reference< XDynamicResultSet > xSet
= new DynamicResultSet( m_xORB,
this,
aOpenCommand,
Environment );
aRet <<= xSet;
}
else
{
// Unsupported.
ucbhelper::cancelCommandExecution(
makeAny( UnsupportedOpenModeException(
rtl::OUString(),
static_cast< cppu::OWeakObject * >( this ),
sal_Int16( aOpenCommand.Mode ) ) ),
Environment );
// Unreachable
}
}
else if ( aCommand.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "insert" ) ) )
{
//////////////////////////////////////////////////////////////////
// insert
//////////////////////////////////////////////////////////////////
InsertCommandArgument arg;
if ( !( aCommand.Argument >>= arg ) )
{
OSL_ENSURE( sal_False, "Wrong argument type!" );
ucbhelper::cancelCommandExecution(
makeAny( IllegalArgumentException(
rtl::OUString(),
static_cast< cppu::OWeakObject * >( this ),
-1 ) ),
Environment );
// Unreachable
}
}
else if ( aCommand.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "delete" ) ) )
{
//////////////////////////////////////////////////////////////////
// delete
//////////////////////////////////////////////////////////////////
}
else
aRet = OContentHelper::execute(aCommand,CommandId,Environment);
return aRet;
}
// -----------------------------------------------------------------------------
namespace
{
sal_Bool lcl_queryContent(const ::rtl::OUString& _sName,Reference< XNameContainer >& _xNameContainer,Any& _rRet,::rtl::OUString& _sSimpleName)
{
sal_Bool bRet = sal_False;
sal_Int32 nIndex = 0;
::rtl::OUString sName = _sName.getToken(0,'/',nIndex);
bRet = _xNameContainer->hasByName(sName);
if ( bRet )
{
_rRet = _xNameContainer->getByName(_sSimpleName = sName);
while ( nIndex != -1 )
{
sName = _sName.getToken(0,'/',nIndex);
_xNameContainer.set(_rRet,UNO_QUERY);
if ( bRet = _xNameContainer.is() )
{
bRet = _xNameContainer->hasByName(sName);
_sSimpleName = sName;
if ( bRet )
_rRet = _xNameContainer->getByName(sName);
}
}
}
else if ( nIndex == -1 )
_sSimpleName = sName; // a content on the root content
return bRet;
}
}
// -----------------------------------------------------------------------------
Reference< XComponent > SAL_CALL ODocumentContainer::loadComponentFromURL( const ::rtl::OUString& _sURL
, const ::rtl::OUString& TargetFrameName
, sal_Int32 SearchFlags
, const Sequence< PropertyValue >& Arguments ) throw (IOException, IllegalArgumentException, RuntimeException)
{
MutexGuard aGuard(m_aMutex);
Reference< XComponent > xComp;
try
{
Any aContent;
Reference< XNameContainer > xNameContainer(this);
::rtl::OUString sName;
if ( lcl_queryContent(_sURL,xNameContainer,aContent,sName) )
{
Reference< XCommandProcessor > xContent(aContent,UNO_QUERY);
if ( xContent.is() )
{
Command aCommand;
static const ::rtl::OUString s_sOpenMode = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("OpenMode"));
const PropertyValue* pIter = Arguments.getConstArray();
const PropertyValue* pEnd = pIter + Arguments.getLength();
for( ; pIter != pEnd ; ++pIter)
{
if ( pIter->Name == s_sOpenMode )
{
pIter->Value >>= aCommand.Name;
break;
}
}
if ( !aCommand.Name.getLength() ) // default mode
aCommand.Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("open"));
OpenCommandArgument2 aOpenCommand;
aOpenCommand.Mode = OpenMode::DOCUMENT;
Sequence< PropertyValue > aArguments(Arguments);
sal_Int32 nLen = aArguments.getLength();
aArguments.realloc(nLen + 1);
aArguments[nLen].Value <<= aOpenCommand;
aCommand.Argument <<= aArguments;
xComp.set(xContent->execute(aCommand,xContent->createCommandIdentifier(),Reference< XCommandEnvironment >()),UNO_QUERY);
}
}
else
throw IllegalArgumentException();
}
catch(NoSuchElementException)
{
throw IllegalArgumentException();
}
catch(WrappedTargetException)
{
throw IllegalArgumentException();
}
return xComp;
}
// -----------------------------------------------------------------------------
Any SAL_CALL ODocumentContainer::getByHierarchicalName( const ::rtl::OUString& _sName ) throw (NoSuchElementException, RuntimeException)
{
MutexGuard aGuard(m_aMutex);
Any aContent;
Reference< XNameContainer > xNameContainer(this);
::rtl::OUString sName;
if ( lcl_queryContent(_sName,xNameContainer,aContent,sName) )
return aContent;
throw NoSuchElementException(_sName,*this);
return Any();
}
// -----------------------------------------------------------------------------
sal_Bool SAL_CALL ODocumentContainer::hasByHierarchicalName( const ::rtl::OUString& _sName ) throw (RuntimeException)
{
MutexGuard aGuard(m_aMutex);
Any aContent;
Reference< XNameContainer > xNameContainer(this);
::rtl::OUString sName;
return lcl_queryContent(_sName,xNameContainer,aContent,sName);
}
// -----------------------------------------------------------------------------
// XHierarchicalNameContainer
void SAL_CALL ODocumentContainer::insertByHierarchicalName( const ::rtl::OUString& _sName, const Any& _aElement ) throw (IllegalArgumentException, ElementExistException, WrappedTargetException, RuntimeException)
{
ClearableMutexGuard aGuard(m_aMutex);
Any aContent;
Reference< XNameContainer > xNameContainer(this);
::rtl::OUString sName;
if ( lcl_queryContent(_sName,xNameContainer,aContent,sName) )
throw ElementExistException(_sName,*this);
Reference< XContent > xContent(_aElement,UNO_QUERY);
if ( !xContent.is() )
throw IllegalArgumentException();
xNameContainer->insertByName(sName,_aElement);
}
// -----------------------------------------------------------------------------
void SAL_CALL ODocumentContainer::removeByHierarchicalName( const ::rtl::OUString& _sName ) throw (NoSuchElementException, WrappedTargetException, RuntimeException)
{
if ( !_sName.getLength() )
throw NoSuchElementException(_sName,*this);
ClearableMutexGuard aGuard(m_aMutex);
Any aContent;
::rtl::OUString sName;
Reference< XNameContainer > xNameContainer(this);
if ( !lcl_queryContent(_sName,xNameContainer,aContent,sName) )
throw NoSuchElementException(_sName,*this);
xNameContainer->removeByName(sName);
}
// -----------------------------------------------------------------------------
// XHierarchicalNameReplace
void SAL_CALL ODocumentContainer::replaceByHierarchicalName( const ::rtl::OUString& _sName, const Any& _aElement ) throw (IllegalArgumentException, NoSuchElementException, WrappedTargetException, RuntimeException)
{
Reference< XContent > xContent(_aElement,UNO_QUERY);
if ( !xContent.is() )
throw IllegalArgumentException();
ClearableMutexGuard aGuard(m_aMutex);
Any aContent;
::rtl::OUString sName;
Reference< XNameContainer > xNameContainer(this);
if ( !lcl_queryContent(_sName,xNameContainer,aContent,sName) )
throw NoSuchElementException(_sName,*this);
xNameContainer->replaceByName(sName,_aElement);
}
// -----------------------------------------------------------------------------
::rtl::Reference<OContentHelper> ODocumentContainer::getContent(const ::rtl::OUString& _sName) const
{
::rtl::Reference<OContentHelper> pContent = NULL;
try
{
Reference<XUnoTunnel> xUnoTunnel(const_cast<ODocumentContainer*>(this)->implGetByName(_sName),UNO_QUERY);
if ( xUnoTunnel.is() )
pContent = reinterpret_cast<OContentHelper*>(xUnoTunnel->getSomething(OContentHelper::getUnoTunnelImplementationId()));
}
catch(Exception)
{
}
return pContent;
}
// -----------------------------------------------------------------------------
Any ODocumentContainer::getPropertyDefaultByHandle( sal_Int32 _nHandle ) const
{
return Any();
}
// -----------------------------------------------------------------------------
void SAL_CALL ODocumentContainer::commit( ) throw (::com::sun::star::io::IOException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException)
{
MutexGuard aGuard(m_aMutex);
Documents::iterator aIter = m_aDocumentMap.begin();
Documents::iterator aEnd = m_aDocumentMap.end();
for (; aIter != aEnd ; ++aIter)
{
Reference<XTransactedObject> xTrans(aIter->second.get(),UNO_QUERY);
if ( xTrans.is() )
xTrans->commit();
}
Reference<XTransactedObject> xTrans(getStorage(),UNO_QUERY);
if ( xTrans.is() )
xTrans->commit();
}
// -----------------------------------------------------------------------------
void SAL_CALL ODocumentContainer::revert( ) throw (::com::sun::star::io::IOException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException)
{
MutexGuard aGuard(m_aMutex);
Documents::iterator aIter = m_aDocumentMap.begin();
Documents::iterator aEnd = m_aDocumentMap.end();
for (; aIter != aEnd ; ++aIter)
{
Reference<XTransactedObject> xTrans(aIter->second.get(),UNO_QUERY);
if ( xTrans.is() )
xTrans->revert();
}
Reference<XTransactedObject> xTrans(getStorage(),UNO_QUERY);
if ( xTrans.is() )
xTrans->revert();
}
// -----------------------------------------------------------------------------
Reference< XStorage> ODocumentContainer::getStorage() const
{
static const ::rtl::OUString s_sForms = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("forms"));
static const ::rtl::OUString s_sReports = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("reports"));
return m_pImpl->m_pDataSource
? m_pImpl->m_pDataSource->getStorage( m_bFormsContainer ? s_sForms : s_sReports )
: Reference< XStorage>();
}
// -----------------------------------------------------------------------------
sal_Bool ODocumentContainer::approveNewObject(const ::rtl::OUString& _sName,const Reference< XContent >& _rxObject) const
{
return (_sName.indexOf('/',0) == -1) && ODefinitionContainer::approveNewObject(_sName,_rxObject);
}
// -----------------------------------------------------------------------------
void SAL_CALL ODocumentContainer::removeByName( const ::rtl::OUString& _rName ) throw(NoSuchElementException, WrappedTargetException, RuntimeException)
{
Reference< XContent > xOldElement;
ClearableMutexGuard aGuard(m_aMutex);
{
// check the arguments
if (!_rName.getLength())
throw IllegalArgumentException();
if (!checkExistence(_rName))
throw NoSuchElementException(_rName,*this);
Reference< XCommandProcessor > xContent(implGetByName(_rName),UNO_QUERY);
if ( xContent.is() )
{
Command aCommand;
aCommand.Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("delete"));
xContent->execute(aCommand,xContent->createCommandIdentifier(),Reference< XCommandEnvironment >());
}
// do the removal
implRemove(_rName);
// disposeComponent(xOldElement); // no dispose here, the object amy be inserted again unde a different name
}
notifyByName(aGuard,_rName,NULL,NULL,E_REMOVED);
}
//........................................................................
} // namespace dbaccess
//........................................................................