// Name: accel.cpp
// Purpose:
// Author: Robert Roebling
-// Id:
+// Id: $id:$
// Copyright: (c) 1998 Robert Roebling
-// Licence: wxWindows licence
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
#ifdef __GNUG__
#include "wx/accel.h"
+#if wxUSE_ACCEL
+
#include <ctype.h>
//-----------------------------------------------------------------------------
class wxAccelRefData: public wxObjectRefData
{
- public:
-
- wxAccelRefData(void);
- ~wxAccelRefData(void);
-
- wxList m_accels;
-};
+public:
+ wxAccelRefData();
-wxAccelRefData::wxAccelRefData(void)
-{
-}
+ wxList m_accels;
+};
-wxAccelRefData::~wxAccelRefData(void)
+wxAccelRefData::wxAccelRefData()
{
- wxNode *node = m_accels.First();
- while (node)
- {
- wxAcceleratorEntry *entry = (wxAcceleratorEntry *)node->Data();
- delete entry;
- node = node->Next();
- }
+ m_accels.DeleteContents( TRUE );
}
//-----------------------------------------------------------------------------
#define M_ACCELDATA ((wxAccelRefData *)m_refData)
IMPLEMENT_DYNAMIC_CLASS(wxAcceleratorTable,wxObject)
-
+
wxAcceleratorTable::wxAcceleratorTable()
{
- m_refData = new wxAccelRefData();
}
wxAcceleratorTable::wxAcceleratorTable( int n, wxAcceleratorEntry entries[] )
{
- m_refData = new wxAccelRefData();
- for (int i = 0; i < n; i++)
- {
- int flag = entries[i].GetFlags();
- int keycode = entries[i].GetKeyCode();
- int command = entries[i].GetCommand();
- if ((keycode >= (int)'A') && (keycode <= (int)'Z')) keycode = (int)tolower( (char)keycode );
- M_ACCELDATA->m_accels.Append( (wxObject*) new wxAcceleratorEntry( flag, keycode, command ) );
- }
+ m_refData = new wxAccelRefData();
+
+ for (int i = 0; i < n; i++)
+ {
+ int flag = entries[i].GetFlags();
+ int keycode = entries[i].GetKeyCode();
+ int command = entries[i].GetCommand();
+ if ((keycode >= (int)'A') && (keycode <= (int)'Z')) keycode = (int)tolower( (char)keycode );
+ M_ACCELDATA->m_accels.Append( new wxAcceleratorEntry( flag, keycode, command ) );
+ }
}
wxAcceleratorTable::~wxAcceleratorTable()
bool wxAcceleratorTable::Ok() const
{
- return (m_refData != NULL);
+ return (m_refData != NULL);
}
int wxAcceleratorTable::GetCommand( wxKeyEvent &event )
{
- wxNode *node = M_ACCELDATA->m_accels.First();
- while (node)
- {
- wxAcceleratorEntry *entry = (wxAcceleratorEntry*)node->Data();
- if ((event.m_keyCode == entry->GetKeyCode()) &&
- (((entry->GetFlags() & wxACCEL_CTRL) == 0) || event.ControlDown()) &&
- (((entry->GetFlags() & wxACCEL_SHIFT) == 0) || event.ShiftDown()) &&
- (((entry->GetFlags() & wxACCEL_ALT) == 0) || event.AltDown() || event.MetaDown()))
- return entry->GetCommand();
- node = node->Next();
- }
-
- return -1;
+ if (!Ok()) return -1;
+
+ wxNode *node = M_ACCELDATA->m_accels.First();
+ while (node)
+ {
+ wxAcceleratorEntry *entry = (wxAcceleratorEntry*)node->Data();
+ if ((event.m_keyCode == entry->GetKeyCode()) &&
+ (((entry->GetFlags() & wxACCEL_CTRL) == 0) || event.ControlDown()) &&
+ (((entry->GetFlags() & wxACCEL_SHIFT) == 0) || event.ShiftDown()) &&
+ (((entry->GetFlags() & wxACCEL_ALT) == 0) || event.AltDown() || event.MetaDown()))
+ {
+ return entry->GetCommand();
+ }
+ node = node->Next();
+ }
+
+ return -1;
}
+#endif