X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/8576d6a4546855a1358c84e45e1bc4f1bc39e496..892aeafc2a0212b4c3bebcaddd96a42cdd307afd:/contrib/src/xml/xh_toolb.cpp?ds=sidebyside diff --git a/contrib/src/xml/xh_toolb.cpp b/contrib/src/xml/xh_toolb.cpp index d4c2887621..87c4d2eb69 100644 --- a/contrib/src/xml/xh_toolb.cpp +++ b/contrib/src/xml/xh_toolb.cpp @@ -38,67 +38,71 @@ wxToolBarXmlHandler::wxToolBarXmlHandler() wxObject *wxToolBarXmlHandler::DoCreateResource() { - if (m_Node->GetName() == _T("tool")) + if (m_Class == wxT("tool")) { - wxCHECK_MSG(m_Toolbar, NULL, _T("Incorrect syntax of XML resource: tool not within a toolbar!")); - m_Toolbar->AddTool(GetID(), - GetBitmap(_T("bitmap")), - GetBitmap(_T("bitmap2")), - GetBool(_T("toggle")), + wxCHECK_MSG(m_Toolbar, NULL, wxT("Incorrect syntax of XML resource: tool not within a toolbar!")); + m_Toolbar->AddTool(GetID(), + GetBitmap(wxT("bitmap")), + GetBitmap(wxT("bitmap2")), + GetBool(wxT("toggle")), GetPosition().x, GetPosition().y, NULL, - GetText(_T("tooltip")), - GetText(_T("longhelp"))); + GetText(wxT("tooltip")), + GetText(wxT("longhelp"))); return m_Toolbar; // must return non-NULL } - else if (m_Node->GetName() == _T("separator")) + else if (m_Class == wxT("separator")) { - wxCHECK_MSG(m_Toolbar, NULL, _T("Incorrect syntax of XML resource: separator not within a toolbar!")); + wxCHECK_MSG(m_Toolbar, NULL, wxT("Incorrect syntax of XML resource: separator not within a toolbar!")); m_Toolbar->AddSeparator(); return m_Toolbar; // must return non-NULL } - else /**/ + else /**/ { + int style = GetStyle(wxT("style"), wxNO_BORDER | wxTB_HORIZONTAL); +#ifdef __WXMSW__ + if (!(style & wxNO_BORDER)) style |= wxNO_BORDER; +#endif wxToolBar *toolbar = new wxToolBar(m_ParentAsWindow, - GetID(), - GetPosition(), - GetSize(), - GetStyle(), - GetName()); + GetID(), + GetPosition(), + GetSize(), + style, + GetName()); - wxSize bmpsize = GetSize(_T("bitmapsize")); + wxSize bmpsize = GetSize(wxT("bitmapsize")); if (!(bmpsize == wxDefaultSize)) toolbar->SetToolBitmapSize(bmpsize); - wxSize margins = GetSize(_T("margins")); + wxSize margins = GetSize(wxT("margins")); if (!(margins == wxDefaultSize)) toolbar->SetMargins(margins.x, margins.y); - long packing = GetLong(_T("packing"), -1); + long packing = GetLong(wxT("packing"), -1); if (packing != -1) toolbar->SetToolPacking(packing); - long separation = GetLong(_T("separation"), -1); + long separation = GetLong(wxT("separation"), -1); if (separation != -1) toolbar->SetToolSeparation(separation); - - wxXmlNode *children_node = GetParamNode(_T("children")); + wxXmlNode *children_node = GetParamNode(wxT("object")); if (children_node == NULL) return toolbar; m_IsInside = TRUE; m_Toolbar = toolbar; - wxXmlNode *n = children_node->GetChildren(); + wxXmlNode *n = children_node; while (n) { - if (n->GetType() == wxXML_ELEMENT_NODE) + if (n->GetType() == wxXML_ELEMENT_NODE && + n->GetName() == wxT("object")) { wxObject *created = CreateResFromNode(n, toolbar, NULL); wxControl *control = wxDynamicCast(created, wxControl); - if (n->GetName() != _T("tool") && - n->GetName() != _T("separator") && + if (IsOfClass(n, wxT("tool")) && + IsOfClass(n, wxT("separator")) && control != NULL) toolbar->AddControl(control); } @@ -117,9 +121,9 @@ wxObject *wxToolBarXmlHandler::DoCreateResource() bool wxToolBarXmlHandler::CanHandle(wxXmlNode *node) { - return ((!m_IsInside && node->GetName() == _T("toolbar")) || - (m_IsInside && node->GetName() == _T("tool")) || - (m_IsInside && node->GetName() == _T("separator"))); + return ((!m_IsInside && IsOfClass(node, wxT("wxToolBar"))) || + (m_IsInside && IsOfClass(node, wxT("tool"))) || + (m_IsInside && IsOfClass(node, wxT("separator")))); } #endif