summaryrefslogtreecommitdiff
path: root/svl/source/uno/registerservices.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'svl/source/uno/registerservices.cxx')
-rw-r--r--svl/source/uno/registerservices.cxx154
1 files changed, 154 insertions, 0 deletions
diff --git a/svl/source/uno/registerservices.cxx b/svl/source/uno/registerservices.cxx
new file mode 100644
index 000000000000..39be9e177fea
--- /dev/null
+++ b/svl/source/uno/registerservices.cxx
@@ -0,0 +1,154 @@
+/*************************************************************************
+ *
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * Copyright 2008 by Sun Microsystems, Inc.
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * $RCSfile: registerservices.cxx,v $
+ * $Revision: 1.21 $
+ *
+ * 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.
+ *
+ ************************************************************************/
+
+// MARKER(update_precomp.py): autogen include statement, do not remove
+#include "precompiled_svl.hxx"
+#include "sal/types.h"
+#include "rtl/ustring.hxx"
+#include <cppuhelper/factory.hxx>
+#include <com/sun/star/lang/XSingleServiceFactory.hpp>
+#include <com/sun/star/lang/XMultiServiceFactory.hpp>
+#include <com/sun/star/registry/XRegistryKey.hpp>
+#include <svl/svldllapi.h>
+
+namespace css = com::sun::star;
+using css::uno::Reference;
+using css::uno::Sequence;
+using rtl::OUString;
+
+// -------------------------------------------------------------------------------------
+
+#define DECLARE_CREATEINSTANCE( ImplName ) \
+ Reference< css::uno::XInterface > SAL_CALL ImplName##_CreateInstance( const Reference< css::lang::XMultiServiceFactory >& );
+
+DECLARE_CREATEINSTANCE( SvNumberFormatterServiceObj )
+DECLARE_CREATEINSTANCE( SvNumberFormatsSupplierServiceObject )
+DECLARE_CREATEINSTANCE( PathService )
+
+// -------------------------------------------------------------------------------------
+
+extern "C"
+{
+
+SVL_DLLPUBLIC void SAL_CALL component_getImplementationEnvironment (
+ const sal_Char ** ppEnvTypeName, uno_Environment ** /* ppEnv */)
+{
+ *ppEnvTypeName = CPPU_CURRENT_LANGUAGE_BINDING_NAME;
+}
+
+SVL_DLLPUBLIC sal_Bool SAL_CALL component_writeInfo (
+ void * /* _pServiceManager */, void * _pRegistryKey)
+{
+ if (_pRegistryKey)
+ {
+ Reference< css::registry::XRegistryKey > xRegistryKey (
+ reinterpret_cast< css::registry::XRegistryKey* >(_pRegistryKey));
+ Reference< css::registry::XRegistryKey > xNewKey;
+
+ xNewKey = xRegistryKey->createKey (
+ OUString::createFromAscii(
+ "/com.sun.star.uno.util.numbers.SvNumberFormatsSupplierServiceObject/UNO/SERVICES" ) );
+ xNewKey->createKey (
+ OUString::createFromAscii( "com.sun.star.util.NumberFormatsSupplier" ) );
+
+ xNewKey = xRegistryKey->createKey (
+ OUString::createFromAscii(
+ "/com.sun.star.uno.util.numbers.SvNumberFormatterServiceObject/UNO/SERVICES" ) );
+ xNewKey->createKey (
+ OUString::createFromAscii( "com.sun.star.util.NumberFormatter" ) );
+
+ xNewKey = xRegistryKey->createKey(
+ OUString::createFromAscii( "/com.sun.star.comp.svl.PathService/UNO/SERVICES" ) );
+ xNewKey->createKey (
+ OUString::createFromAscii( "com.sun.star.config.SpecialConfigManager" ) );
+
+ return sal_True;
+ }
+ return sal_False;
+}
+
+SVL_DLLPUBLIC void* SAL_CALL component_getFactory (
+ const sal_Char * pImplementationName, void * _pServiceManager, void * /* _pRegistryKey*/)
+{
+ void * pResult = 0;
+ if ( _pServiceManager )
+ {
+ Reference< css::lang::XSingleServiceFactory > xFactory;
+ if (rtl_str_compare(
+ pImplementationName,
+ "com.sun.star.uno.util.numbers.SvNumberFormatsSupplierServiceObject") == 0)
+ {
+ Sequence< OUString > aServiceNames(1);
+ aServiceNames.getArray()[0] =
+ OUString::createFromAscii( "com.sun.star.util.NumberFormatsSupplier" );
+
+ xFactory = ::cppu::createSingleFactory(
+ reinterpret_cast< css::lang::XMultiServiceFactory* >(_pServiceManager),
+ OUString::createFromAscii( pImplementationName ),
+ SvNumberFormatsSupplierServiceObject_CreateInstance,
+ aServiceNames);
+ }
+ else if (rtl_str_compare(
+ pImplementationName,
+ "com.sun.star.uno.util.numbers.SvNumberFormatterServiceObject") == 0)
+ {
+ Sequence< OUString > aServiceNames(1);
+ aServiceNames.getArray()[0] =
+ OUString::createFromAscii( "com.sun.star.util.NumberFormatter" );
+
+ xFactory = ::cppu::createSingleFactory(
+ reinterpret_cast< css::lang::XMultiServiceFactory* >(_pServiceManager),
+ OUString::createFromAscii( pImplementationName ),
+ SvNumberFormatterServiceObj_CreateInstance,
+ aServiceNames);
+ }
+ else if (rtl_str_compare (
+ pImplementationName, "com.sun.star.comp.svl.PathService") == 0)
+ {
+ Sequence< OUString > aServiceNames(1);
+ aServiceNames.getArray()[0] =
+ OUString::createFromAscii( "com.sun.star.config.SpecialConfigManager" );
+ xFactory = ::cppu::createSingleFactory (
+ reinterpret_cast< css::lang::XMultiServiceFactory* >( _pServiceManager ),
+ OUString::createFromAscii( pImplementationName ),
+ PathService_CreateInstance,
+ aServiceNames);
+ }
+ if ( xFactory.is() )
+ {
+ xFactory->acquire();
+ pResult = xFactory.get();
+ }
+ }
+ return pResult;
+}
+
+} // "C"
+