/* -*- 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. * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_desktop.hxx" #include #include #include #include #include #include #include "splash.hxx" using namespace ::com::sun::star::uno; using namespace ::com::sun::star::lang; using namespace ::com::sun::star::beans; using namespace ::com::sun::star::registry; using namespace ::desktop; using ::rtl::OUString; static const char* pServices[] = { SplashScreen::serviceName, NULL }; static const char* pImplementations[] = { SplashScreen::implementationName, NULL }; typedef Reference(* fProvider)(const Reference&); static const fProvider pInstanceProviders[] = { SplashScreen::getInstance, NULL }; static const char** pSupportedServices[] = { SplashScreen::interfaces, NULL }; static Sequence getSupportedServiceNames(int p) { const char **names = pSupportedServices[p]; Sequence aSeq; for(int i = 0; names[i] != NULL; i++) { aSeq.realloc(i+1); aSeq[i] = OUString::createFromAscii(names[i]); } return aSeq; } extern "C" { void SAL_CALL component_getImplementationEnvironment( const sal_Char** ppEnvironmentTypeName, uno_Environment**) { *ppEnvironmentTypeName = CPPU_CURRENT_LANGUAGE_BINDING_NAME ; } void* SAL_CALL component_getFactory( const sal_Char* pImplementationName, void* pServiceManager, void*) { // Set default return value for this operation - if it failed. if ( pImplementationName && pServiceManager ) { Reference< XSingleServiceFactory > xFactory; Reference< XMultiServiceFactory > xServiceManager( reinterpret_cast< XMultiServiceFactory* >( pServiceManager ) ) ; // search implementation for (int i = 0; (pImplementations[i]!=NULL); i++) { if ( strcmp(pImplementations[i], pImplementationName ) == 0 ) { // found implementation xFactory = Reference(cppu::createSingleFactory( xServiceManager, OUString::createFromAscii(pImplementationName), pInstanceProviders[i], getSupportedServiceNames(i))); if ( xFactory.is() ) { // Factory is valid - service was found. xFactory->acquire(); return xFactory.get(); } } } // for() } // Return with result of this operation. return NULL; } } // extern "C" /* vim:set shiftwidth=4 softtabstop=4 expandtab: */