169 lines
6.5 KiB
C++
169 lines
6.5 KiB
C++
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
/*************************************************************************
|
|
*
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
*
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
|
*
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
|
*
|
|
* 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.
|
|
*
|
|
************************************************************************/
|
|
|
|
#include <string.h>
|
|
|
|
#include <usr/reflserv.hxx> // for EXTERN_SERVICE_CALLTYPE
|
|
|
|
#include <usr/factoryhlp.hxx>
|
|
#include "testfactreg.hxx"
|
|
|
|
|
|
using namespace usr;
|
|
|
|
#ifdef __cplusplus
|
|
extern "C"
|
|
{
|
|
#endif
|
|
|
|
BOOL EXTERN_SERVICE_CALLTYPE exService_writeRegEntry(
|
|
const UNO_INTERFACE(XRegistryKey)* xUnoKey)
|
|
|
|
{
|
|
XRegistryKeyRef xKey;
|
|
uno2smart(xKey, *xUnoKey);
|
|
|
|
UString str = UString( L"/" ) + OPipeTest_getImplementationName() + UString( L"/UNO/SERVICES" );
|
|
XRegistryKeyRef xNewKey = xKey->createKey( str );
|
|
xNewKey->createKey( OPipeTest_getServiceName() );
|
|
|
|
str = UString( L"/" ) + ODataStreamTest_getImplementationName(1) + UString( L"/UNO/SERVICES" );
|
|
xNewKey = xKey->createKey( str );
|
|
xNewKey->createKey( ODataStreamTest_getServiceName(1) );
|
|
|
|
str = UString( L"/" ) + ODataStreamTest_getImplementationName(2) + UString( L"/UNO/SERVICES" );
|
|
xNewKey = xKey->createKey( str );
|
|
xNewKey->createKey( ODataStreamTest_getServiceName(2) );
|
|
|
|
str = UString( L"/" ) + OObjectStreamTest_getImplementationName(1) + UString( L"/UNO/SERVICES" );
|
|
xNewKey = xKey->createKey( str );
|
|
xNewKey->createKey( OObjectStreamTest_getServiceName(1) );
|
|
|
|
str = UString( L"/" ) + OObjectStreamTest_getImplementationName(2) + UString( L"/UNO/SERVICES" );
|
|
xNewKey = xKey->createKey( str );
|
|
xNewKey->createKey( OObjectStreamTest_getServiceName(2) );
|
|
|
|
str = UString( L"/" ) + OMarkableOutputStreamTest_getImplementationName() + UString( L"/UNO/SERVICES" );
|
|
xNewKey = xKey->createKey( str );
|
|
xNewKey->createKey( OMarkableOutputStreamTest_getServiceName() );
|
|
|
|
str = UString( L"/" ) + OMarkableInputStreamTest_getImplementationName() + UString( L"/UNO/SERVICES" );
|
|
xNewKey = xKey->createKey( str );
|
|
xNewKey->createKey( OMarkableInputStreamTest_getServiceName() );
|
|
|
|
str = UString( L"/" ) + OMyPersistObject_getImplementationName() + UString( L"/UNO/SERVICES" );
|
|
xNewKey = xKey->createKey( str );
|
|
xNewKey->createKey( OMyPersistObject_getServiceName() );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
UNO_INTERFACE(XInterface) EXTERN_SERVICE_CALLTYPE exService_getFactory
|
|
(
|
|
const wchar_t* implementationName,
|
|
const UNO_INTERFACE(XMultiServiceFactory)* xUnoFact,
|
|
const UNO_INTERFACE(XRegistryKey)*
|
|
)
|
|
{
|
|
UNO_INTERFACE(XInterface) xUnoRet = {0, 0};
|
|
|
|
XInterfaceRef xRet;
|
|
XMultiServiceFactoryRef xSMgr;
|
|
UString aImplementationName(implementationName);
|
|
|
|
uno2smart(xSMgr, *xUnoFact);
|
|
|
|
if (aImplementationName == OPipeTest_getImplementationName() )
|
|
{
|
|
xRet = createSingleFactory( xSMgr, implementationName,
|
|
OPipeTest_CreateInstance,
|
|
OPipeTest_getSupportedServiceNames() );
|
|
}
|
|
else if( aImplementationName == ODataStreamTest_getImplementationName(1) ) {
|
|
xRet = createSingleFactory( xSMgr , implementationName,
|
|
ODataStreamTest_CreateInstance,
|
|
ODataStreamTest_getSupportedServiceNames(1) );
|
|
}
|
|
else if( aImplementationName == ODataStreamTest_getImplementationName(2) ) {
|
|
xRet = createSingleFactory( xSMgr , implementationName,
|
|
ODataStreamTest_CreateInstance,
|
|
ODataStreamTest_getSupportedServiceNames(2) );
|
|
}
|
|
else if( aImplementationName == OObjectStreamTest_getImplementationName(1) ) {
|
|
xRet = createSingleFactory( xSMgr , implementationName,
|
|
OObjectStreamTest_CreateInstance,
|
|
OObjectStreamTest_getSupportedServiceNames(1) );
|
|
}
|
|
else if( aImplementationName == OObjectStreamTest_getImplementationName(2) ) {
|
|
xRet = createSingleFactory( xSMgr , implementationName,
|
|
OObjectStreamTest_CreateInstance,
|
|
OObjectStreamTest_getSupportedServiceNames(2) );
|
|
}
|
|
else if( aImplementationName == OMarkableOutputStreamTest_getImplementationName() ) {
|
|
xRet = createSingleFactory( xSMgr , implementationName,
|
|
OMarkableOutputStreamTest_CreateInstance,
|
|
OMarkableOutputStreamTest_getSupportedServiceNames() );
|
|
}
|
|
else if( aImplementationName == OMarkableInputStreamTest_getImplementationName() ) {
|
|
xRet = createSingleFactory( xSMgr , implementationName,
|
|
OMarkableInputStreamTest_CreateInstance,
|
|
OMarkableInputStreamTest_getSupportedServiceNames() );
|
|
}
|
|
else if( aImplementationName == OMyPersistObject_getImplementationName() ) {
|
|
xRet = createSingleFactory( xSMgr , implementationName,
|
|
OMyPersistObject_CreateInstance,
|
|
OMyPersistObject_getSupportedServiceNames() );
|
|
}
|
|
if (xRet.is())
|
|
{
|
|
smart2uno(xRet, xUnoRet);
|
|
}
|
|
|
|
return xUnoRet;
|
|
}
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
Sequence<BYTE> createSeq( char * p )
|
|
{
|
|
Sequence<BYTE> seq( strlen( p )+1 );
|
|
strcpy( (char * ) seq.getArray() , p );
|
|
return seq;
|
|
}
|
|
|
|
Sequence<BYTE> createIntSeq( INT32 i )
|
|
{
|
|
char pcCount[20];
|
|
sprintf( pcCount , "%d" , i );
|
|
return createSeq( pcCount );
|
|
}
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|