]> git.saurik.com Git - wxWidgets.git/blame - include/wx/combobox.h
Don't cache incorrect length in wxString::assign(char*, size_t).
[wxWidgets.git] / include / wx / combobox.h
CommitLineData
1e6feb95
VZ
1///////////////////////////////////////////////////////////////////////////////
2// Name: wx/combobox.h
3// Purpose: wxComboBox declaration
4// Author: Vadim Zeitlin
5// Modified by:
6// Created: 24.12.00
7// RCS-ID: $Id$
77ffb593 8// Copyright: (c) 1996-2000 wxWidgets team
65571936 9// Licence: wxWindows licence
1e6feb95
VZ
10///////////////////////////////////////////////////////////////////////////////
11
34138703
JS
12#ifndef _WX_COMBOBOX_H_BASE_
13#define _WX_COMBOBOX_H_BASE_
c801d85f 14
1e6feb95
VZ
15#include "wx/defs.h"
16
83beee57
RR
17#if wxUSE_COMBOBOX
18
53a2db12 19extern WXDLLIMPEXP_DATA_CORE(const char) wxComboBoxNameStr[];
1e6feb95
VZ
20
21// ----------------------------------------------------------------------------
22// wxComboBoxBase: this interface defines the methods wxComboBox must implement
23// ----------------------------------------------------------------------------
24
25#include "wx/ctrlsub.h"
0ec1179b 26#include "wx/textentry.h"
1e6feb95 27
53a2db12 28class WXDLLIMPEXP_CORE wxComboBoxBase : public wxItemContainer,
8bd9fa33 29 public wxTextEntry
1e6feb95
VZ
30{
31public:
f7dfb0b5 32 // override these methods to disambiguate between two base classes versions
0ec1179b
VZ
33 virtual void Clear()
34 {
35 wxTextEntry::Clear();
36 wxItemContainer::Clear();
37 }
38
36a96421
VZ
39 // IsEmpty() is ambiguous because we inherit it from both wxItemContainer
40 // and wxTextEntry, and even if defined it here to help the compiler with
41 // choosing one of them, it would still be confusing for the human users of
42 // this class. So instead define the clearly named methods below and leave
43 // IsEmpty() ambiguous to trigger a compilation error if it's used.
44 bool IsListEmpty() const { return wxItemContainer::IsEmpty(); }
45 bool IsTextEmpty() const { return wxTextEntry::IsEmpty(); }
f7dfb0b5 46
0ec1179b
VZ
47 // also bring in GetSelection() versions of both base classes in scope
48 //
49 // NB: GetSelection(from, to) could be already implemented in wxTextEntry
50 // but still make it pure virtual because for some platforms it's not
51 // implemented there and also because the derived class has to override
52 // it anyhow to avoid ambiguity with the other GetSelection()
53 virtual int GetSelection() const = 0;
54 virtual void GetSelection(long *from, long *to) const = 0;
150e31d2 55
6dd0883d
SN
56 virtual void Popup() { wxFAIL_MSG( wxT("Not implemented") ); }
57 virtual void Dismiss() { wxFAIL_MSG( wxT("Not implemented") ); }
d1d1f817 58
c63312c4
VZ
59 // may return value different from GetSelection() when the combobox
60 // dropdown is shown and the user selected, but not yet accepted, a value
61 // different from the old one in it
62 virtual int GetCurrentSelection() const { return GetSelection(); }
1e6feb95
VZ
63};
64
65// ----------------------------------------------------------------------------
66// include the platform-dependent header defining the real class
67// ----------------------------------------------------------------------------
68
69#if defined(__WXUNIVERSAL__)
70 #include "wx/univ/combobox.h"
71#elif defined(__WXMSW__)
72 #include "wx/msw/combobox.h"
2049ba38 73#elif defined(__WXMOTIF__)
1e6feb95 74 #include "wx/motif/combobox.h"
1be7a35c 75#elif defined(__WXGTK20__)
1e6feb95 76 #include "wx/gtk/combobox.h"
1be7a35c
MR
77#elif defined(__WXGTK__)
78 #include "wx/gtk1/combobox.h"
34138703 79#elif defined(__WXMAC__)
ef0e9220 80 #include "wx/osx/combobox.h"
421a8431
DE
81#elif defined(__WXCOCOA__)
82 #include "wx/cocoa/combobox.h"
1777b9bb 83#elif defined(__WXPM__)
1e6feb95 84 #include "wx/os2/combobox.h"
c801d85f
KB
85#endif
86
1e6feb95
VZ
87#endif // wxUSE_COMBOBOX
88
0ec1179b 89#endif // _WX_COMBOBOX_H_BASE_