1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: Dynamic loading framework
4 // Author: Ron Lee, David Falkinder, Vadim Zeitlin and a cast of 1000's
5 // (derived in part from dynlib.cpp (c) 1998 Guilhem Lavaux)
9 // Copyright: (c) 2001 Ron Lee <ron@debian.org>
10 // Licence: wxWindows licence
11 /////////////////////////////////////////////////////////////////////////////
13 #ifndef _WX_DYNAMICLOADER_H__
14 #define _WX_DYNAMICLOADER_H__
16 // ----------------------------------------------------------------------------
18 // ----------------------------------------------------------------------------
22 #if wxUSE_DYNAMIC_LOADER
24 #include "wx/dynlib.h"
25 #include "wx/hashmap.h"
26 #include "wx/module.h"
28 class WXDLLIMPEXP_BASE wxPluginLibrary
;
31 WX_DECLARE_STRING_HASH_MAP_WITH_DECL(wxPluginLibrary
*, wxDLManifest
,
32 class WXDLLIMPEXP_BASE
);
33 typedef wxDLManifest wxDLImports
;
35 // ---------------------------------------------------------------------------
37 // ---------------------------------------------------------------------------
39 // NOTE: Do not attempt to use a base class pointer to this class.
40 // wxDL is not virtual and we deliberately hide some of it's
43 // Unless you know exacty why you need to, you probably shouldn't
44 // instantiate this class directly anyway, use wxPluginManager
47 class WXDLLIMPEXP_BASE wxPluginLibrary
: public wxDynamicLibrary
51 static wxDLImports
* ms_classes
; // Static hash of all imported classes.
53 wxPluginLibrary( const wxString
&libname
, int flags
= wxDL_DEFAULT
);
56 wxPluginLibrary
*RefLib();
59 // These two are called by the PluginSentinel on (PLUGGABLE) object
60 // creation/destruction. There is usually no reason for the user to
61 // call them directly. We have to separate this from the link count,
62 // since the two are not interchangeable.
64 // FIXME: for even better debugging PluginSentinel should register
65 // the name of the class created too, then we can state
66 // exactly which object was not destroyed which may be
67 // difficult to find otherwise. Also this code should
68 // probably only be active in DEBUG mode, but let's just
69 // get it right first.
71 void RefObj() { ++m_objcount
; }
74 wxASSERT_MSG( m_objcount
> 0, _T("Too many objects deleted??") );
78 // Override/hide some base class methods
80 bool IsLoaded() const { return m_linkcount
> 0; }
81 void Unload() { UnrefLib(); }
85 wxClassInfo
*m_before
; // sm_first before loading this lib
86 wxClassInfo
*m_after
; // ..and after.
88 size_t m_linkcount
; // Ref count of library link calls
89 size_t m_objcount
; // ..and (pluggable) object instantiations.
90 wxModuleList m_wxmodules
; // any wxModules that we initialised.
92 void UpdateClasses(); // Update ms_classes
93 void RestoreClasses(); // Removes this library from ms_classes
94 void RegisterModules(); // Init any wxModules in the lib.
95 void UnregisterModules(); // Cleanup any wxModules we installed.
97 DECLARE_NO_COPY_CLASS(wxPluginLibrary
)
101 class WXDLLIMPEXP_BASE wxPluginManager
107 static wxPluginLibrary
*LoadLibrary( const wxString
&libname
,
108 int flags
= wxDL_DEFAULT
);
109 static bool UnloadLibrary(const wxString
&libname
);
111 // This is used by wxDllLoader. It's wrapped in the compatibility
112 // macro because it's of arguable use outside of that.
114 #if WXWIN_COMPATIBILITY_2_2
115 wxDEPRECATED( static wxPluginLibrary
*GetObjectFromHandle(wxDllType handle
) );
120 wxPluginManager() : m_entry(NULL
) {}
121 wxPluginManager(const wxString
&libname
, int flags
= wxDL_DEFAULT
)
123 Load(libname
, flags
);
125 ~wxPluginManager() { if ( IsLoaded() ) Unload(); }
127 bool Load(const wxString
&libname
, int flags
= wxDL_DEFAULT
);
130 bool IsLoaded() const { return m_entry
&& m_entry
->IsLoaded(); }
131 void *GetSymbol(const wxString
&symbol
, bool *success
= 0)
133 return m_entry
->GetSymbol( symbol
, success
);
136 static void CreateManifest() { ms_manifest
= new wxDLManifest(wxKEY_STRING
); }
137 static void ClearManifest() { delete ms_manifest
; ms_manifest
= NULL
; }
140 // return the pointer to the entry for the library with given name in
141 // ms_manifest or NULL if none
142 static wxPluginLibrary
*FindByName(const wxString
& name
)
144 const wxDLManifest::iterator i
= ms_manifest
->find(name
);
146 return i
== ms_manifest
->end() ? NULL
: i
->second
;
149 static wxDLManifest
* ms_manifest
; // Static hash of loaded libs.
150 wxPluginLibrary
* m_entry
; // Cache our entry in the manifest.
152 // We could allow this class to be copied if we really
153 // wanted to, but not without modification.
154 DECLARE_NO_COPY_CLASS(wxPluginManager
)
158 #endif // wxUSE_DYNAMIC_LOADER
159 #endif // _WX_DYNAMICLOADER_H__