LibreOffice Module salhelper (master) 1
dynload.cxx
Go to the documentation of this file.
1/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2/*
3 * This file is part of the LibreOffice project.
4 *
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8 *
9 * This file incorporates work covered by the following license notice:
10 *
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
18 */
19
20#include <salhelper/dynload.hxx>
21
22namespace salhelper
23{
24
25typedef void* (*ApiInitFunction) ();
26
28 const OUString& moduleName,
29 const OUString& initFunction,
30 void* pApi,
31 oslModule pModule)
32 : m_pApi(pApi)
33 , m_refCount(1)
34 , m_pModule(pModule)
35 , m_strModuleName(moduleName)
36 , m_strInitFunction(initFunction)
37 , ppSetToZeroInDestructor( ppSetToZeroInDestructor_ )
38{
39}
40
42 const OUString& moduleName,
43 const OUString& initFunction)
44{
45#ifdef DISABLE_DYNLOADING
47 (void) moduleName;
48 (void) initFunction;
49
50 return NULL;
51#else
52 ApiInitFunction initFunc;
53 oslModule pModule = osl_loadModule(moduleName.pData, SAL_LOADMODULE_DEFAULT);
54
55 if ( !pModule )
56 {
57 return nullptr;
58 }
59
60 initFunc = reinterpret_cast<ApiInitFunction>(osl_getFunctionSymbol(
61 pModule, initFunction.pData));
62
63 if ( !initFunc )
64 {
65 osl_unloadModule(pModule);
66 return nullptr;
67 }
68
69 return(new ORealDynamicLoader(ppSetToZeroInDestructor, moduleName,
70 initFunction,
71 initFunc(),
72 pModule));
73#endif
74}
75
77{
78 // set the address to zero
80 *ppSetToZeroInDestructor = nullptr;
81
82 if (m_pModule)
83 {
84#ifndef DISABLE_DYNLOADING
85 osl_unloadModule(m_pModule);
86#endif
87 m_pModule = nullptr;
88 }
89}
90
92{
93 return ++m_refCount;
94}
95
97{
98 sal_uInt32 nRet = --m_refCount;
99 if( nRet == 0 )
100 delete this;
101 return nRet;
102}
103
104
106{
107 return m_pApi;
108}
109
110} // namespace salhelper
111
112/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
The ORealDynamicLoader is an implementation helper class for the template loader ODynamicLoader.
Definition: dynload.hxx:38
sal_uInt32 SAL_CALL release()
decrease the reference count and delete the last instance.
Definition: dynload.cxx:96
static ORealDynamicLoader *SAL_CALL newInstance(ORealDynamicLoader **ppSetToZeroInDestructor, const ::rtl::OUString &strModuleName, const ::rtl::OUString &strInitFunction)
initializes the loader, loads the library and call the initialization function.
Definition: dynload.cxx:41
virtual ~ORealDynamicLoader()
Destructor, try to unload the library.
Definition: dynload.cxx:76
oslModule m_pModule
stores the library handle.
Definition: dynload.hxx:84
void * m_pApi
points to the structure with the initialized API function pointers.
Definition: dynload.hxx:80
sal_uInt32 m_refCount
stores the reference count.
Definition: dynload.hxx:82
void *SAL_CALL getApi() const
returns a pointer to the initialized API function structure.
Definition: dynload.cxx:105
ORealDynamicLoader(ORealDynamicLoader **ppSetToZeroInDestructor, const ::rtl::OUString &strModuleName, const ::rtl::OUString &strInitFunction, void *pApi, oslModule pModule)
Constructor.
Definition: dynload.cxx:27
sal_uInt32 SAL_CALL acquire()
increase the reference count.
Definition: dynload.cxx:91
ORealDynamicLoader ** ppSetToZeroInDestructor
stores a pointer to itself, which must be reset in the destructor to signal that the loader is invali...
Definition: dynload.hxx:92
ULONG m_refCount
return NULL
void *(* ApiInitFunction)()
Definition: dynload.cxx:25