namespace compmodule
{
typedef css::uno::Reference< css::lang::XSingleServiceFactory > (*FactoryInstantiation)
(
const css::uno::Reference< css::lang::XMultiServiceFactory >& _rServiceManager,
const OUString & _rComponentName,
::cppu::ComponentInstantiation _pCreateFunction,
const css::uno::Sequence< OUString > & _rServiceNames,
rtl_ModuleCount*
);
class OModule
{
private:
OModule() = delete; //TODO: get rid of this class
protected:
// auto registration administration
static std::vector< OUString >*
s_pImplementationNames;
static std::vector< css::uno::Sequence< OUString > >*
s_pSupportedServices;
static std::vector< cppu::ComponentInstantiation >*
s_pCreationFunctionPointers;
static std::vector< FactoryInstantiation >*
s_pFactoryFunctionPointers;
public:
/** register a component implementing a service with the given data.
@param _rImplementationName
the implementation name of the component
@param _rServiceNames
the services the component supports
@param _pCreateFunction
a function for creating an instance of the component
@param _pFactoryFunction
a function for creating a factory for that component
@see revokeComponent
*/
static void registerComponent(
const OUString& _rImplementationName,
const css::uno::Sequence< OUString >& _rServiceNames,
::cppu::ComponentInstantiation _pCreateFunction,
FactoryInstantiation _pFactoryFunction);
/** revoke the registration for the specified component
@param _rImplementationName
the implementation name of the component
*/
static void revokeComponent(
const OUString& _rImplementationName);
/** creates a Factory for the component with the given implementation name.
Usually used from within component_getFactory.
@param _rxServiceManager
a pointer to an XMultiServiceFactory interface as got in component_getFactory
@param _pImplementationName
the implementation name of the component
@return
the XInterface access to a factory for the component
*/
static css::uno::Reference< css::uno::XInterface > getComponentFactory(
const OUString& _rImplementationName,
const css::uno::Reference< css::lang::XMultiServiceFactory >& _rxServiceManager
);
};
// specialized ResId, using the resource locale provided by the global module
OUString ModuleRes(const char* pId);
template
class OMultiInstanceAutoRegistration
{
public:
/** automatically registers a multi instance component
Assumed that the template argument has the three methods
static OUString getImplementationName_Static()
static css::uno::Sequence< OUString > getSupportedServiceNames_Static()
static css::uno::Reference< css::uno::XInterface >
Create(const css::uno::Reference< css::lang::XMultiServiceFactory >&)
the instantiation of this object will automatically register the class via OModule::registerComponent.
The factory creation function used is ::cppu::createSingleFactory
.
*/
OMultiInstanceAutoRegistration();
~OMultiInstanceAutoRegistration();
};
template
OMultiInstanceAutoRegistration::OMultiInstanceAutoRegistration()
{
OModule::registerComponent(
TYPE::getImplementationName_Static(),
TYPE::getSupportedServiceNames_Static(),
TYPE::Create,
::cppu::createSingleFactory
);
}
template
OMultiInstanceAutoRegistration::~OMultiInstanceAutoRegistration()
{
OModule::revokeComponent(TYPE::getImplementationName_Static());
}
} // namespace compmodule
#endif // INCLUDED_EXTENSIONS_SOURCE_INC_COMPONENTMODULE_HXX
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */