]> git.saurik.com Git - wxWidgets.git/blame - src/xrc/xh_combo.cpp
[ 1563875 ] wxTreeCtrl::FindItem asserts when item not found
[wxWidgets.git] / src / xrc / xh_combo.cpp
CommitLineData
78d14f80 1/////////////////////////////////////////////////////////////////////////////
88a7a4e1 2// Name: src/xrc/xh_combo.cpp
5f6475c1 3// Purpose: XRC resource for wxComboBox
78d14f80
VS
4// Author: Bob Mitchell
5// Created: 2000/03/21
6// RCS-ID: $Id$
7// Copyright: (c) 2000 Bob Mitchell and Verant Interactive
8// Licence: wxWindows licence
9/////////////////////////////////////////////////////////////////////////////
f80ea77b 10
78d14f80
VS
11// For compilers that support precompilation, includes "wx.h".
12#include "wx/wxprec.h"
13
14#ifdef __BORLANDC__
15 #pragma hdrstop
16#endif
17
621be1ec 18#if wxUSE_XRC && wxUSE_COMBOBOX
a1e4ec87 19
78d14f80 20#include "wx/xrc/xh_combo.h"
88a7a4e1
WS
21
22#ifndef WX_PRECOMP
23 #include "wx/intl.h"
a5bbd1cc 24 #include "wx/combobox.h"
88a7a4e1
WS
25#endif
26
854e189f
VS
27IMPLEMENT_DYNAMIC_CLASS(wxComboBoxXmlHandler, wxXmlResourceHandler)
28
f80ea77b 29wxComboBoxXmlHandler::wxComboBoxXmlHandler()
a5bbd1cc
WS
30 :wxXmlResourceHandler()
31 ,m_insideBox(false)
78d14f80 32{
544fee32
VS
33 XRC_ADD_STYLE(wxCB_SIMPLE);
34 XRC_ADD_STYLE(wxCB_SORT);
35 XRC_ADD_STYLE(wxCB_READONLY);
36 XRC_ADD_STYLE(wxCB_DROPDOWN);
78d14f80
VS
37 AddWindowStyles();
38}
39
40wxObject *wxComboBoxXmlHandler::DoCreateResource()
f80ea77b 41{
78d14f80
VS
42 if( m_class == wxT("wxComboBox"))
43 {
44 // find the selection
45 long selection = GetLong( wxT("selection"), -1 );
46
47 // need to build the list of strings from children
f80ea77b 48 m_insideBox = true;
544fee32 49 CreateChildrenPrivately(NULL, GetParamNode(wxT("content")));
78d14f80 50 wxString *strings = (wxString *) NULL;
544fee32 51 if (strList.GetCount() > 0)
78d14f80
VS
52 {
53 strings = new wxString[strList.GetCount()];
54 int count = strList.GetCount();
544fee32 55 for (int i = 0; i < count; i++)
78d14f80
VS
56 strings[i]=strList[i];
57 }
58
544fee32 59 XRC_MAKE_INSTANCE(control, wxComboBox)
78d14f80 60
544fee32 61 control->Create(m_parentAsWindow,
f2588180
VS
62 GetID(),
63 GetText(wxT("value")),
64 GetPosition(), GetSize(),
65 strList.GetCount(),
66 strings,
67 GetStyle(),
68 wxDefaultValidator,
69 GetName());
78d14f80 70
544fee32
VS
71 if (selection != -1)
72 control->SetSelection(selection);
78d14f80
VS
73
74 SetupWindow(control);
75
544fee32
VS
76 if (strings != NULL)
77 delete[] strings;
f80ea77b 78 strList.Clear(); // dump the strings
78d14f80
VS
79
80 return control;
81 }
82 else
83 {
84 // on the inside now.
85 // handle <item>Label</item>
86
87 // add to the list
74c107ba
VS
88 wxString str = GetNodeContent(m_node);
89 if (m_resource->GetFlags() & wxXRC_USE_LOCALE)
d4a724d4 90 str = wxGetTranslation(str, m_resource->GetDomain());
74c107ba 91 strList.Add(str);
78d14f80
VS
92
93 return NULL;
94 }
78d14f80
VS
95}
96
78d14f80
VS
97bool wxComboBoxXmlHandler::CanHandle(wxXmlNode *node)
98{
99 return (IsOfClass(node, wxT("wxComboBox")) ||
544fee32 100 (m_insideBox && node->GetName() == wxT("item")));
78d14f80
VS
101}
102
621be1ec 103#endif // wxUSE_XRC && wxUSE_COMBOBOX