// Name: module.h
// Purpose: interface of wxModule
// Author: wxWidgets team
-// RCS-ID: $Id$
-// Licence: wxWindows license
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
/**
To define a new kind of module, derive a class from wxModule, override the
wxModule::OnInit and wxModule::OnExit functions, and add the
- DECLARE_DYNAMIC_CLASS and IMPLEMENT_DYNAMIC_CLASS to header and implementation
+ wxDECLARE_DYNAMIC_CLASS and wxIMPLEMENT_DYNAMIC_CLASS to header and implementation
files (which can be the same file).
On initialization, wxWidgets will find all classes derived from wxModule, create
an instance of each, and call each wxModule::OnInit function. On exit, wxWidgets
virtual void OnExit() { wxDDECleanUp(); };
private:
- DECLARE_DYNAMIC_CLASS(wxDDEModule)
+ wxDECLARE_DYNAMIC_CLASS(wxDDEModule);
};
- IMPLEMENT_DYNAMIC_CLASS(wxDDEModule, wxModule)
+ wxIMPLEMENT_DYNAMIC_CLASS(wxDDEModule, wxModule);
// Another module which uses DDE in its OnInit()
class MyModule: public wxModule
{
public:
- MyModule() { AddDependency(CLASSINFO(wxDDEModule)); }
+ MyModule() { AddDependency(wxCLASSINFO(wxDDEModule)); }
virtual bool OnInit() { ... code using DDE ... }
virtual void OnExit() { ... }
private:
- DECLARE_DYNAMIC_CLASS(MyModule)
+ wxDECLARE_DYNAMIC_CLASS(MyModule);
};
- IMPLEMENT_DYNAMIC_CLASS(MyModule, wxModule)
+ wxIMPLEMENT_DYNAMIC_CLASS(MyModule, wxModule);
// Another module which uses DDE in its OnInit()
// but uses a named dependency
virtual void OnExit() { ... }
private:
- DECLARE_DYNAMIC_CLASS(MyModule2)
+ wxDECLARE_DYNAMIC_CLASS(MyModule2)
};
- IMPLEMENT_DYNAMIC_CLASS(MyModule2, wxModule)
+ wxIMPLEMENT_DYNAMIC_CLASS(MyModule2, wxModule)
@endcode
@library{wxbase}
- @category{misc}
+ @category{appmanagement}
*/
class wxModule : public wxObject
{
*/
virtual ~wxModule();
+ /**
+ Provide this function with appropriate cleanup for your module.
+ */
+ virtual void OnExit() = 0;
+
+ /**
+ Provide this function with appropriate initialization for your module.
+ If the function returns @false, wxWidgets will exit immediately.
+ */
+ virtual bool OnInit() = 0;
+
+protected:
+
/**
Call this function from the constructor of the derived class.
- @a dep must be the CLASSINFO() of a wxModule-derived class and the
+ @a dep must be the wxCLASSINFO() of a wxModule-derived class and the
corresponding module will be loaded before and unloaded after this module.
@param dep
the class info.
This is useful when a module is declared entirely in a source file and
- there is no header for the declaration of the module needed by CLASSINFO(),
+ there is no header for the declaration of the module needed by wxCLASSINFO(),
however errors are not detected until run-time, instead of compile-time, then.
Note that circular dependencies are detected and result in a fatal error.
The class name of the dependent module.
*/
void AddDependency(const char* classname);
-
- /**
- Provide this function with appropriate cleanup for your module.
- */
- virtual void OnExit();
-
- /**
- Provide this function with appropriate initialization for your module.
- If the function returns @false, wxWidgets will exit immediately.
- */
- virtual bool OnInit();
};