use iterators instead of c_str() in wxXmlResource::GetText()

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@54566 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Václav Slavík 2008-07-09 23:05:18 +00:00
parent 1506cc6641
commit 424af7aabf

View File

@ -899,22 +899,21 @@ wxString wxXmlResourceHandler::GetText(const wxString& param, bool translate)
wxXmlNode *parNode = GetParamNode(param); wxXmlNode *parNode = GetParamNode(param);
wxString str1(GetNodeContent(parNode)); wxString str1(GetNodeContent(parNode));
wxString str2; wxString str2;
const wxChar *dt;
wxChar amp_char; // "\\" wasn't translated to "\" prior to 2.5.3.0:
const bool escapeBackslash = (m_resource->CompareVersion(2,5,3,0) >= 0);
// VS: First version of XRC resources used $ instead of & (which is // VS: First version of XRC resources used $ instead of & (which is
// illegal in XML), but later I realized that '_' fits this purpose // illegal in XML), but later I realized that '_' fits this purpose
// much better (because &File means "File with F underlined"). // much better (because &File means "File with F underlined").
if (m_resource->CompareVersion(2,3,0,1) < 0) const wxChar amp_char = (m_resource->CompareVersion(2,3,0,1) < 0)
amp_char = wxT('$'); ? '$' : '_';
else
amp_char = wxT('_');
for (dt = str1.c_str(); *dt; dt++) for ( wxString::const_iterator dt = str1.begin(); dt != str1.end(); ++dt )
{ {
// Remap amp_char to &, map double amp_char to amp_char (for things // Remap amp_char to &, map double amp_char to amp_char (for things
// like "&File..." -- this is illegal in XML, so we use "_File..."): // like "&File..." -- this is illegal in XML, so we use "_File..."):
if (*dt == amp_char) if ( *dt == amp_char )
{ {
if ( *(++dt) == amp_char ) if ( *(++dt) == amp_char )
str2 << amp_char; str2 << amp_char;
@ -922,8 +921,9 @@ wxString wxXmlResourceHandler::GetText(const wxString& param, bool translate)
str2 << wxT('&') << *dt; str2 << wxT('&') << *dt;
} }
// Remap \n to CR, \r to LF, \t to TAB, \\ to \: // Remap \n to CR, \r to LF, \t to TAB, \\ to \:
else if (*dt == wxT('\\')) else if ( *dt == wxT('\\') )
switch (*(++dt)) {
switch ( (*(++dt)).GetValue() )
{ {
case wxT('n'): case wxT('n'):
str2 << wxT('\n'); str2 << wxT('\n');
@ -939,7 +939,7 @@ wxString wxXmlResourceHandler::GetText(const wxString& param, bool translate)
case wxT('\\') : case wxT('\\') :
// "\\" wasn't translated to "\" prior to 2.5.3.0: // "\\" wasn't translated to "\" prior to 2.5.3.0:
if (m_resource->CompareVersion(2,5,3,0) >= 0) if ( escapeBackslash )
{ {
str2 << wxT('\\'); str2 << wxT('\\');
break; break;
@ -950,7 +950,11 @@ wxString wxXmlResourceHandler::GetText(const wxString& param, bool translate)
str2 << wxT('\\') << *dt; str2 << wxT('\\') << *dt;
break; break;
} }
else str2 << *dt; }
else
{
str2 << *dt;
}
} }
if (m_resource->GetFlags() & wxXRC_USE_LOCALE) if (m_resource->GetFlags() & wxXRC_USE_LOCALE)