/////////////////////////////////////////////////////////////////////////////
-// Name: accel.cpp
+// Name: msw/accel.cpp
// Purpose: wxAcceleratorTable
// Author: Julian Smart
// Modified by:
// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
-#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
-#pragma implementation "accel.h"
-#endif
+// ============================================================================
+// declarations
+// ============================================================================
+
+// ----------------------------------------------------------------------------
+// headers
+// ----------------------------------------------------------------------------
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
#ifdef __BORLANDC__
-#pragma hdrstop
+ #pragma hdrstop
#endif
+#if wxUSE_ACCEL
+
#ifndef WX_PRECOMP
#include "wx/window.h"
#endif
#include "wx/accel.h"
-#if wxUSE_ACCEL
-
#include "wx/msw/private.h"
+extern WXWORD wxCharCodeWXToMSW(int id, bool *isVirtual);
+
IMPLEMENT_DYNAMIC_CLASS(wxAcceleratorTable, wxObject)
+// ----------------------------------------------------------------------------
+// data defining wxAcceleratorTable
+// ----------------------------------------------------------------------------
+
class WXDLLEXPORT wxAcceleratorRefData: public wxObjectRefData
{
friend class WXDLLEXPORT wxAcceleratorTable;
public:
wxAcceleratorRefData();
- ~wxAcceleratorRefData();
+ virtual ~wxAcceleratorRefData();
inline HACCEL GetHACCEL() const { return m_hAccel; }
protected:
DECLARE_NO_COPY_CLASS(wxAcceleratorRefData)
};
+// ============================================================================
+// implementation
+// ============================================================================
+
+// ----------------------------------------------------------------------------
+// wxAcceleratorRefData
+// ----------------------------------------------------------------------------
+
#define M_ACCELDATA ((wxAcceleratorRefData *)m_refData)
wxAcceleratorRefData::wxAcceleratorRefData()
{
- m_ok = false;
- m_hAccel = 0;
+ m_ok = false;
+ m_hAccel = 0;
}
wxAcceleratorRefData::~wxAcceleratorRefData()
{
- if (m_hAccel)
- {
- DestroyAcceleratorTable((HACCEL) m_hAccel);
- }
- m_hAccel = 0 ;
-}
-
-wxAcceleratorTable::wxAcceleratorTable()
-{
- m_refData = NULL;
+ if (m_hAccel)
+ {
+ DestroyAcceleratorTable((HACCEL) m_hAccel);
+ }
}
-wxAcceleratorTable::~wxAcceleratorTable()
-{
-}
+// ----------------------------------------------------------------------------
+// wxAcceleratorTable
+// ----------------------------------------------------------------------------
// Load from .rc resource
wxAcceleratorTable::wxAcceleratorTable(const wxString& resource)
{
m_refData = new wxAcceleratorRefData;
- HACCEL hAccel =
-#if defined(__WIN32__)
-#ifdef UNICODE
- ::LoadAcceleratorsW(wxGetInstance(), (const wxChar *)resource);
-#else
- ::LoadAcceleratorsA(wxGetInstance(), (const char *)resource);
-#endif
-#else
- ::LoadAccelerators(wxGetInstance(), (const wxChar *)resource);
-#endif
+ HACCEL hAccel = ::LoadAccelerators(wxGetInstance(), resource);
M_ACCELDATA->m_hAccel = hAccel;
- M_ACCELDATA->m_ok = (hAccel != 0);
+ M_ACCELDATA->m_ok = hAccel != 0;
}
-extern int wxCharCodeWXToMSW(int id, bool *isVirtual);
-
// Create from an array
wxAcceleratorTable::wxAcceleratorTable(int n, const wxAcceleratorEntry entries[])
{
bool isVirtual;
- WORD key = (WORD)wxCharCodeWXToMSW(entries[i].GetKeyCode(), &isVirtual);
+ WORD key = wxCharCodeWXToMSW(entries[i].GetKeyCode(), &isVirtual);
if (isVirtual)
fVirt |= FVIRTKEY;
arr[i].fVirt = fVirt;
arr[i].key = key;
- arr[i].cmd = entries[i].GetCommand();
+ arr[i].cmd = (WORD)entries[i].GetCommand();
}
M_ACCELDATA->m_hAccel = ::CreateAcceleratorTable(arr, n);
M_ACCELDATA->m_ok = (M_ACCELDATA->m_hAccel != 0);
}
+bool wxAcceleratorTable::operator==(const wxAcceleratorTable& accel) const
+{
+ const wxAcceleratorRefData *
+ accelData = (wxAcceleratorRefData *)accel.m_refData;
+
+ return m_refData ? (accelData &&
+ M_ACCELDATA->m_hAccel == accelData->m_hAccel)
+ : !accelData;
+}
+
bool wxAcceleratorTable::Ok() const
{
return (M_ACCELDATA && (M_ACCELDATA->m_ok));
bool wxAcceleratorTable::Translate(wxWindow *window, WXMSG *wxmsg) const
{
+#if 0
+ // calling TranslateAccelerator() with child window doesn't do anything so
+ // it's probably a bug
+ wxASSERT_MSG( window->IsTopLevel(),
+ _T("TranslateAccelerator() needs a top level window") );
+#endif
+
MSG *msg = (MSG *)wxmsg;
return Ok() && ::TranslateAccelerator(GetHwndOf(window), GetHaccel(), msg);
}
-#endif
+#endif // wxUSE_ACCEL
+