1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: Dynamic library loading classes
4 // Author: Guilhem Lavaux, Vadim Zeitlin, Vaclav Slavik
8 // Copyright: (c) 1998 Guilhem Lavaux
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
12 #ifndef _WX_DYNLIB_H__
13 #define _WX_DYNLIB_H__
15 #if defined(__GNUG__) && !defined(__APPLE__)
16 # pragma interface "dynlib.h"
21 #if wxUSE_DYNAMIC_LOADER
23 #include "wx/dynload.h" // Use the new (version of) wxDynamicLibrary instead
25 #elif wxUSE_DYNLIB_CLASS
27 #include "wx/string.h"
31 // this is normally done by configure, but I leave it here for now...
32 #if defined(__UNIX__) && !(defined(HAVE_DLOPEN) || defined(HAVE_SHL_LOAD))
33 # if defined(__LINUX__) || defined(__SOLARIS__) || defined(__SUNOS__) || defined(__FREEBSD__)
35 # elif defined(__HPUX__)
36 # define HAVE_SHL_LOAD
37 # endif // Unix flavour
38 #endif // !Unix or already have some HAVE_xxx defined
40 // Note: WXPM/EMX has to be tested first, since we want to use
41 // native version, even if configure detected presence of DLOPEN.
42 #if defined(__WXPM__) || defined(__EMX__)
45 typedef HMODULE wxDllType
;
46 #elif defined(HAVE_DLOPEN)
48 typedef void *wxDllType
;
49 #elif defined(HAVE_SHL_LOAD)
51 typedef shl_t wxDllType
;
52 #elif defined(__WINDOWS__)
53 # include <windows.h> // needed to get HMODULE
54 typedef HMODULE wxDllType
;
55 #elif defined(__DARWIN__)
56 typedef void *wxDllType
;
57 #elif defined(__WXMAC__)
58 typedef void *wxDllType
;
60 # error "wxLibrary can't be compiled on this platform, sorry."
63 // LoadLibrary is defined in windows.h as LoadLibraryA, but wxDllLoader method
64 // should be called LoadLibrary, not LoadLibraryA or LoadLibraryW!
65 #if defined(__WIN32__) && defined(LoadLibrary)
66 # include "wx/msw/winundef.h"
69 // ----------------------------------------------------------------------------
70 // wxDllLoader: low level DLL functions, use wxDynamicLibrary in your code
71 // ----------------------------------------------------------------------------
74 wxDllLoader is a class providing an interface similar to unix's dlopen().
75 It is used by wxDynamicLibrary wxLibrary and manages the actual loading of
76 DLLs and the resolving of symbols in them. There are no instances of this
77 class, it simply serves as a namespace for its static member functions.
79 class WXDLLEXPORT wxDllLoader
83 This function loads the shared library libname into memory.
85 libname may be either the full path to the file or just the filename in
86 which case the library is searched for in all standard locations
87 (use GetDllExt() to construct the filename)
89 if success pointer is not NULL, it will be filled with TRUE if everything
90 went ok and FALSE otherwise
92 static wxDllType
LoadLibrary(const wxString
& libname
, bool *success
= 0);
95 This function unloads the shared library previously loaded with
98 static void UnloadLibrary(wxDllType dll
);
101 This function returns a valid handle for the main program
102 itself or NULL if back linking is not supported by the current platform
105 static wxDllType
GetProgramHandle();
108 This function resolves a symbol in a loaded DLL, such as a
109 variable or function name.
111 dllHandle Handle of the DLL, as returned by LoadDll().
112 name Name of the symbol.
114 Returns the pointer to the symbol or NULL on error.
116 static void *GetSymbol(wxDllType dllHandle
,
117 const wxString
&name
,
118 bool *success
= NULL
);
120 // return the standard DLL extension (with leading dot) for this platform
121 static const wxString
&GetDllExt() { return ms_dllext
; }
124 // forbid construction of objects
126 static const wxString ms_dllext
;
129 // ----------------------------------------------------------------------------
130 // wxDynamicLibrary - friendly interface to wxDllLoader
131 // ----------------------------------------------------------------------------
133 class WXDLLEXPORT wxDynamicLibrary
137 wxDynamicLibrary() { m_library
= 0; }
138 wxDynamicLibrary(const wxString
& name
) { Load(name
); }
140 // return TRUE if the library was loaded successfully
141 bool IsLoaded() const { return m_library
!= 0; }
142 operator bool() const { return IsLoaded(); }
144 // load the library with the given name (full or not), return TRUE on
146 bool Load(const wxString
& name
)
148 m_library
= wxDllLoader::LoadLibrary(name
);
153 // unload the library, also done automatically in dtor
157 wxDllLoader::UnloadLibrary(m_library
);
160 // load a symbol from the library, return NULL if an error occured or
161 // symbol wasn't found
162 void *GetSymbol(const wxString
& name
) const
164 wxCHECK_MSG( IsLoaded(), NULL
,
165 _T("can't load symbol from unloaded library") );
167 return wxDllLoader::GetSymbol(m_library
, name
);
170 // unload the library
172 // NB: dtor is not virtual, don't derive from this class
173 ~wxDynamicLibrary() { Unload(); }
176 // the handle to DLL or NULL
179 // no copy ctor/assignment operators (or we'd try to unload the library
181 DECLARE_NO_COPY_CLASS(wxDynamicLibrary
)
184 // ----------------------------------------------------------------------------
186 // ----------------------------------------------------------------------------
188 class WXDLLEXPORT wxLibrary
: public wxObject
191 wxLibrary(wxDllType handle
);
192 virtual ~wxLibrary();
194 // Get a symbol from the dynamic library
195 void *GetSymbol(const wxString
& symbname
);
197 // Create the object whose classname is "name"
198 wxObject
*CreateObject(const wxString
& name
);
201 void PrepareClasses(wxClassInfo
*first
);
206 wxHashTable classTable
;
209 // ----------------------------------------------------------------------------
211 // ----------------------------------------------------------------------------
213 class WXDLLEXPORT wxLibraries
219 // caller is responsible for deleting the returned pointer if !NULL
220 wxLibrary
*LoadLibrary(const wxString
& basename
);
222 wxObject
*CreateObject(const wxString
& name
);
228 // ----------------------------------------------------------------------------
230 // ----------------------------------------------------------------------------
232 extern WXDLLEXPORT_DATA(wxLibraries
) wxTheLibraries
;
234 // ----------------------------------------------------------------------------
235 // Interesting defines
236 // ----------------------------------------------------------------------------
238 #define WXDLL_ENTRY_FUNCTION() \
239 extern "C" WXEXPORT const wxClassInfo *wxGetClassFirst(); \
240 const wxClassInfo *wxGetClassFirst() { \
241 return wxClassInfo::GetFirst(); \
244 #endif // wxUSE_DYNLIB_CLASS
246 #endif // _WX_DYNLIB_H__