Files
libreoffice/connectivity/source/drivers/mozab/MConfigAccess.cxx
Oliver Bolte 76efb61e76 INTEGRATION: CWS pchfix02 (1.7.94); FILE MERGED
2006/09/01 17:22:26 kaib 1.7.94.1: #i68856# Added header markers and pch files
2006-09-17 01:55:53 +00:00

267 lines
11 KiB
C++

/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: MConfigAccess.cxx,v $
*
* $Revision: 1.8 $
*
* last change: $Author: obo $ $Date: 2006-09-17 02:55:53 $
*
* 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
*
************************************************************************/
// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_connectivity.hxx"
#ifndef CONNECTIVITY_MOZAB_MCONFIGACCESS_HXX
#include "MConfigAccess.hxx"
#endif
#ifndef CONNECTIVITY_MOZAB_MEXTCONFIGACCESS_HXX
#include "MExtConfigAccess.hxx"
#endif
#ifndef CONNECTIVITY_SCONNECTION_HXX
#include "MConnection.hxx"
#endif
using namespace ::com::sun::star::uno;
using namespace ::com::sun::star::lang;
using namespace ::com::sun::star::beans;
//.........................................................................
namespace connectivity
{
namespace mozab
{
//-----------------------------------------------------------------
Reference< XPropertySet > createDriverConfigNode( Reference< XMultiServiceFactory > _rxORB )
{
Reference< XPropertySet > xNode;
try
{
//=============================================================
// create the config provider
Reference< XMultiServiceFactory > xConfigProvider(
_rxORB->createInstance( ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("com.sun.star.configuration.ConfigurationProvider" )) ),
UNO_QUERY
);
OSL_ENSURE( xConfigProvider.is(), "createDriverConfigNode: could not create the config provider!" );
if ( xConfigProvider.is() )
{
::rtl::OUString sCompleteNodePath = ::rtl::OUString::createFromAscii ("/org.openoffice.Office.DataAccess/DriverSettings/" );
sCompleteNodePath += OConnection::getDriverImplementationName();
//=========================================================
// arguments for creating the config access
Sequence< Any > aArguments(2);
// the path to the node to open
aArguments[0] <<= PropertyValue(
::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("nodepath")),
0,
makeAny( sCompleteNodePath ),
PropertyState_DIRECT_VALUE
);
// the depth: -1 means unlimited
aArguments[1] <<= PropertyValue(
::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("depth")),
0,
makeAny( (sal_Int32)-1 ),
PropertyState_DIRECT_VALUE
);
//=========================================================
// create the access
Reference< XInterface > xAccess = xConfigProvider->createInstanceWithArguments(
::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("com.sun.star.configuration.ConfigurationAccess" )),
aArguments
);
OSL_ENSURE( xAccess.is(), "createDriverConfigNode: invalid access returned (should throw an exception instead)!" );
xNode = xNode.query( xAccess );
}
}
catch( const Exception& )
{
OSL_ENSURE( sal_False, "createDriverConfigNode: caught an exception while accessing the driver's config node!" );
}
// outta here
return xNode;
}
//-----------------------------------------------------------------
namespace
{
// a private helper to accessing the point where we store the reference
// to the factory
Reference< XMultiServiceFactory >& accessFactoryStorage( )
{
static Reference< XMultiServiceFactory > xMozabServiceFactory;
return xMozabServiceFactory;
}
}
//-----------------------------------------------------------------
void setMozabServiceFactory( const Reference< XMultiServiceFactory >& _rxFactory )
{
accessFactoryStorage( ) = _rxFactory;
}
//-----------------------------------------------------------------
const Reference< XMultiServiceFactory >& getMozabServiceFactory( )
{
return accessFactoryStorage( );
}
//-----------------------------------------------------------------
::rtl::OUString getDescription(const sal_Char* sNode,const ::rtl::OUString & sDefault)
{
::rtl::OUString sPreferredName;
::rtl::OUString sDescription;
Reference< XMultiServiceFactory > xFactory = getMozabServiceFactory();
OSL_ENSURE( xFactory.is(), "getPreferredProfileName: invalid service factory!" );
if ( xFactory.is() )
{
try
{
Reference< XPropertySet > xDriverNode = createDriverConfigNode( xFactory );
Reference< XPropertySet > xMozPrefsNode;
if ( xDriverNode.is() )
xDriverNode->getPropertyValue( ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("MozillaPreferences" )) ) >>= xMozPrefsNode;
OSL_ENSURE( xMozPrefsNode.is(), "getPreferredProfileName: could not access the node for the mozilla preferences!" );
if ( xMozPrefsNode.is() )
xMozPrefsNode->getPropertyValue( ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("ProfileName" )) ) >>= sPreferredName;
if ( xMozPrefsNode.is() )
xMozPrefsNode->getPropertyValue( ::rtl::OUString::createFromAscii(sNode) ) >>= sDescription;
if (sDescription.getLength() == 0)
sDescription = sDefault;
}
catch( const Exception& )
{
OSL_ENSURE( sal_False, "getDescription: caught an exception!" );
}
}
if (sDescription.getLength() == 0)
sDescription = sDefault;
return sDescription;
}
//-----------------------------------------------------------------
::rtl::OUString getPreferredProfileName( )
{
::rtl::OUString sPreferredName;
Reference< XMultiServiceFactory > xFactory = getMozabServiceFactory();
OSL_ENSURE( xFactory.is(), "getPreferredProfileName: invalid service factory!" );
if ( xFactory.is() )
{
try
{
Reference< XPropertySet > xDriverNode = createDriverConfigNode( xFactory );
Reference< XPropertySet > xMozPrefsNode;
if ( xDriverNode.is() )
xDriverNode->getPropertyValue( ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("MozillaPreferences" )) ) >>= xMozPrefsNode;
OSL_ENSURE( xMozPrefsNode.is(), "getPreferredProfileName: could not access the node for the mozilla preferences!" );
if ( xMozPrefsNode.is() )
xMozPrefsNode->getPropertyValue( ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("ProfileName" )) ) >>= sPreferredName;
}
catch( const Exception& )
{
OSL_ENSURE( sal_False, "getPreferredProfileName: caught an exception!" );
}
}
return sPreferredName;
}
}
}
//.........................................................................
//-------------------------------------------------------------------------
extern "C" const sal_Unicode* SAL_CALL getUserProfile( void )
{
static sal_Bool bReadConfig = sal_False;
static ::rtl::OUString sUserProfile;
if ( !bReadConfig )
{
sUserProfile = ::connectivity::mozab::getPreferredProfileName( );
bReadConfig = sal_True;
}
return sUserProfile.getStr();
}
//------------------------------------------------------------------------
extern "C" const sal_Char* SAL_CALL getPabDescription( void )
{
static sal_Bool bReadConfig = sal_False;
static ::rtl::OUString usPabDescription;
static ::rtl::OString sPabDescription;
if ( !bReadConfig )
{
usPabDescription = ::connectivity::mozab::getDescription(
"PabDescription" ,
::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("Personal Address Book" )));
sPabDescription = ::rtl::OUStringToOString( usPabDescription,
RTL_TEXTENCODING_UTF8);
bReadConfig = sal_True;
}
return sPabDescription.getStr();
}
//-------------------------------------------------------------------------
extern "C" const sal_Char* SAL_CALL getHisDescription( void )
{
static sal_Bool bReadConfig = sal_False;
static ::rtl::OUString usHisDescription;
static ::rtl::OString sHisDescription;
if ( !bReadConfig )
{
usHisDescription = ::connectivity::mozab::getDescription(
"HisDescription" ,
::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("Collected Addresses" )));
sHisDescription = ::rtl::OUStringToOString( usHisDescription,
RTL_TEXTENCODING_UTF8);
bReadConfig = sal_True;
}
return sHisDescription.getStr();
}
//-------------------------------------------------------------------------
extern "C" void SAL_CALL setMozabServiceFactory( void* _pFactory )
{
Reference< XMultiServiceFactory > xFactory = static_cast< XMultiServiceFactory* >( _pFactory );
::connectivity::mozab::setMozabServiceFactory( xFactory );
// by definition, the object behind the interface pointer has been acquired once for purpose
// of safely transporting it
xFactory->release();
}