]> git.saurik.com Git - wxWidgets.git/blame - src/os2/choice.cpp
removed __throws_bad_alloc import, this apparently breaks CW8.3 compilation and...
[wxWidgets.git] / src / os2 / choice.cpp
CommitLineData
0e320a79 1/////////////////////////////////////////////////////////////////////////////
11e62fe6 2// Name: src/os2/choice.cpp
0e320a79 3// Purpose: wxChoice
37f214d5 4// Author: David Webster
0e320a79 5// Modified by:
37f214d5 6// Created: 10/13/99
0e320a79 7// RCS-ID: $Id$
37f214d5 8// Copyright: (c) David Webster
65571936 9// Licence: wxWindows licence
0e320a79
DW
10/////////////////////////////////////////////////////////////////////////////
11
37f214d5
DW
12// For compilers that support precompilation, includes "wx.h".
13#include "wx/wxprec.h"
14
312ebad4
WS
15#if wxUSE_CHOICE
16
37f214d5
DW
17#ifndef WX_PRECOMP
18 #include "wx/choice.h"
19 #include "wx/utils.h"
20 #include "wx/log.h"
a4a16252 21 #include "wx/settings.h"
0e320a79
DW
22#endif
23
37f214d5 24#include "wx/os2/private.h"
0e320a79 25
0e320a79 26IMPLEMENT_DYNAMIC_CLASS(wxChoice, wxControl)
0e320a79 27
584ad2a3
MB
28bool wxChoice::Create(
29 wxWindow* pParent
30, wxWindowID vId
31, const wxPoint& rPos
32, const wxSize& rSize
33, const wxArrayString& asChoices
34, long lStyle
35, const wxValidator& rValidator
36, const wxString& rsName
37)
38{
39 wxCArrayString chs(asChoices);
40
41 return Create(pParent, vId, rPos, rSize, chs.GetCount(), chs.GetStrings(),
42 lStyle, rValidator, rsName);
43}
44
0cf6acbf
DW
45bool wxChoice::Create(
46 wxWindow* pParent
47, wxWindowID vId
48, const wxPoint& rPos
49, const wxSize& rSize
50, int n
51, const wxString asChoices[]
52, long lStyle
0cf6acbf 53, const wxValidator& rValidator
0cf6acbf
DW
54, const wxString& rsName
55)
0e320a79 56{
0cf6acbf
DW
57 long lSstyle;
58
b9b1d6c8
DW
59 if (!CreateControl( pParent
60 ,vId
61 ,rPos
62 ,rSize
63 ,lStyle
b9b1d6c8 64 ,rValidator
b9b1d6c8
DW
65 ,rsName
66 ))
312ebad4 67 return false;
0cf6acbf 68 lSstyle = CBS_DROPDOWNLIST |
5d44b24e
DW
69 WS_TABSTOP |
70 WS_VISIBLE;
0cf6acbf
DW
71
72 if (lStyle & wxCLIP_SIBLINGS )
73 lSstyle |= WS_CLIPSIBLINGS;
74
75 wxASSERT_MSG( !(lStyle & wxCB_DROPDOWN) &&
76 !(lStyle & wxCB_READONLY) &&
77 !(lStyle & wxCB_SIMPLE),
37f214d5
DW
78 wxT("this style flag is ignored by wxChoice, you "
79 "probably want to use a wxComboBox") );
0e320a79 80
0cf6acbf
DW
81 if (!OS2CreateControl( wxT("COMBOBOX")
82 ,lSstyle
83 ))
312ebad4 84 return false;
0e320a79 85
0cf6acbf
DW
86 //
87 // A choice/combobox normally has a white background (or other, depending
88 // on global settings) rather than inheriting the parent's background colour.
89 //
a756f210 90 SetBackgroundColour(wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW));
0934d91c
SN
91
92 // initialize the controls contents
0cf6acbf 93 for (int i = 0; i < n; i++)
37f214d5 94 {
0cf6acbf 95 Append(asChoices[i]);
37f214d5 96 }
0cf6acbf
DW
97 SetSize( rPos.x
98 ,rPos.y
99 ,rSize.x
100 ,rSize.y
101 );
312ebad4 102 return true;
0cf6acbf 103} // end of wxChoice::Create
0e320a79 104
0934d91c
SN
105wxChoice::~wxChoice()
106{
107 Free();
108}
109
37f214d5
DW
110// ----------------------------------------------------------------------------
111// adding/deleting items to/from the list
112// ----------------------------------------------------------------------------
113
0cf6acbf
DW
114int wxChoice::DoAppend(
115 const wxString& rsItem
116)
0e320a79 117{
0cf6acbf 118 int nIndex;
9923c37d 119 LONG nIndexType = 0;
0cf6acbf
DW
120
121 if (m_windowStyle & wxLB_SORT)
122 nIndexType = LIT_SORTASCENDING;
123 else
124 nIndexType = LIT_END;
125 nIndex = (int)::WinSendMsg( GetHwnd()
126 ,LM_INSERTITEM
127 ,(MPARAM)nIndexType
128 ,(MPARAM)rsItem.c_str()
129 );
130 return nIndex;
131} // end of wxChoice::DoAppend
132
aa61d352 133int wxChoice::DoInsert( const wxString& rsItem, unsigned int pos )
243dbf1a
VZ
134{
135 wxCHECK_MSG(!(GetWindowStyle() & wxCB_SORT), -1, wxT("can't insert into sorted list"));
8228b893 136 wxCHECK_MSG(IsValidInsert(pos), -1, wxT("invalid index"));
243dbf1a 137
aa61d352 138 if (pos == GetCount())
33c6ae1d 139 return DoAppend(rsItem);
243dbf1a 140
8228b893
WS
141 int nIndex;
142 LONG nIndexType = 0;
243dbf1a
VZ
143
144 if (m_windowStyle & wxLB_SORT)
145 nIndexType = LIT_SORTASCENDING;
146 else
147 nIndexType = pos;
148 nIndex = (int)::WinSendMsg( GetHwnd()
149 ,LM_INSERTITEM
150 ,(MPARAM)nIndexType
151 ,(MPARAM)rsItem.c_str()
152 );
153 return nIndex;
154} // end of wxChoice::DoInsert
155
aa61d352 156void wxChoice::Delete(unsigned int n)
0e320a79 157{
8228b893 158 wxCHECK_RET( IsValid(n), wxT("invalid item index in wxChoice::Delete") );
0934d91c
SN
159
160 if ( HasClientObjectData() )
161 {
162 delete GetClientObject(n);
163 }
164
0cf6acbf
DW
165 ::WinSendMsg(GetHwnd(), LM_DELETEITEM, (MPARAM)n, (MPARAM)0);
166} // end of wxChoice::Delete
0e320a79
DW
167
168void wxChoice::Clear()
169{
0cf6acbf
DW
170 Free();
171 ::WinSendMsg(GetHwnd(), LM_DELETEALL, (MPARAM)0, (MPARAM)0);
172} // end of wxChoice::Clear
0e320a79 173
37f214d5
DW
174// ----------------------------------------------------------------------------
175// selection
176// ----------------------------------------------------------------------------
177
0e320a79 178int wxChoice::GetSelection() const
0934d91c
SN
179{
180 // if m_lastAcceptedSelection is set, it means that the dropdown is
181 // currently shown and that we want to use the last "permanent" selection
182 // instead of whatever is under the mouse pointer currently
183 //
184 // otherwise, get the selection from the control
185 return m_lastAcceptedSelection == wxID_NONE ? GetCurrentSelection()
186 : m_lastAcceptedSelection;
187}
188
189int wxChoice::GetCurrentSelection() const
0e320a79 190{
0cf6acbf
DW
191 return((int)LONGFROMMR(::WinSendMsg(GetHwnd(), LM_QUERYSELECTION, (MPARAM)LIT_FIRST, (MPARAM)0)));
192} // end of wxChoice::GetSelection
0e320a79 193
0cf6acbf
DW
194void wxChoice::SetSelection(
195 int n
196)
0e320a79 197{
0cf6acbf
DW
198 ::WinSendMsg( GetHwnd()
199 ,LM_SELECTITEM
200 ,(MPARAM)n
201 ,(MPARAM)TRUE
202 );
203} // end of wxChoice::SetSelection
37f214d5
DW
204
205// ----------------------------------------------------------------------------
206// string list functions
207// ----------------------------------------------------------------------------
208
aa61d352 209unsigned int wxChoice::GetCount() const
37f214d5 210{
aa61d352 211 return((unsigned int)LONGFROMMR(::WinSendMsg(GetHwnd(), LM_QUERYITEMCOUNT, (MPARAM)0, (MPARAM)0)));
0cf6acbf 212} // end of wxChoice::GetCount
0e320a79 213
aa61d352 214void wxChoice::SetString(unsigned int n, const wxString& rsStr)
0e320a79 215{
11e62fe6
WS
216 LONG nIndexType = 0;
217 void* pData;
57ff8a87
DW
218
219 if ( m_clientDataItemsType != wxClientData_None )
220 {
221 pData = DoGetItemClientData(n);
222 }
223 else // no client data
224 {
225 pData = NULL;
226 }
dcd307ee 227
e90bc5bf 228 ::WinSendMsg(GetHwnd(), LM_DELETEITEM, (MPARAM)n, 0);
58238121 229
e90bc5bf 230 if (m_windowStyle & wxLB_SORT)
58238121
DW
231 nIndexType = LIT_SORTASCENDING;
232 else
233 nIndexType = LIT_END;
e90bc5bf
DW
234 ::WinSendMsg( GetHwnd()
235 ,LM_INSERTITEM
236 ,(MPARAM)nIndexType
237 ,(MPARAM)rsStr.c_str()
238 );
57ff8a87
DW
239
240 if (pData)
241 {
aa61d352 242 DoSetItemClientData(n, pData);
57ff8a87 243 }
0cf6acbf 244} // end of wxChoice::SetString
dcd307ee 245
aa61d352 246wxString wxChoice::GetString(unsigned int n) const
0e320a79 247{
11e62fe6
WS
248 int nLen = 0;
249 wxString sStr = wxEmptyString;
250 wxChar* zBuf;
0cf6acbf
DW
251
252 nLen = (size_t)LONGFROMMR(::WinSendMsg(GetHwnd(), LM_QUERYITEMTEXTLENGTH, (MPARAM)n, (MPARAM)0));
cfcebdb1 253 if (nLen != LIT_ERROR && nLen > 0)
0cf6acbf 254 {
0fba44b4 255 zBuf = new wxChar[nLen + 1];
0cf6acbf
DW
256 ::WinSendMsg( GetHwnd()
257 ,LM_QUERYITEMTEXT
258 ,MPFROM2SHORT((SHORT)n, (SHORT)nLen)
259 ,(MPARAM)zBuf
260 );
261 sStr = zBuf;
262 delete [] zBuf;
37f214d5 263 }
0cf6acbf
DW
264 return sStr;
265} // end of wxChoice::GetString
0e320a79 266
37f214d5
DW
267// ----------------------------------------------------------------------------
268// client data
269// ----------------------------------------------------------------------------
270
aa61d352 271void wxChoice::DoSetItemClientData(unsigned int n, void* pClientData)
0e320a79 272{
0cf6acbf
DW
273 ::WinSendMsg(GetHwnd(), LM_SETITEMHANDLE, (MPARAM)n, MPFROMP(pClientData));
274} // end of wxChoice::DoSetItemClientData
0e320a79 275
aa61d352 276void* wxChoice::DoGetItemClientData(unsigned int n) const
0e320a79 277{
aa61d352 278 MRESULT rc = ::WinSendMsg(GetHwnd(), LM_QUERYITEMHANDLE, (MPARAM)n, (MPARAM)0);
0cf6acbf 279 return((void*)rc);
aa61d352 280} // end of wxChoice::DoGetItemClientData
0e320a79 281
aa61d352 282void wxChoice::DoSetItemClientObject(unsigned int n, wxClientData* pClientData)
0e320a79 283{
aa61d352 284 DoSetItemClientData(n, pClientData);
0cf6acbf
DW
285} // end of wxChoice::DoSetItemClientObject
286
aa61d352 287wxClientData* wxChoice::DoGetItemClientObject(unsigned int n) const
0e320a79 288{
e6ebb514 289 return (wxClientData *)DoGetItemClientData(n);
0cf6acbf 290} // end of wxChoice::DoGetItemClientObject
37f214d5
DW
291
292// ----------------------------------------------------------------------------
293// wxOS2 specific helpers
294// ----------------------------------------------------------------------------
295
6670f564
WS
296void wxChoice::DoSetSize(int nX,
297 int nY,
298 int nWidth,
299 int WXUNUSED(nHeight),
300 int nSizeFlags)
37f214d5 301{
0cf6acbf 302 //
37f214d5
DW
303 // Ignore height parameter because height doesn't mean 'initially
304 // displayed' height, it refers to the drop-down menu as well. The
77ffb593 305 // wxWidgets interpretation is different; also, getting the size returns
37f214d5
DW
306 // the _displayed_ size (NOT the drop down menu size) so
307 // setting-getting-setting size would not work.
0cf6acbf
DW
308 //
309 wxControl::DoSetSize( nX
310 ,nY
311 ,nWidth
6670f564 312 ,wxDefaultCoord
0cf6acbf
DW
313 ,nSizeFlags
314 );
315} // end of wxChoice::DoSetSize
37f214d5 316
e78c4d50 317wxSize wxChoice::DoGetBestSize() const
37f214d5 318{
0cf6acbf
DW
319 //
320 // Find the widest string
321 //
8228b893
WS
322 int nLineWidth;
323 int nChoiceWidth = 0;
324 int nCx;
325 int nCy;
326 wxFont vFont = (wxFont)GetFont();
327
aa61d352 328 const unsigned int nItems = GetCount();
0cf6acbf 329
aa61d352 330 for (unsigned int i = 0; i < nItems; i++)
8228b893
WS
331 {
332 wxString sStr(GetString(i));
333 GetTextExtent( sStr, &nLineWidth, NULL );
0cf6acbf
DW
334 if (nLineWidth > nChoiceWidth)
335 nChoiceWidth = nLineWidth;
37f214d5
DW
336 }
337
0cf6acbf
DW
338 //
339 // Give it some reasonable default value if there are no strings in the
37f214d5 340 // list
0cf6acbf
DW
341 //
342 if (nChoiceWidth == 0L)
343 nChoiceWidth = 100L;
344
345 //
346 // The combobox should be larger than the widest string
347 //
8228b893 348 wxGetCharSize( GetHWND(), &nCx, &nCy, &vFont );
0cf6acbf
DW
349 nChoiceWidth += 5 * nCx;
350
351 //
37f214d5 352 // Choice drop-down list depends on number of items (limited to 10)
0cf6acbf 353 //
aa61d352
VZ
354 size_t nStrings = nItems == 0 ? 10 : wxMin(10, nItems) + 1;
355 int nChoiceHeight = EDIT_HEIGHT_FROM_CHAR_HEIGHT(nCy) * nStrings;
0cf6acbf 356
aa61d352 357 return wxSize(nChoiceWidth, nChoiceHeight);
0cf6acbf
DW
358} // end of wxChoice::DoGetBestSize
359
360MRESULT wxChoice::OS2WindowProc(
361 WXUINT uMsg
362, WXWPARAM wParam
363, WXLPARAM lParam
364)
37f214d5 365{
0cf6acbf
DW
366 return wxWindow::OS2WindowProc( uMsg
367 ,wParam
368 ,lParam
369 );
370} // end of wxChoice::OS2WindowProc
371
372bool wxChoice::OS2Command(
373 WXUINT uParam
374, WXWORD WXUNUSED(wId)
375)
37f214d5 376{
0cf6acbf 377 if (uParam != LN_SELECT)
37f214d5 378 {
0cf6acbf 379 //
37f214d5 380 // "selection changed" is the only event we're after
0cf6acbf 381 //
312ebad4 382 return false;
37f214d5 383 }
0cf6acbf 384 int n = GetSelection();
37f214d5 385
0cf6acbf
DW
386 if (n > -1)
387 {
388 wxCommandEvent vEvent( wxEVT_COMMAND_CHOICE_SELECTED
389 ,m_windowId
390 );
391
392 vEvent.SetInt(n);
393 vEvent.SetEventObject(this);
0fba44b4 394 vEvent.SetString(GetStringSelection());
0cf6acbf
DW
395 if (HasClientObjectData())
396 vEvent.SetClientObject(GetClientObject(n));
397 else if (HasClientUntypedData())
398 vEvent.SetClientData(GetClientData(n));
399 ProcessCommand(vEvent);
400 }
312ebad4 401 return true;
0cf6acbf 402} // end of wxChoice::OS2Command
0e320a79 403
0cf6acbf
DW
404void wxChoice::Free()
405{
406 if (HasClientObjectData())
407 {
aa61d352 408 const unsigned int nCount = GetCount();
0cf6acbf 409
aa61d352 410 for (unsigned int n = 0; n < nCount; n++)
0cf6acbf
DW
411 {
412 delete GetClientObject(n);
413 }
414 }
312ebad4
WS
415} // end of wxChoice::Free
416
417#endif // wxUSE_CHOICE