/************************************************************************* * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: samplelib1.cxx,v $ * * $Revision: 1.4 $ * * last change: $Author: obo $ $Date: 2006-09-17 09:07:43 $ * * 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_sal.hxx" #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace ::com::sun::star::registry; using namespace ::com::sun::star::uno; using namespace ::com::sun::star::lang; using namespace ::rtl; using namespace ::cppu; #define IMPLNAME1 "com.sun.star.comp.sal.UnloadingTest1" #define SERVICENAME1 "com.sun.star.UnloadingTest1" #define IMPLNAME2 "com.sun.star.comp.sal.UnloadingTest2" #define SERVICENAME2 "com.sun.star.UnloadingTest2" #define IMPLNAME3 "com.sun.star.comp.sal.UnloadingTest3" #define SERVICENAME3 "com.sun.star.UnloadingTest3" #define IMPLNAME4 "com.sun.star.comp.sal.OneInstanceTest" #define SERVICENAME4 "com.sun.star.OneInstanceTest" // Unloading Support ---------------------------------------------- rtl_StandardModuleCount globalModuleCount= MODULE_COUNT_INIT; //rtl_StandardModuleCount globalModuleCount= { {rtl_moduleCount_acquire,rtl_moduleCount_release}, rtl_moduleCount_canUnload,0,{0,0}}; //, 0, {0, 0}}; // Services ------------------------------------------------------- class TestService: public WeakImplHelper1 { OUString m_implName; OUString m_serviceName; public: TestService( OUString implName, OUString serviceName); ~TestService(); virtual OUString SAL_CALL getImplementationName( ) throw (RuntimeException); virtual sal_Bool SAL_CALL supportsService( const OUString& ServiceName ) throw (RuntimeException); virtual Sequence SAL_CALL getSupportedServiceNames( ) throw (RuntimeException); }; TestService::TestService( OUString implName, OUString serviceName): m_implName(implName),m_serviceName(serviceName) { // Library unloading support globalModuleCount.modCnt.acquire( &globalModuleCount.modCnt); } TestService::~TestService() { // Library unloading support globalModuleCount.modCnt.release( &globalModuleCount.modCnt); } OUString SAL_CALL TestService::getImplementationName( ) throw (RuntimeException) { return m_implName; } sal_Bool SAL_CALL TestService::supportsService( const OUString& ServiceName ) throw (RuntimeException) { return ServiceName.equals( m_serviceName); } Sequence SAL_CALL TestService::getSupportedServiceNames( ) throw (RuntimeException) { return Sequence( &m_serviceName, 1); } // Creator functions for Services ------------------------------------------------- static Reference SAL_CALL test1_createInstance(const Reference & rSMgr) throw (RuntimeException) { return Reference( static_cast( new TestService( OUString( RTL_CONSTASCII_USTRINGPARAM( IMPLNAME1)), OUString( RTL_CONSTASCII_USTRINGPARAM( SERVICENAME1)) )), UNO_QUERY); } static Reference SAL_CALL test2_createInstance(const Reference & rSMgr) throw (RuntimeException) { return Reference( static_cast( new TestService( OUString( RTL_CONSTASCII_USTRINGPARAM( IMPLNAME2)), OUString( RTL_CONSTASCII_USTRINGPARAM( SERVICENAME2)) )), UNO_QUERY); } static Reference SAL_CALL test3_createInstance(const Reference & rSMgr) throw (RuntimeException) { return Reference( static_cast( new TestService( OUString( RTL_CONSTASCII_USTRINGPARAM( IMPLNAME3)), OUString( RTL_CONSTASCII_USTRINGPARAM( SERVICENAME3)) )), UNO_QUERY); } static Reference SAL_CALL test4_createInstance(const Reference & rSMgr) throw (RuntimeException) { return Reference( static_cast( new TestService( OUString( RTL_CONSTASCII_USTRINGPARAM( IMPLNAME4)), OUString( RTL_CONSTASCII_USTRINGPARAM( SERVICENAME4)) )), UNO_QUERY); } // Standard UNO library interface ------------------------------------------------- extern "C" { void SAL_CALL component_getImplementationEnvironment(const sal_Char ** ppEnvTypeName, uno_Environment ** ppEnv){ *ppEnvTypeName = CPPU_CURRENT_LANGUAGE_BINDING_NAME; } sal_Bool SAL_CALL component_writeInfo(void * pServiceManager, void * pRegistryKey) throw() { if (pRegistryKey) { try { Reference< XRegistryKey > xNewKey( reinterpret_cast< XRegistryKey * >( pRegistryKey )->createKey( OUString::createFromAscii( "/" IMPLNAME1 "/UNO/SERVICES" ) ) ); xNewKey->createKey( OUString( RTL_CONSTASCII_USTRINGPARAM( SERVICENAME1))); xNewKey= reinterpret_cast< XRegistryKey * >( pRegistryKey )->createKey( OUString::createFromAscii( "/" IMPLNAME2 "/UNO/SERVICES" ) ); xNewKey->createKey(OUString( RTL_CONSTASCII_USTRINGPARAM( SERVICENAME2))); xNewKey= reinterpret_cast< XRegistryKey * >( pRegistryKey )->createKey( OUString::createFromAscii( "/" IMPLNAME3 "/UNO/SERVICES" ) ); xNewKey->createKey(OUString( RTL_CONSTASCII_USTRINGPARAM( SERVICENAME3))); xNewKey= reinterpret_cast< XRegistryKey * >( pRegistryKey )->createKey( OUString::createFromAscii( "/" IMPLNAME4 "/UNO/SERVICES" ) ); xNewKey->createKey(OUString( RTL_CONSTASCII_USTRINGPARAM( SERVICENAME4))); return sal_True; } catch (InvalidRegistryException &) { OSL_ENSURE( sal_False, "### InvalidRegistryException!" ); } } return sal_False; } void * SAL_CALL component_getFactory(const sal_Char * pImplName, void * pServiceManager, void * pRegistryKey) throw() { void * pRet = 0; OUString implname1( RTL_CONSTASCII_USTRINGPARAM( IMPLNAME1) ); OUString serviceName1( RTL_CONSTASCII_USTRINGPARAM( SERVICENAME1) ); OUString implname2( RTL_CONSTASCII_USTRINGPARAM( IMPLNAME2) ); OUString serviceName2( RTL_CONSTASCII_USTRINGPARAM( SERVICENAME2) ); OUString implname3( RTL_CONSTASCII_USTRINGPARAM( IMPLNAME3) ); OUString serviceName3( RTL_CONSTASCII_USTRINGPARAM( SERVICENAME3) ); OUString implname4( RTL_CONSTASCII_USTRINGPARAM( IMPLNAME4) ); OUString serviceName4( RTL_CONSTASCII_USTRINGPARAM( SERVICENAME4) ); if (implname1.equals( OUString::createFromAscii(pImplName))) { Reference mgr= reinterpret_cast(pServiceManager); Reference xFactory( createSingleFactory( reinterpret_cast(pServiceManager), implname1, test1_createInstance, Sequence( &serviceName1, 1), &globalModuleCount.modCnt )); if (xFactory.is()) { xFactory->acquire(); pRet = xFactory.get(); } } else if( implname2.equals( OUString::createFromAscii(pImplName))) { Reference mgr= reinterpret_cast(pServiceManager); Reference xFactory( createSingleFactory( reinterpret_cast(pServiceManager), implname2, test2_createInstance, Sequence( &serviceName2, 1), &globalModuleCount.modCnt )); if (xFactory.is()) { xFactory->acquire(); pRet = xFactory.get(); } } else if( implname3.equals( OUString::createFromAscii(pImplName))) { Reference mgr= reinterpret_cast(pServiceManager); Reference xFactory( createSingleFactory( reinterpret_cast(pServiceManager), implname3, test3_createInstance, Sequence( &serviceName3, 1), &globalModuleCount.modCnt )); if (xFactory.is()) { xFactory->acquire(); pRet = xFactory.get(); } } else if( implname4.equals( OUString::createFromAscii(pImplName))) { Reference mgr= reinterpret_cast(pServiceManager); Reference xFactory( createOneInstanceFactory( reinterpret_cast(pServiceManager), implname3, test4_createInstance, Sequence( &serviceName3, 1), &globalModuleCount.modCnt )); if (xFactory.is()) { xFactory->acquire(); pRet = xFactory.get(); } } return pRet; } sal_Bool component_canUnload( TimeValue* libUnused) { return globalModuleCount.canUnload( &globalModuleCount, libUnused); } }