X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/12d9e30820444b48882ab9e29139611b99a84495..3d104ec3570c714e770784003d6eafe9f9226d9a:/contrib/utils/wxrcedit/xmlhelpr.cpp diff --git a/contrib/utils/wxrcedit/xmlhelpr.cpp b/contrib/utils/wxrcedit/xmlhelpr.cpp index c5a56f854e..a8fa0886af 100644 --- a/contrib/utils/wxrcedit/xmlhelpr.cpp +++ b/contrib/utils/wxrcedit/xmlhelpr.cpp @@ -29,7 +29,7 @@ wxXmlNode *XmlFindNodeSimple(wxXmlNode *parent, const wxString& param) if (param.IsEmpty()) return parent; wxXmlNode *n = parent->GetChildren(); - + while (n) { if (n->GetType() == wxXML_ELEMENT_NODE && n->GetName() == param) @@ -55,25 +55,42 @@ wxXmlNode *XmlFindNode(wxXmlNode *parent, const wxString& path) -void XmlWriteValue(wxXmlNode *parent, const wxString& name, const wxString& value) +wxXmlNode *XmlCreateNode(wxXmlNode *parent, const wxString& name) { - wxXmlNode *n = XmlFindNode(parent, name); - if (n == NULL) + wxXmlNode *n; + wxString nm; + + wxStringTokenizer tkn(name, _T("/")); + n = parent; + while (tkn.HasMoreTokens()) { - wxString pname = name.BeforeLast(_T('/')); - if (pname.IsEmpty()) pname = name; - wxXmlNode *p = XmlFindNode(parent, pname); - if (p == NULL) p = parent; - n = new wxXmlNode(wxXML_ELEMENT_NODE, name.AfterLast(_T('/'))); - p->AddChild(n); - n->AddChild(new wxXmlNode(wxXML_TEXT_NODE, wxEmptyString)); + parent = n; + nm = tkn.GetNextToken(); + n = XmlFindNodeSimple(parent, nm); + if (n) continue; + + // n == NULL: + n = new wxXmlNode(wxXML_ELEMENT_NODE, nm); + parent->AddChild(n); } - + n->AddChild(new wxXmlNode(wxXML_TEXT_NODE, wxEmptyString)); + + return n; +} + + + +void XmlWriteValue(wxXmlNode *parent, const wxString& name, const wxString& value) +{ + wxXmlNode *n = XmlFindNode(parent, name); + if (n == NULL) + n = XmlCreateNode(parent, name); + n = n->GetChildren(); - + while (n) { - if (n->GetType() == wxXML_TEXT_NODE || + if (n->GetType() == wxXML_TEXT_NODE || n->GetType() == wxXML_CDATA_SECTION_NODE) { n->SetContent(value); @@ -90,10 +107,10 @@ wxString XmlReadValue(wxXmlNode *parent, const wxString& name) wxXmlNode *n = XmlFindNode(parent, name); if (n == NULL) return wxEmptyString; n = n->GetChildren(); - + while (n) { - if (n->GetType() == wxXML_TEXT_NODE || + if (n->GetType() == wxXML_TEXT_NODE || n->GetType() == wxXML_CDATA_SECTION_NODE) return n->GetContent(); n = n->GetNext();