]> git.saurik.com Git - wxWidgets.git/blame_incremental - src/msw/accel.cpp
Committing in .
[wxWidgets.git] / src / msw / accel.cpp
... / ...
CommitLineData
1/////////////////////////////////////////////////////////////////////////////
2// Name: accel.cpp
3// Purpose: wxAcceleratorTable
4// Author: Julian Smart
5// Modified by:
6// Created: 04/01/98
7// RCS-ID: $Id$
8// Copyright: (c) Julian Smart
9// Licence: wxWindows licence
10/////////////////////////////////////////////////////////////////////////////
11
12#ifdef __GNUG__
13#pragma implementation "accel.h"
14#endif
15
16// For compilers that support precompilation, includes "wx.h".
17#include "wx/wxprec.h"
18
19#ifdef __BORLANDC__
20#pragma hdrstop
21#endif
22
23#ifndef WX_PRECOMP
24#include <stdio.h>
25#include "wx/setup.h"
26#include "wx/window.h"
27#endif
28
29#include "wx/msw/accel.h"
30
31#include "wx/msw/private.h"
32
33IMPLEMENT_DYNAMIC_CLASS(wxAcceleratorTable, wxObject)
34
35class WXDLLEXPORT wxAcceleratorRefData: public wxObjectRefData
36{
37 friend class WXDLLEXPORT wxAcceleratorTable;
38public:
39 wxAcceleratorRefData();
40 ~wxAcceleratorRefData();
41
42 inline HACCEL GetHACCEL() const { return m_hAccel; }
43protected:
44 HACCEL m_hAccel;
45 bool m_ok;
46};
47
48#define M_ACCELDATA ((wxAcceleratorRefData *)m_refData)
49
50wxAcceleratorRefData::wxAcceleratorRefData()
51{
52 m_ok = FALSE;
53 m_hAccel = 0;
54}
55
56wxAcceleratorRefData::~wxAcceleratorRefData()
57{
58 if (m_hAccel)
59 {
60 // This function not available in WIN16
61#if !defined(__WIN16__) && !defined(__TWIN32__)
62 DestroyAcceleratorTable((HACCEL) m_hAccel);
63#endif
64 }
65 m_hAccel = 0 ;
66}
67
68wxAcceleratorTable::wxAcceleratorTable()
69{
70 m_refData = NULL;
71}
72
73wxAcceleratorTable::~wxAcceleratorTable()
74{
75}
76
77// Load from .rc resource
78wxAcceleratorTable::wxAcceleratorTable(const wxString& resource)
79{
80 m_refData = new wxAcceleratorRefData;
81
82 HACCEL hAccel =
83#if defined(__WIN32__) && !defined(__TWIN32__)
84#ifdef UNICODE
85 ::LoadAcceleratorsW(wxGetInstance(), (const wxChar *)resource);
86#else
87 ::LoadAcceleratorsA(wxGetInstance(), (const char *)resource);
88#endif
89#else
90 ::LoadAccelerators(wxGetInstance(), (const wxChar *)resource);
91#endif
92 M_ACCELDATA->m_hAccel = hAccel;
93 M_ACCELDATA->m_ok = (hAccel != 0);
94}
95
96extern int wxCharCodeWXToMSW(int id, bool *isVirtual);
97
98// Create from an array
99#if !defined(__WIN16__) && !defined(__TWIN32__) && !defined(__WXWINE__)
100wxAcceleratorTable::wxAcceleratorTable(int n, const wxAcceleratorEntry entries[])
101{
102 // Not available in WIN16
103 m_refData = new wxAcceleratorRefData;
104
105 ACCEL* arr = new ACCEL[n];
106 int i;
107 for (i = 0; i < n; i++)
108 {
109 BYTE fVirt = 0;
110 if (entries[i].m_flags & wxACCEL_ALT)
111 fVirt |= FALT;
112 if (entries[i].m_flags & wxACCEL_SHIFT)
113 fVirt |= FSHIFT;
114 if (entries[i].m_flags & wxACCEL_CTRL)
115 fVirt |= FCONTROL;
116
117 bool isVirtual;
118 WORD key = wxCharCodeWXToMSW(entries[i].m_keyCode, & isVirtual);
119 fVirt |= FVIRTKEY;
120
121 WORD cmd = entries[i].m_command;
122
123 arr[i].fVirt = fVirt;
124 arr[i].key = key;
125 arr[i].cmd = cmd;
126 }
127
128 M_ACCELDATA->m_hAccel = ::CreateAcceleratorTable(arr, n);
129 delete[] arr;
130
131 M_ACCELDATA->m_ok = (M_ACCELDATA->m_hAccel != 0);
132}
133#else // Win16
134wxAcceleratorTable::wxAcceleratorTable(int WXUNUSED(n), const wxAcceleratorEntry WXUNUSED(entries)[])
135{
136 // No, we simply gracefully degrade; we don't expect the
137 // developer to pepper their code with #ifdefs just for this.
138 // wxFAIL_MSG("not implemented");
139}
140#endif // Win32/16
141
142bool wxAcceleratorTable::Ok() const
143{
144 return (M_ACCELDATA && (M_ACCELDATA->m_ok));
145}
146
147void wxAcceleratorTable::SetHACCEL(WXHACCEL hAccel)
148{
149 if (!M_ACCELDATA)
150 m_refData = new wxAcceleratorRefData;
151
152 M_ACCELDATA->m_hAccel = (HACCEL) hAccel;
153}
154
155WXHACCEL wxAcceleratorTable::GetHACCEL() const
156{
157 if (!M_ACCELDATA)
158 return 0;
159 return (WXHACCEL) M_ACCELDATA->m_hAccel;
160}
161
162bool wxAcceleratorTable::Translate(wxWindow *window, WXMSG *wxmsg) const
163{
164 MSG *msg = (MSG *)wxmsg;
165
166 return Ok() && ::TranslateAccelerator(GetHwndOf(window), GetHaccel(), msg);
167}
168