Implement compatibility aliases for non-prefixed macro names. Require a final semicolon where possible. Correct a recurring error in the docs: IMPLEMENT/DECLARE_CLASS are alias to the DYNAMIC macros, not to the ABSTRACT macros. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@64532 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
		
			
				
	
	
		
			132 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Objective-C
		
	
	
	
	
	
			
		
		
	
	
			132 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Objective-C
		
	
	
	
	
	
| /////////////////////////////////////////////////////////////////////////////
 | |
| // Name:        module.h
 | |
| // Purpose:     interface of wxModule
 | |
| // Author:      wxWidgets team
 | |
| // RCS-ID:      $Id$
 | |
| // Licence:     wxWindows license
 | |
| /////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| /**
 | |
|     @class wxModule
 | |
| 
 | |
|     The module system is a very simple mechanism to allow applications (and parts
 | |
|     of wxWidgets itself) to define initialization and cleanup functions that are
 | |
|     automatically called on wxWidgets startup and exit.
 | |
| 
 | |
|     To define a new kind of module, derive a class from wxModule, override the
 | |
|     wxModule::OnInit and wxModule::OnExit functions, and add the
 | |
|     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
 | |
|     will call the wxModule::OnExit function for each module instance.
 | |
| 
 | |
|     Note that your module class does not have to be in a header file.
 | |
| 
 | |
|     For example:
 | |
| 
 | |
|     @code
 | |
|         // A module to allow DDE initialization/cleanup
 | |
|       // without calling these functions from app.cpp or from
 | |
|       // the user's application.
 | |
|       class wxDDEModule: public wxModule
 | |
|       {
 | |
|       public:
 | |
|           wxDDEModule() { }
 | |
|           virtual bool OnInit() { wxDDEInitialize(); return true; };
 | |
|           virtual void OnExit() { wxDDECleanUp(); };
 | |
| 
 | |
|       private:
 | |
|           wxDECLARE_DYNAMIC_CLASS(wxDDEModule);
 | |
|       };
 | |
| 
 | |
|       wxIMPLEMENT_DYNAMIC_CLASS(wxDDEModule, wxModule);
 | |
| 
 | |
|       // Another module which uses DDE in its OnInit()
 | |
|       class MyModule: public wxModule
 | |
|       {
 | |
|       public:
 | |
|           MyModule() { AddDependency(wxCLASSINFO(wxDDEModule)); }
 | |
|           virtual bool OnInit() { ... code using DDE ... }
 | |
|           virtual void OnExit() { ... }
 | |
| 
 | |
|       private:
 | |
|           wxDECLARE_DYNAMIC_CLASS(MyModule);
 | |
|       };
 | |
| 
 | |
|       wxIMPLEMENT_DYNAMIC_CLASS(MyModule, wxModule);
 | |
| 
 | |
|       // Another module which uses DDE in its OnInit()
 | |
|       // but uses a named dependency
 | |
|       class MyModule2: public wxModule
 | |
|       {
 | |
|       public:
 | |
|           MyModule2() { AddDependency("wxDDEModule"); }
 | |
|           virtual bool OnInit() { ... code using DDE ... }
 | |
|           virtual void OnExit() { ... }
 | |
| 
 | |
|       private:
 | |
|           wxDECLARE_DYNAMIC_CLASS(MyModule2)
 | |
|       };
 | |
| 
 | |
|       wxIMPLEMENT_DYNAMIC_CLASS(MyModule2, wxModule)
 | |
|     @endcode
 | |
| 
 | |
|     @library{wxbase}
 | |
|     @category{appmanagement}
 | |
| */
 | |
| class wxModule : public wxObject
 | |
| {
 | |
| public:
 | |
|     /**
 | |
|         Constructs a wxModule object.
 | |
|     */
 | |
|     wxModule();
 | |
| 
 | |
|     /**
 | |
|         Destructor.
 | |
|     */
 | |
|     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 wxCLASSINFO() of a wxModule-derived class and the
 | |
|         corresponding module will be loaded before and unloaded after this module.
 | |
| 
 | |
|         @param dep
 | |
|             The class information object for the dependent module.
 | |
|     */
 | |
|     void AddDependency(wxClassInfo* dep);
 | |
| 
 | |
|     /**
 | |
|         Call this function from the constructor of the derived class.
 | |
| 
 | |
|         This overload allows a dependency to be added by name without access to
 | |
|         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 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.
 | |
| 
 | |
|         @param classname
 | |
|             The class name of the dependent module.
 | |
|     */
 | |
|     void AddDependency(const char* classname);
 | |
| };
 | |
| 
 |