git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@14548
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
const wxAcceleratorEntry *GetEntry(const wxKeyEvent& event) const;
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)
};
private:
DECLARE_DYNAMIC_CLASS(wxAcceleratorTable)
};
class wxAccelRefData : public wxObjectRefData
{
public:
class wxAccelRefData : public wxObjectRefData
{
public:
- wxAccelRefData() { m_accels.DeleteContents(TRUE); }
+ wxAccelRefData()
+ {
+ m_accels.DeleteContents(TRUE);
+ }
+
+ wxAccelRefData(const wxAccelRefData& data)
+ {
+ m_accels.DeleteContents(TRUE);
+ m_accels = data.m_accels;
+ }
// macro which can be used to access wxAccelRefData from wxAcceleratorTable
#define M_ACCELDATA ((wxAccelRefData *)m_refData)
// macro which can be used to access wxAccelRefData from wxAcceleratorTable
#define M_ACCELDATA ((wxAccelRefData *)m_refData)
// ============================================================================
// implementation
// ============================================================================
// ============================================================================
// implementation
// ============================================================================
void wxAcceleratorTable::Add(const wxAcceleratorEntry& entry)
{
void wxAcceleratorTable::Add(const wxAcceleratorEntry& entry)
{
if ( !m_refData )
{
m_refData = new wxAccelRefData;
if ( !m_refData )
{
m_refData = new wxAccelRefData;
void wxAcceleratorTable::Remove(const wxAcceleratorEntry& entry)
{
void wxAcceleratorTable::Remove(const wxAcceleratorEntry& entry)
{
wxAccelList::Node *node = M_ACCELDATA->m_accels.GetFirst();
while ( node )
{
wxAccelList::Node *node = M_ACCELDATA->m_accels.GetFirst();
while ( node )
{
return entry ? entry->GetCommand() : -1;
}
return entry ? entry->GetCommand() : -1;
}
+wxObjectRefData *wxAcceleratorTable::CreateRefData() const
+{
+ return new wxAccelRefData;
+}
+
+wxObjectRefData *wxAcceleratorTable::CloneRefData(const wxObjectRefData *data) const
+{
+ return new wxAccelRefData(*(wxAccelRefData *)data);
+}
+