remove some ugly hacks

This commit is contained in:
Chris Forbes
2010-03-16 19:55:43 +13:00
parent 7af5ef2a65
commit 6855732954
2 changed files with 41 additions and 54 deletions

View File

@@ -131,9 +131,7 @@ namespace OpenRA
var widgetYaml = m.ChromeLayout.Select(a => MiniYaml.FromFile(a)).Aggregate(MiniYaml.Merge);
// Hack around a bug in MiniYaml
widgetYaml.Values.FirstOrDefault().Value = widgetYaml.Keys.FirstOrDefault();
WidgetLoader.rootWidget = WidgetLoader.LoadWidget(widgetYaml.Values.FirstOrDefault());
WidgetLoader.rootWidget = WidgetLoader.LoadWidget( widgetYaml.FirstOrDefault() );
WidgetLoader.rootWidget.Initialize();
}

View File

@@ -1,53 +1,42 @@
using OpenRA.FileFormats;
using OpenRA.Graphics;
using OpenRA.Widgets;
using System;
using System.Collections.Generic;
using System.Drawing;
using System.IO;
using System.Reflection;
using System.Linq;
namespace OpenRA
{
class WidgetLoader
{
public static Widget rootWidget;
public static Widget LoadWidget( MiniYaml node )
{
var widget = NewWidget( node.Value );
foreach( var child in node.Nodes )
{
if( child.Key == "Children" )
{
foreach( var c in child.Value.Nodes )
{
// Hack around a bug in MiniYaml
c.Value.Value = c.Key;
widget.AddChild( LoadWidget( c.Value ) );
}
}
else
FieldLoader.LoadField( widget, child.Key, child.Value );
}
return widget;
}
static Widget NewWidget( string widgetType )
using System;
using OpenRA.FileFormats;
using OpenRA.Widgets;
using System.Collections.Generic;
namespace OpenRA
{
class WidgetLoader
{
public static Widget rootWidget;
public static Widget LoadWidget(KeyValuePair<string, MiniYaml> node)
{
widgetType = widgetType.Split('@')[0];
foreach (var mod in Game.ModAssemblies)
{
var fullTypeName = mod.Second + "." + widgetType + "Widget";
var widget = (Widget)mod.First.CreateInstance(fullTypeName);
if (widget == null) continue;
Log.Write("Creating Widget of type {0}",widgetType);
return widget;
}
throw new InvalidOperationException("Cannot locate widget: {0}".F(widgetType));
}
}
var widget = NewWidget(node.Key);
foreach (var child in node.Value.Nodes)
{
if (child.Key == "Children")
foreach (var c in child.Value.Nodes)
widget.AddChild(LoadWidget(c));
else
FieldLoader.LoadField(widget, child.Key, child.Value);
}
return widget;
}
static Widget NewWidget(string widgetType)
{
widgetType = widgetType.Split('@')[0];
foreach (var mod in Game.ModAssemblies)
{
var fullTypeName = mod.Second + "." + widgetType + "Widget";
var widget = (Widget)mod.First.CreateInstance(fullTypeName);
if (widget == null) continue;
Log.Write("Creating Widget of type {0}", widgetType);
return widget;
}
throw new InvalidOperationException("Cannot locate widget: {0}".F(widgetType));
}
}
}