#7829 AppEnum : Make sure text used in XML serialization is trimmed

If the AppEnum text used to serialize the AppEnum contains whitespace at start or end, the serialization will fail and the AppEnum value will end up with a default value. 

This commit will make sure that this field is always trimmed ( text coming from the application, from xml parsing, text from scripting).
This commit is contained in:
Magne Sjaastad 2021-06-29 20:41:50 +02:00
parent 4e45f397e8
commit 3af8d32928

View File

@ -191,7 +191,10 @@ private:
public: public:
void addItem( T enumVal, const QString& text, QString uiText ) void addItem( T enumVal, const QString& text, QString uiText )
{ {
instance()->m_mapping.push_back( Triplet( enumVal, text, uiText ) ); // Make sure the text is trimmed, as this text is streamed to XML and will be trimmed when read back from
// XML text
// https://github.com/OPM/ResInsight/issues/7829
instance()->m_mapping.push_back( Triplet( enumVal, text.trimmed(), uiText ) );
} }
static EnumMapper* instance() static EnumMapper* instance()
@ -244,7 +247,9 @@ private:
size_t idx; size_t idx;
for ( idx = 0; idx < m_mapping.size(); ++idx ) for ( idx = 0; idx < m_mapping.size(); ++idx )
{ {
if ( text == m_mapping[idx].m_text ) // Make sure the text parsed from a text stream is trimmed
// https://github.com/OPM/ResInsight/issues/7829
if ( text.trimmed() == m_mapping[idx].m_text )
{ {
value = m_mapping[idx].m_enumVal; value = m_mapping[idx].m_enumVal;
return true; return true;
@ -349,7 +354,10 @@ QTextStream& operator>>( QTextStream& str, caf::AppEnum<T>& appEnum )
{ {
QString text; QString text;
str >> text; str >> text;
appEnum.setFromText( text );
// Make sure the text parsed from a text stream is trimmed
// https://github.com/OPM/ResInsight/issues/7829
appEnum.setFromText( text.trimmed() );
return str; return str;
} }