// Name: wx/generic/accel.h
// Purpose: wxAcceleratorTable class
// Author: Robert Roebling
-// RCS-ID: $Id$
// Copyright: (c) Robert Roebling
// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
#ifndef _WX_GENERIC_ACCEL_H_
#define _WX_GENERIC_ACCEL_H_
-#ifdef __GNUG__
-#pragma interface "accel.h"
-#endif
-
-class WXDLLEXPORT wxKeyEvent;
+class WXDLLIMPEXP_FWD_CORE wxKeyEvent;
// ----------------------------------------------------------------------------
// wxAcceleratorTable
// ----------------------------------------------------------------------------
-class WXDLLEXPORT wxAcceleratorTable : public wxObject
+class WXDLLIMPEXP_CORE wxAcceleratorTable : public wxObject
{
public:
wxAcceleratorTable();
- wxAcceleratorTable(int n, wxAcceleratorEntry entries[]);
+ wxAcceleratorTable(int n, const wxAcceleratorEntry entries[]);
virtual ~wxAcceleratorTable();
- wxAcceleratorTable(const wxAcceleratorTable& accel)
- { Ref(accel); }
- wxAcceleratorTable& operator=(const wxAcceleratorTable& accel)
- { if ( m_refData != accel.m_refData ) 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;
+ bool Ok() const { return IsOk(); }
+ bool IsOk() const;
void Add(const wxAcceleratorEntry& entry);
void Remove(const wxAcceleratorEntry& entry);
const wxAcceleratorEntry *GetEntry(const wxKeyEvent& event) const;
+protected:
+ // ref counting code
+ virtual wxObjectRefData *CreateRefData() const;
+ virtual wxObjectRefData *CloneRefData(const wxObjectRefData *data) const;
+
private:
DECLARE_DYNAMIC_CLASS(wxAcceleratorTable)
};