-rw-r--r-- | libopie/xmltree.cc | 42 |
1 files changed, 17 insertions, 25 deletions
diff --git a/libopie/xmltree.cc b/libopie/xmltree.cc index d5ce74a..3d03cc6 100644 --- a/libopie/xmltree.cc +++ b/libopie/xmltree.cc @@ -19,3 +19,3 @@ - +#include <qpe/stringutil.h> #include <opie/xmltree.h> @@ -26,23 +26,2 @@ -namespace -{ - -/** - Encode an attribute value upon saving. - replaces '"' with """ - replaces '<' with "<" - replaces '&' with "&" - replaces '>' with ">" -*/ -QString encodeAttr( const QString& str ) -{ - QString encAttr( str ); // cause of the const parameter - encAttr = encAttr.replace( QRegExp( "[<]" ), "<" ); - encAttr = encAttr.replace( QRegExp( "[>]" ), ">" ); - encAttr = encAttr.replace( QRegExp( "[\"]" ), """ ); - encAttr = encAttr.replace( QRegExp( "[&]" ), "&" ); - return encAttr; -} - -} @@ -112,3 +91,14 @@ void XMLElement::insertAfter( XMLElement *newChild, XMLElement *refChild ) } - +QString XMLElement::attribute(const QString &attr )const +{ + if ( !m_attributes.contains( attr ) ) + return QString::null; + AttributeMap::ConstIterator it = m_attributes.find( attr ); + return it.data(); +} +void XMLElement::setAttribute(const QString &attr, const QString &value ) +{ + m_attributes.remove( attr ); + m_attributes.insert( attr, value ); +} void XMLElement::insertBefore( XMLElement *newChild, XMLElement *refChild ) @@ -165,3 +155,3 @@ void XMLElement::save( QTextStream &s, uint indent ) { - s << encodeAttr( m_value ); + s << Qtopia::escapeString( m_value ); return; @@ -181,3 +171,3 @@ void XMLElement::save( QTextStream &s, uint indent ) { - s << it.key() << "=\"" << encodeAttr( it.data() ) << "\""; + s << it.key() << "=\"" << Qtopia::escapeString( it.data() ) << "\""; s << " "; @@ -326 +316,3 @@ XMLElement *XMLElement::load( const QString &fileName ) } + + |