CHANGED: #1471 Apparently the *root* group needed to be serializes separately, otherwise the parser cannot read it back.

This commit is contained in:
dfighter1985 2012-08-10 17:10:01 +02:00
parent 793455fb7d
commit fc30cff307
5 changed files with 52 additions and 6 deletions

View file

@ -44,6 +44,8 @@ namespace NLGUI
std::string getProperty( const std::string &name ) const;
void setProperty( const std::string &name, const std::string &value );
xmlNodePtr serialize( xmlNodePtr parentNode, const char *type ) const;
xmlNodePtr serializeGroup( xmlNodePtr parentNode, const char *type ) const;
xmlNodePtr serializeSubGroups( xmlNodePtr parentNode ) const;
virtual uint32 getMemory ();

View file

@ -666,6 +666,17 @@ namespace NLGUI
}
xmlNodePtr CInterfaceGroup::serialize( xmlNodePtr parentNode, const char *type ) const
{
xmlNodePtr node = serializeGroup( parentNode, type );
if( node == NULL )
return NULL;
serializeSubGroups( node );
return node;
}
xmlNodePtr CInterfaceGroup::serializeGroup( xmlNodePtr parentNode, const char *type ) const
{
xmlNodePtr node = CCtrlBase::serialize( parentNode, type );
if( node == NULL )
@ -700,6 +711,13 @@ namespace NLGUI
xmlNewProp( node, BAD_CAST "lua_class",
BAD_CAST CWidgetManager::getInstance()->getParser()->getLuaClassAssociation( (CInterfaceGroup*)this ).c_str() );
return node;
}
xmlNodePtr CInterfaceGroup::serializeSubGroups( xmlNodePtr parentNode ) const
{
xmlNodePtr node = parentNode;
std::vector< CInterfaceGroup* >::const_iterator itr;
for( itr = _ChildrenGroups.begin(); itr != _ChildrenGroups.end(); ++itr )
{

View file

@ -240,6 +240,11 @@ namespace GUIEditor
tr( "There was an error while trying to save the project." ) );
return;
}
QMessageBox::information( this,
tr( "Save successful" ),
tr( "Project saved successfully!" ) );
}
void GUIEditorWindow::close()

View file

@ -43,13 +43,21 @@ namespace GUIEditor
return false;
}
if( mg->serialize( root, "root" ) == NULL )
if( mg->serializeGroup( root, "root" ) == NULL )
{
xmlFreeNode( root );
out.close();
return false;
}
if( mg->serializeSubGroups( root ) == NULL )
{
xmlFreeNode( root );
out.close();
return false;
}
level = -1;
serializeTree( root );
@ -61,7 +69,13 @@ namespace GUIEditor
bool WidgetSerializer::serializeTree( _xmlNode *node )
{
out << "<" << node->name;
level++;
std::string tabs;
for( int i = 0; i < level; i++ )
tabs.push_back( '\t' );
out << tabs << "<" << node->name;
xmlAttrPtr prop = node->properties;
while( prop != NULL )
@ -72,12 +86,12 @@ namespace GUIEditor
std::string value =
std::string( reinterpret_cast< const char* >( xmlGetProp( node, BAD_CAST name.c_str() ) ) );
out << " " << name << "=\"" << value << "\"" << std::endl;
out << " " << name << "=\"" << value << "\"" << std::endl << tabs;
prop = prop->next;
}
out << ">" << std::endl;
out << tabs << ">" << std::endl << std::endl;
xmlNodePtr child = node->children;
while( child != NULL )
@ -86,7 +100,9 @@ namespace GUIEditor
child = child->next;
}
out << "</" << node->name << ">" << std::endl;
out << tabs << "</" << node->name << ">" << std::endl << std::endl;
level--;
return true;
}

View file

@ -29,7 +29,11 @@ namespace GUIEditor
class WidgetSerializer
{
public:
WidgetSerializer(){}
WidgetSerializer()
{
level = 0;
}
~WidgetSerializer(){}
void setFile( const std::string &name ){ fileName = name; }
@ -40,6 +44,7 @@ namespace GUIEditor
std::string fileName;
std::ofstream out;
long level;
};
}