xref: /trunk/main/dbaccess/source/inc/registrationhelper.hxx (revision 914d351e5f5b84e4342a86d6ab8d4aca7308b9bd)
1*2e2212a7SAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3*2e2212a7SAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4*2e2212a7SAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5*2e2212a7SAndrew Rist  * distributed with this work for additional information
6*2e2212a7SAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7*2e2212a7SAndrew Rist  * to you under the Apache License, Version 2.0 (the
8*2e2212a7SAndrew Rist  * "License"); you may not use this file except in compliance
9*2e2212a7SAndrew Rist  * with the License.  You may obtain a copy of the License at
10cdf0e10cSrcweir  *
11*2e2212a7SAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir  *
13*2e2212a7SAndrew Rist  * Unless required by applicable law or agreed to in writing,
14*2e2212a7SAndrew Rist  * software distributed under the License is distributed on an
15*2e2212a7SAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*2e2212a7SAndrew Rist  * KIND, either express or implied.  See the License for the
17*2e2212a7SAndrew Rist  * specific language governing permissions and limitations
18*2e2212a7SAndrew Rist  * under the License.
19cdf0e10cSrcweir  *
20*2e2212a7SAndrew Rist  *************************************************************/
21*2e2212a7SAndrew Rist 
22*2e2212a7SAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir #ifndef _REGISTRATIONHELPER_INCLUDED_INDIRECTLY_
25cdf0e10cSrcweir #error "don't include this file directly! use dbu_reghelper.hxx instead!"
26cdf0e10cSrcweir #endif
27cdf0e10cSrcweir 
28cdf0e10cSrcweir typedef ::com::sun::star::uno::Reference< ::com::sun::star::lang::XSingleServiceFactory > (SAL_CALL *FactoryInstantiation)
29cdf0e10cSrcweir         (
30cdf0e10cSrcweir             const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XMultiServiceFactory >& _rServiceManager,
31cdf0e10cSrcweir             const ::rtl::OUString & _rComponentName,
32cdf0e10cSrcweir             ::cppu::ComponentInstantiation _pCreateFunction,
33cdf0e10cSrcweir             const ::com::sun::star::uno::Sequence< ::rtl::OUString > & _rServiceNames,
34cdf0e10cSrcweir             rtl_ModuleCount* _p
35cdf0e10cSrcweir         );
36cdf0e10cSrcweir 
37cdf0e10cSrcweir //==========================================================================
38cdf0e10cSrcweir class OModuleRegistration
39cdf0e10cSrcweir {
40cdf0e10cSrcweir     static  ::com::sun::star::uno::Sequence< ::rtl::OUString >*
41cdf0e10cSrcweir         s_pImplementationNames;
42cdf0e10cSrcweir     static  ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Sequence< ::rtl::OUString > >*
43cdf0e10cSrcweir         s_pSupportedServices;
44cdf0e10cSrcweir     static  ::com::sun::star::uno::Sequence< sal_Int64 >*
45cdf0e10cSrcweir         s_pCreationFunctionPointers;
46cdf0e10cSrcweir     static  ::com::sun::star::uno::Sequence< sal_Int64 >*
47cdf0e10cSrcweir         s_pFactoryFunctionPointers;
48cdf0e10cSrcweir 
49cdf0e10cSrcweir     // no direct instantiation, only static members/methods
OModuleRegistration()50cdf0e10cSrcweir     OModuleRegistration() { }
51cdf0e10cSrcweir 
52cdf0e10cSrcweir public:
53cdf0e10cSrcweir     /** register a component implementing a service with the given data.
54cdf0e10cSrcweir         @param      _rImplementationName        the implementation name of the component
55cdf0e10cSrcweir         @param      _rServiceNames              the services the component supports
56cdf0e10cSrcweir         @param      _pCreateFunction            a function for creating an instance of the component
57cdf0e10cSrcweir         @param      _pFactoryFunction           a function for creating a factory for that component
58cdf0e10cSrcweir         @see revokeComponent
59cdf0e10cSrcweir     */
60cdf0e10cSrcweir     static void registerComponent(
61cdf0e10cSrcweir         const ::rtl::OUString& _rImplementationName,
62cdf0e10cSrcweir         const ::com::sun::star::uno::Sequence< ::rtl::OUString >& _rServiceNames,
63cdf0e10cSrcweir         ::cppu::ComponentInstantiation _pCreateFunction,
64cdf0e10cSrcweir         FactoryInstantiation _pFactoryFunction);
65cdf0e10cSrcweir 
66cdf0e10cSrcweir     /** revoke the registration for the specified component
67cdf0e10cSrcweir         @param      _rImplementationName        the implementation name of the component
68cdf0e10cSrcweir     */
69cdf0e10cSrcweir     static void revokeComponent(
70cdf0e10cSrcweir         const ::rtl::OUString& _rImplementationName);
71cdf0e10cSrcweir 
72cdf0e10cSrcweir     /** creates a Factory for the component with the given implementation name. Usually used from within component_getFactory.
73cdf0e10cSrcweir         @param      _rxServiceManager       a pointer to an XMultiServiceFactory interface as got in component_getFactory
74cdf0e10cSrcweir         @param      _pImplementationName    the implementation name of the component
75cdf0e10cSrcweir         @return                             the XInterface access to a factory for the component
76cdf0e10cSrcweir     */
77cdf0e10cSrcweir     static ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > getComponentFactory(
78cdf0e10cSrcweir         const ::rtl::OUString& _rImplementationName,
79cdf0e10cSrcweir         const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XMultiServiceFactory >& _rxServiceManager
80cdf0e10cSrcweir         );
81cdf0e10cSrcweir };
82cdf0e10cSrcweir 
83cdf0e10cSrcweir //==========================================================================
84cdf0e10cSrcweir template <class TYPE>
85cdf0e10cSrcweir class OMultiInstanceAutoRegistration
86cdf0e10cSrcweir {
87cdf0e10cSrcweir public:
88cdf0e10cSrcweir     /** assumed that the template argument has the three methods<BR>
89cdf0e10cSrcweir         <code>static ::rtl::OUString getImplementationName_Static()</code><BR>
90cdf0e10cSrcweir         <code>static ::com::sun::star::uno::Sequence< ::rtl::OUString > getSupportedServiceNames_Static()</code><BR>
91cdf0e10cSrcweir         and<BR>
92cdf0e10cSrcweir         <code>static ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface >
93cdf0e10cSrcweir             Create(const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XMultiServiceFactory >&)</code><BR>
94cdf0e10cSrcweir         the instantiation of this object will automatically register the class via <code>OModuleRegistration::registerComponent</code>.
95cdf0e10cSrcweir         The factory creation function used is <code>::cppu::createSingleFactory</code>.<BR>
96cdf0e10cSrcweir         @see OOneInstanceAutoRegistration
97cdf0e10cSrcweir     */
98cdf0e10cSrcweir     OMultiInstanceAutoRegistration();
99cdf0e10cSrcweir     ~OMultiInstanceAutoRegistration();
100cdf0e10cSrcweir };
101cdf0e10cSrcweir 
102cdf0e10cSrcweir template <class TYPE>
OMultiInstanceAutoRegistration()103cdf0e10cSrcweir OMultiInstanceAutoRegistration<TYPE>::OMultiInstanceAutoRegistration()
104cdf0e10cSrcweir {
105cdf0e10cSrcweir     OModuleRegistration::registerComponent(
106cdf0e10cSrcweir         TYPE::getImplementationName_Static(),
107cdf0e10cSrcweir         TYPE::getSupportedServiceNames_Static(),
108cdf0e10cSrcweir         TYPE::Create,
109cdf0e10cSrcweir         ::cppu::createSingleFactory
110cdf0e10cSrcweir         );
111cdf0e10cSrcweir }
112cdf0e10cSrcweir 
113cdf0e10cSrcweir template <class TYPE>
~OMultiInstanceAutoRegistration()114cdf0e10cSrcweir OMultiInstanceAutoRegistration<TYPE>::~OMultiInstanceAutoRegistration()
115cdf0e10cSrcweir {
116cdf0e10cSrcweir     OModuleRegistration::revokeComponent(TYPE::getImplementationName_Static());
117cdf0e10cSrcweir }
118cdf0e10cSrcweir 
119cdf0e10cSrcweir //==========================================================================
120cdf0e10cSrcweir template <class TYPE>
121cdf0e10cSrcweir class OOneInstanceAutoRegistration
122cdf0e10cSrcweir {
123cdf0e10cSrcweir public:
124cdf0e10cSrcweir     /** provided that the template argument has three methods<BR>
125cdf0e10cSrcweir         <code>static ::rtl::OUString getImplementationName_Static()</code><BR>
126cdf0e10cSrcweir         <code>static ::com::sun::star::uno::Sequence< ::rtl::OUString > getSupportedServiceNames_Static()</code><BR>
127cdf0e10cSrcweir         and<BR>
128cdf0e10cSrcweir         <code>static ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface >
129cdf0e10cSrcweir             Create(const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XMultiServiceFactory >&)</code><BR>
130cdf0e10cSrcweir         the instantiation of this object will automatically register the class via <code>OModuleRegistration::registerComponent</code>.
131cdf0e10cSrcweir         The factory creation function used is <code>::cppu::createSingleFactory</code>.<BR>
132cdf0e10cSrcweir         @see OMultiInstanceAutoRegistration
133cdf0e10cSrcweir     */
134cdf0e10cSrcweir     OOneInstanceAutoRegistration();
135cdf0e10cSrcweir     ~OOneInstanceAutoRegistration();
136cdf0e10cSrcweir };
137cdf0e10cSrcweir 
138cdf0e10cSrcweir template <class TYPE>
OOneInstanceAutoRegistration()139cdf0e10cSrcweir OOneInstanceAutoRegistration<TYPE>::OOneInstanceAutoRegistration()
140cdf0e10cSrcweir {
141cdf0e10cSrcweir     OModuleRegistration::registerComponent(
142cdf0e10cSrcweir         TYPE::getImplementationName_Static(),
143cdf0e10cSrcweir         TYPE::getSupportedServiceNames_Static(),
144cdf0e10cSrcweir         TYPE::Create,
145cdf0e10cSrcweir         ::cppu::createOneInstanceFactory
146cdf0e10cSrcweir         );
147cdf0e10cSrcweir }
148cdf0e10cSrcweir 
149cdf0e10cSrcweir template <class TYPE>
~OOneInstanceAutoRegistration()150cdf0e10cSrcweir OOneInstanceAutoRegistration<TYPE>::~OOneInstanceAutoRegistration()
151cdf0e10cSrcweir {
152cdf0e10cSrcweir     OModuleRegistration::revokeComponent(TYPE::getImplementationName_Static());
153cdf0e10cSrcweir }
154