/////////////////////////////////////////////////////////////////////////////
-// Name: accel.h
+// Name: wx/msw/accel.h
// Purpose: wxAcceleratorTable class
// Author: Julian Smart
// Modified by:
// Created: 31/7/98
// RCS-ID: $Id$
// Copyright: (c) Julian Smart
-// Licence: wxWindows licence
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
#ifndef _WX_ACCEL_H_
#define _WX_ACCEL_H_
-#ifdef __GNUG__
-#pragma interface "accel.h"
-#endif
-
-#include "wx/object.h"
-
-class WXDLLEXPORT wxAcceleratorTable;
-
-// 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
-
-class WXDLLEXPORT wxAcceleratorEntry
-{
-public:
- wxAcceleratorEntry(int flags = 0, int keyCode = 0, int cmd = 0)
- {
- m_flags = flags; m_keyCode = keyCode; m_command = cmd;
- }
-
- inline void Set(int flags, int keyCode, int cmd)
- { m_flags = flags; m_keyCode = keyCode; m_command = cmd; }
-
- inline int GetFlags() const { return m_flags; }
- inline int GetKeyCode() const { return m_keyCode; }
- inline int GetCommand() const { return m_command; }
+class WXDLLIMPEXP_CORE wxWindow;
- 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
+class WXDLLEXPORT wxAcceleratorTable : public wxObject
{
-DECLARE_DYNAMIC_CLASS(wxAcceleratorTable)
public:
- wxAcceleratorTable();
- wxAcceleratorTable(const wxString& resource); // Load from .rc resource
- wxAcceleratorTable(int n, wxAcceleratorEntry entries[]); // Load from array
+ // default ctor
+ wxAcceleratorTable() { }
- // Copy constructors
- inline wxAcceleratorTable(const wxAcceleratorTable& accel) { Ref(accel); }
- inline wxAcceleratorTable(const wxAcceleratorTable* accel) { if (accel) Ref(*accel); }
+ // load from .rc resource (Windows specific)
+ wxAcceleratorTable(const wxString& resource);
- ~wxAcceleratorTable();
+ // initialize from array
+ wxAcceleratorTable(int n, const wxAcceleratorEntry entries[]);
- inline wxAcceleratorTable& operator = (const wxAcceleratorTable& accel) { if (*this == accel) return (*this); Ref(accel); return *this; }
- inline bool operator == (const wxAcceleratorTable& accel) { return m_refData == accel.m_refData; }
- inline bool operator != (const wxAcceleratorTable& accel) { return m_refData != accel.m_refData; }
+ bool operator==(const wxAcceleratorTable& accel) const;
+ bool operator!=(const wxAcceleratorTable& accel) const
+ { return !(*this == accel); }
- bool Ok(void) const;
+ bool Ok() const { return IsOk(); }
+ bool IsOk() const;
void SetHACCEL(WXHACCEL hAccel);
WXHACCEL GetHACCEL() const;
-};
-WXDLLEXPORT_DATA(extern wxAcceleratorTable) wxNullAcceleratorTable;
+ // translate the accelerator, return true if done
+ bool Translate(wxWindow *window, WXMSG *msg) const;
+
+private:
+ DECLARE_DYNAMIC_CLASS(wxAcceleratorTable)
+};
#endif
// _WX_ACCEL_H_