/* -*- 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 * * for a copy of the LGPLv3 License. * ************************************************************************/ #include #include using namespace ::rtl; using namespace ::com::sun::star::uno; using namespace ::com::sun::star::lang; using namespace ::com::sun::star::registry; namespace cppu { sal_Bool component_writeInfoHelper( void *, void *pRegistryKey , const struct ImplementationEntry entries[] ) { sal_Bool bRet = sal_False; try { if( pRegistryKey ) { for( sal_Int32 i = 0; entries[i].create ; i ++ ) { OUStringBuffer buf( 124 ); buf.appendAscii( RTL_CONSTASCII_STRINGPARAM("/") ); buf.append( entries[i].getImplementationName() ); buf.appendAscii(RTL_CONSTASCII_STRINGPARAM( "/UNO/SERVICES" ) ); Reference< XRegistryKey > xNewKey( reinterpret_cast< XRegistryKey * >( pRegistryKey )->createKey( buf.makeStringAndClear() ) ); Sequence< OUString > seq = entries[i].getSupportedServiceNames(); const OUString *pArray = seq.getConstArray(); for ( sal_Int32 nPos = 0 ; nPos < seq.getLength(); nPos ++ ) xNewKey->createKey( pArray[nPos] ); } bRet = sal_True; } } catch ( InvalidRegistryException & ) { OSL_FAIL( "### InvalidRegistryException!" ); } return bRet; } void * component_getFactoryHelper( const sal_Char * pImplName, void *, void *, const struct ImplementationEntry entries[] ) { void * pRet = 0; Reference< XSingleComponentFactory > xFactory; for( sal_Int32 i = 0 ; entries[i].create ; i ++ ) { OUString implName = entries[i].getImplementationName(); if( 0 == implName.compareToAscii( pImplName ) ) { xFactory = entries[i].createFactory( entries[i].create, implName, entries[i].getSupportedServiceNames(), entries[i].moduleCounter ); } } if( xFactory.is() ) { xFactory->acquire(); pRet = xFactory.get(); } return pRet; } } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */