1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: wxApp class
4 // Author: Julian Smart
8 // Copyright: (c) Julian Smart
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
16 #pragma interface "app.h"
20 #include "wx/object.h"
21 #include "wx/gdicmn.h"
24 class WXDLLEXPORT wxFrame
;
25 class WXDLLEXPORT wxWindow
;
26 class WXDLLEXPORT wxApp
;
27 class WXDLLEXPORT wxKeyEvent
;
28 class WXDLLEXPORT wxLog
;
30 #define wxPRINT_WINDOWS 1
31 #define wxPRINT_POSTSCRIPT 2
33 WXDLLEXPORT_DATA(extern wxApp
*) wxTheApp
;
35 // Force an exit from main loop
36 void WXDLLEXPORT
wxExit();
38 // Yield to other apps/messages
39 bool WXDLLEXPORT
wxYield();
41 // Represents the application. Derive OnInit and declare
42 // a new App object to start application
43 class WXDLLEXPORT wxApp
: public wxEvtHandler
45 DECLARE_DYNAMIC_CLASS(wxApp
)
49 static void SetInitializerFunction(wxAppInitializerFunction fn
) { m_appInitFn
= fn
; }
50 static wxAppInitializerFunction
GetInitializerFunction() { return m_appInitFn
; }
52 virtual int MainLoop();
55 virtual bool Pending() ;
56 virtual void Dispatch() ;
58 void OnIdle(wxIdleEvent
& event
);
61 virtual bool OnInit() { return FALSE
; };
63 // Create an application context
64 virtual bool OnInitGui();
66 // Called to set off the main loop
67 virtual int OnRun() { return MainLoop(); };
68 virtual int OnExit() { return 0; }
70 /** Returns the standard icons for the msg dialogs, implemented in
71 src/generic/msgdlgg.cpp and src/gtk/app.cpp. */
72 virtual wxIcon
GetStdIcon(int which
) const;
74 inline void SetPrintMode(int mode
) { m_printMode
= mode
; }
75 inline int GetPrintMode() const { return m_printMode
; }
77 inline void SetExitOnFrameDelete(bool flag
) { m_exitOnFrameDelete
= flag
; }
78 inline bool GetExitOnFrameDelete() const { return m_exitOnFrameDelete
; }
80 inline wxString
GetAppName() const {
83 else return m_className
;
86 inline void SetAppName(const wxString
& name
) { m_appName
= name
; };
87 inline wxString
GetClassName() const { return m_className
; }
88 inline void SetClassName(const wxString
& name
) { m_className
= name
; }
90 void SetVendorName(const wxString
& vendorName
) { m_vendorName
= vendorName
; }
91 const wxString
& GetVendorName() const { return m_vendorName
; }
93 wxWindow
*GetTopWindow() const ;
94 inline void SetTopWindow(wxWindow
*win
) { m_topWindow
= win
; }
96 inline void SetWantDebugOutput(bool flag
) { m_wantDebugOutput
= flag
; }
97 inline bool GetWantDebugOutput() { return m_wantDebugOutput
; }
99 // Send idle event to all top-level windows.
100 // Returns TRUE if more idle time is requested.
101 bool SendIdleEvents();
103 // Send idle event to window and all subwindows
104 // Returns TRUE if more idle time is requested.
105 bool SendIdleEvents(wxWindow
* win
);
107 // Windows only, but for compatibility...
108 inline void SetAuto3D(bool flag
) { m_auto3D
= flag
; }
109 inline bool GetAuto3D() const { return m_auto3D
; }
111 // Creates a log object
112 virtual wxLog
* CreateLogTarget();
114 // Motif implementation.
116 // Processes an X event.
117 virtual void ProcessXEvent(WXEvent
* event
);
119 // Returns TRUE if an accelerator has been processed
120 virtual bool CheckForAccelerator(WXEvent
* event
);
123 // Will always be set to the appropriate, main-style values.
128 bool m_wantDebugOutput
;
129 wxString m_className
;
132 wxWindow
* m_topWindow
;
133 bool m_exitOnFrameDelete
;
135 int m_printMode
; // wxPRINT_WINDOWS, wxPRINT_POSTSCRIPT
136 bool m_auto3D
; // Always use 3D controls, except
138 static wxAppInitializerFunction m_appInitFn
;
143 static bool Initialize();
144 static void CleanUp();
146 void DeletePendingObjects();
149 void ProcessPendingEvents();
153 inline WXAppContext
GetAppContext() const { return m_appContext
; }
154 inline WXWidget
GetTopLevelWidget() const { return m_topLevelWidget
; }
155 WXColormap
GetMainColormap(WXDisplay
* display
) ;
156 WXDisplay
* GetInitialDisplay() const { return m_initialDisplay
; }
157 inline long GetMaxRequestSize() const { return m_maxRequestSize
; }
159 // This handler is called when a property change event occurs
160 virtual void HandlePropertyChange(WXEvent
*event
);
163 static long sm_lastMessageTime
;
170 WXAppContext m_appContext
;
171 WXWidget m_topLevelWidget
;
172 WXColormap m_mainColormap
;
173 WXDisplay
* m_initialDisplay
;
174 long m_maxRequestSize
;
176 DECLARE_EVENT_TABLE()
179 int WXDLLEXPORT
wxEntry( int argc
, char *argv
[] );