X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/37f214d588b02079a3ddf64c2e46585ca1657c1b..b0fb0f3c71c527b5c5cb839355c88766b6f8c888:/include/wx/msw/accel.h diff --git a/include/wx/msw/accel.h b/include/wx/msw/accel.h index d035b0aac4..b3fa62a00a 100644 --- a/include/wx/msw/accel.h +++ b/include/wx/msw/accel.h @@ -1,5 +1,5 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: accel.h +// Name: wx/msw/accel.h // Purpose: wxAcceleratorTable class // Author: Julian Smart // Modified by: @@ -12,78 +12,36 @@ #ifndef _WX_ACCEL_H_ #define _WX_ACCEL_H_ -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) #pragma interface "accel.h" #endif -#include "wx/object.h" - -class WXDLLEXPORT wxAcceleratorTable; - -// ---------------------------------------------------------------------------- -// constants -// ---------------------------------------------------------------------------- - -// Hold Ctrl key down -#define wxACCEL_ALT 0x01 - -// Hold Ctrl key down -#define wxACCEL_CTRL 0x02 - - // Hold Shift key down -#define wxACCEL_SHIFT 0x04 - - // Hold no other key -#define wxACCEL_NORMAL 0x00 - -// ---------------------------------------------------------------------------- -// an entry in wxAcceleratorTable corresponds to one accelerator -// ---------------------------------------------------------------------------- - -class WXDLLEXPORT wxAcceleratorEntry -{ -public: - wxAcceleratorEntry(int flags = 0, int keyCode = 0, int cmd = 0) - { - Set(flags, keyCode, cmd); - } - - void Set(int flags, int keyCode, int cmd) - { - m_flags = flags; m_keyCode = keyCode; m_command = cmd; - } - - int GetFlags() const { return m_flags; } - int GetKeyCode() const { return m_keyCode; } - int GetCommand() const { return m_command; } - -//private: - int m_flags; - int m_keyCode; // ASCII or virtual keycode - int m_command; // Command id to generate -}; - // ---------------------------------------------------------------------------- // the accel table has all accelerators for a given window or menu // ---------------------------------------------------------------------------- class WXDLLEXPORT wxAcceleratorTable : public wxObject { -DECLARE_DYNAMIC_CLASS(wxAcceleratorTable) public: + // default ctor wxAcceleratorTable(); - wxAcceleratorTable(const wxString& resource); // Load from .rc resource - wxAcceleratorTable(int n, const wxAcceleratorEntry entries[]); // Load from array - // Copy constructors - inline wxAcceleratorTable(const wxAcceleratorTable& accel) { Ref(accel); } - inline wxAcceleratorTable(const wxAcceleratorTable* accel) { if (accel) Ref(*accel); } + // copy ctor + wxAcceleratorTable(const wxAcceleratorTable& accel) { Ref(accel); } + + // load from .rc resource (Windows specific) + wxAcceleratorTable(const wxString& resource); + + // initialize from array + wxAcceleratorTable(int n, const wxAcceleratorEntry entries[]); - ~wxAcceleratorTable(); + virtual ~wxAcceleratorTable(); - inline wxAcceleratorTable& operator = (const wxAcceleratorTable& accel) { if ( *this != accel ) Ref(accel); return *this; } - inline bool operator == (const wxAcceleratorTable& accel) const { return m_refData == accel.m_refData; } - inline bool operator != (const wxAcceleratorTable& accel) const { return m_refData != accel.m_refData; } + wxAcceleratorTable& operator = (const wxAcceleratorTable& accel) { if ( *this != accel ) Ref(accel); return *this; } + bool operator==(const wxAcceleratorTable& accel) const + { return m_refData == accel.m_refData; } // FIXME: this is wrong (VZ) + bool operator!=(const wxAcceleratorTable& accel) const + { return !(*this == accel); } bool Ok() const; void SetHACCEL(WXHACCEL hAccel); @@ -91,9 +49,10 @@ public: // translate the accelerator, return TRUE if done bool Translate(wxWindow *window, WXMSG *msg) const; -}; -WXDLLEXPORT_DATA(extern wxAcceleratorTable) wxNullAcceleratorTable; +private: + DECLARE_DYNAMIC_CLASS(wxAcceleratorTable) +}; #endif // _WX_ACCEL_H_