X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/83df96d63a52ebb08b9e32549dc255354b4a18d0..15c3723c6092669f91c9251382f4a1521deeceeb:/include/wx/x11/app.h diff --git a/include/wx/x11/app.h b/include/wx/x11/app.h index d3bc19d40b..c1e44dad6e 100644 --- a/include/wx/x11/app.h +++ b/include/wx/x11/app.h @@ -32,9 +32,10 @@ class WXDLLEXPORT wxWindow; class WXDLLEXPORT wxApp; class WXDLLEXPORT wxKeyEvent; class WXDLLEXPORT wxLog; +class WXDLLEXPORT wxEventLoop; // ---------------------------------------------------------------------------- -// the wxApp class for Motif - see wxAppBase for more details +// the wxApp class for wxX11 - see wxAppBase for more details // ---------------------------------------------------------------------------- class WXDLLEXPORT wxApp : public wxAppBase @@ -43,7 +44,7 @@ class WXDLLEXPORT wxApp : public wxAppBase public: wxApp(); - ~wxApp() {} + ~wxApp(); // override base class (pure) virtuals // ----------------------------------- @@ -54,11 +55,10 @@ public: virtual bool Pending(); virtual void Dispatch(); virtual bool Yield(bool onlyIfNeeded = FALSE); + virtual bool ProcessIdle(); virtual bool OnInitGui(); - virtual wxIcon GetStdIcon(int which) const; - // implementation from now on // -------------------------- @@ -72,19 +72,12 @@ public: // Returns TRUE if more idle time is requested. bool SendIdleEvents(wxWindow* win); - // Motif implementation. - // Processes an X event. - virtual void ProcessXEvent(WXEvent* event); - - // Returns TRUE if an accelerator has been processed - virtual bool CheckForAccelerator(WXEvent* event); - - // Returns TRUE if a key down event has been processed - virtual bool CheckForKeyDown(WXEvent* event); + virtual bool ProcessXEvent(WXEvent* event); - // Returns TRUE if a key up event has been processed - virtual bool CheckForKeyUp(WXEvent* event); +#ifdef __WXDEBUG__ + virtual void OnAssert(const wxChar *file, int line, const wxChar* cond, const wxChar *msg); +#endif // __WXDEBUG__ protected: bool m_showOnInit; @@ -95,31 +88,55 @@ public: static void CleanUp(); void DeletePendingObjects(); - bool ProcessIdle(); - // Motif-specific - WXAppContext GetAppContext() const { return m_appContext; } - WXWidget GetTopLevelWidget() const { return m_topLevelWidget; } + WXWindow GetTopLevelWidget() const { return m_topLevelWidget; } WXColormap GetMainColormap(WXDisplay* display); - WXDisplay* GetInitialDisplay() const { return m_initialDisplay; } long GetMaxRequestSize() const { return m_maxRequestSize; } // This handler is called when a property change event occurs - virtual void HandlePropertyChange(WXEvent *event); + virtual bool HandlePropertyChange(WXEvent *event); + // Values that can be passed on the command line. + // Returns -1, -1 if none specified. + const wxSize& GetInitialSize() const { return m_initialSize; } + bool GetShowIconic() const { return m_showIconic; } + + // We need this before creating the app + static WXDisplay* GetDisplay() { return ms_display; } + static WXDisplay* ms_display; + public: - static long sm_lastMessageTime; - int m_nCmdShow; + static long sm_lastMessageTime; + bool m_showIconic; + wxSize m_initialSize; + +#if !wxUSE_NANOX + // Someone find a better place for these + int m_visualType; // TrueColor, DirectColor etc. + int m_visualDepth; + int m_visualColormapSize; + void *m_visualColormap; + int m_visualScreen; + unsigned long m_visualRedMask; + unsigned long m_visualGreenMask; + unsigned long m_visualBlueMask; + int m_visualRedShift; + int m_visualGreenShift; + int m_visualBlueShift; + int m_visualRedPrec; + int m_visualGreenPrec; + int m_visualBluePrec; + + unsigned char *m_colorCube; +#endif protected: bool m_keepGoing; - // Motif-specific - WXAppContext m_appContext; - WXWidget m_topLevelWidget; + WXWindow m_topLevelWidget; WXColormap m_mainColormap; - WXDisplay* m_initialDisplay; long m_maxRequestSize; + wxEventLoop* m_mainLoop; DECLARE_EVENT_TABLE() };