Move AvailableMaps into ModData
This commit is contained in:
@@ -48,29 +48,7 @@ namespace OpenRA
|
|||||||
static int2 clientSize;
|
static int2 clientSize;
|
||||||
static string mapName;
|
static string mapName;
|
||||||
public static Session LobbyInfo = new Session();
|
public static Session LobbyInfo = new Session();
|
||||||
static bool packageChangePending;
|
|
||||||
static bool mapChangePending;
|
static bool mapChangePending;
|
||||||
|
|
||||||
public static Dictionary<string, MapStub> AvailableMaps;
|
|
||||||
|
|
||||||
// TODO: Do this nicer
|
|
||||||
static Dictionary<string, MapStub> FindMaps(string[] mods)
|
|
||||||
{
|
|
||||||
var paths = new[] { "maps/" }.Concat(mods.Select(m => "mods/" + m + "/maps/"))
|
|
||||||
.Where(p => Directory.Exists(p))
|
|
||||||
.SelectMany(p => Directory.GetDirectories(p)).ToList();
|
|
||||||
|
|
||||||
return paths.Select(p => new MapStub(new Folder(p))).ToDictionary(m => m.Uid);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void ChangeMods()
|
|
||||||
{
|
|
||||||
AvailableMaps = FindMaps(LobbyInfo.GlobalSettings.Mods);
|
|
||||||
|
|
||||||
modData = new ModData( LobbyInfo.GlobalSettings.Mods );
|
|
||||||
|
|
||||||
ChromeProvider.Initialize( modData.Manifest.Chrome );
|
|
||||||
}
|
|
||||||
|
|
||||||
static void LoadMap(string mapName)
|
static void LoadMap(string mapName)
|
||||||
{
|
{
|
||||||
@@ -78,10 +56,10 @@ namespace OpenRA
|
|||||||
modData = new ModData( LobbyInfo.GlobalSettings.Mods );
|
modData = new ModData( LobbyInfo.GlobalSettings.Mods );
|
||||||
Timer.Time("manifest: {0}");
|
Timer.Time("manifest: {0}");
|
||||||
|
|
||||||
if (!Game.AvailableMaps.ContainsKey(mapName))
|
if (!modData.AvailableMaps.ContainsKey(mapName))
|
||||||
throw new InvalidDataException("Cannot find map with Uid {0}".F(mapName));
|
throw new InvalidDataException("Cannot find map with Uid {0}".F(mapName));
|
||||||
|
|
||||||
var map = new Map(Game.AvailableMaps[mapName].Package);
|
var map = new Map(modData.AvailableMaps[mapName].Package);
|
||||||
|
|
||||||
viewport = new Viewport(clientSize, map.TopLeft, map.BottomRight, Renderer);
|
viewport = new Viewport(clientSize, map.TopLeft, map.BottomRight, Renderer);
|
||||||
world = null; // trying to access the old world will NRE, rather than silently doing it wrong.
|
world = null; // trying to access the old world will NRE, rather than silently doing it wrong.
|
||||||
@@ -153,14 +131,6 @@ namespace OpenRA
|
|||||||
|
|
||||||
static void Tick()
|
static void Tick()
|
||||||
{
|
{
|
||||||
if (packageChangePending)
|
|
||||||
{
|
|
||||||
// TODO: Only do this on mod change
|
|
||||||
ChangeMods();
|
|
||||||
packageChangePending = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (mapChangePending)
|
if (mapChangePending)
|
||||||
{
|
{
|
||||||
mapName = LobbyInfo.GlobalSettings.Map;
|
mapName = LobbyInfo.GlobalSettings.Map;
|
||||||
@@ -224,8 +194,6 @@ namespace OpenRA
|
|||||||
|
|
||||||
internal static void SyncLobbyInfo(string data)
|
internal static void SyncLobbyInfo(string data)
|
||||||
{
|
{
|
||||||
var oldLobbyInfo = LobbyInfo;
|
|
||||||
|
|
||||||
var session = new Session();
|
var session = new Session();
|
||||||
session.GlobalSettings.Mods = Settings.InitialMods;
|
session.GlobalSettings.Mods = Settings.InitialMods;
|
||||||
|
|
||||||
@@ -265,13 +233,6 @@ namespace OpenRA
|
|||||||
if (mapName != LobbyInfo.GlobalSettings.Map)
|
if (mapName != LobbyInfo.GlobalSettings.Map)
|
||||||
mapChangePending = true;
|
mapChangePending = true;
|
||||||
|
|
||||||
if (string.Join(",", oldLobbyInfo.GlobalSettings.Mods)
|
|
||||||
!= string.Join(",", LobbyInfo.GlobalSettings.Mods))
|
|
||||||
{
|
|
||||||
Debug("Mods list changed, reloading: {0}".F(string.Join(",", LobbyInfo.GlobalSettings.Mods)));
|
|
||||||
packageChangePending = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
LobbyInfoChanged();
|
LobbyInfoChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -386,8 +347,6 @@ namespace OpenRA
|
|||||||
PerfHistory.items["text"].hasNormalTick = false;
|
PerfHistory.items["text"].hasNormalTick = false;
|
||||||
PerfHistory.items["cursor"].hasNormalTick = false;
|
PerfHistory.items["cursor"].hasNormalTick = false;
|
||||||
|
|
||||||
ChangeMods();
|
|
||||||
|
|
||||||
Renderer = new Renderer();
|
Renderer = new Renderer();
|
||||||
clientSize = new int2(Renderer.Resolution);
|
clientSize = new int2(Renderer.Resolution);
|
||||||
|
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ using System.Linq;
|
|||||||
using System.Text;
|
using System.Text;
|
||||||
using OpenRA.FileFormats;
|
using OpenRA.FileFormats;
|
||||||
using OpenRA.Graphics;
|
using OpenRA.Graphics;
|
||||||
|
using System.IO;
|
||||||
|
|
||||||
namespace OpenRA
|
namespace OpenRA
|
||||||
{
|
{
|
||||||
@@ -13,7 +14,8 @@ namespace OpenRA
|
|||||||
public readonly ObjectCreator ObjectCreator;
|
public readonly ObjectCreator ObjectCreator;
|
||||||
public readonly SheetBuilder SheetBuilder;
|
public readonly SheetBuilder SheetBuilder;
|
||||||
public readonly CursorSheetBuilder CursorSheetBuilder;
|
public readonly CursorSheetBuilder CursorSheetBuilder;
|
||||||
|
public readonly Dictionary<string, MapStub> AvailableMaps;
|
||||||
|
|
||||||
public ModData( params string[] mods )
|
public ModData( params string[] mods )
|
||||||
{
|
{
|
||||||
Manifest = new Manifest( mods );
|
Manifest = new Manifest( mods );
|
||||||
@@ -21,6 +23,20 @@ namespace OpenRA
|
|||||||
FileSystem.LoadFromManifest( Manifest );
|
FileSystem.LoadFromManifest( Manifest );
|
||||||
SheetBuilder = new SheetBuilder( TextureChannel.Red );
|
SheetBuilder = new SheetBuilder( TextureChannel.Red );
|
||||||
CursorSheetBuilder = new CursorSheetBuilder( this );
|
CursorSheetBuilder = new CursorSheetBuilder( this );
|
||||||
|
|
||||||
|
ChromeProvider.Initialize( Manifest.Chrome );
|
||||||
|
|
||||||
|
AvailableMaps = FindMaps( mods );
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: Do this nicer
|
||||||
|
static Dictionary<string, MapStub> FindMaps(string[] mods)
|
||||||
|
{
|
||||||
|
var paths = new[] { "maps/" }.Concat(mods.Select(m => "mods/" + m + "/maps/"))
|
||||||
|
.Where(p => Directory.Exists(p))
|
||||||
|
.SelectMany(p => Directory.GetDirectories(p)).ToList();
|
||||||
|
|
||||||
|
return paths.Select(p => new MapStub(new Folder(p))).ToDictionary(m => m.Uid);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -33,10 +33,10 @@ namespace OpenRA.Widgets.Delegates
|
|||||||
r.OpenWindow("SERVER_LOBBY");
|
r.OpenWindow("SERVER_LOBBY");
|
||||||
|
|
||||||
// TODO: Get this from a map chooser
|
// TODO: Get this from a map chooser
|
||||||
string map = Game.AvailableMaps.Keys.FirstOrDefault();
|
string map = Game.modData.AvailableMaps.Keys.FirstOrDefault();
|
||||||
|
|
||||||
// TODO: Get this from a mod chooser
|
// TODO: Get this from a mod chooser
|
||||||
var mods = Game.Settings.InitialMods;
|
var mods = Game.LobbyInfo.GlobalSettings.Mods;
|
||||||
|
|
||||||
Game.Settings.LastServerTitle = cs.GetWidget<TextFieldWidget>("GAME_TITLE").Text;
|
Game.Settings.LastServerTitle = cs.GetWidget<TextFieldWidget>("GAME_TITLE").Text;
|
||||||
Game.Settings.ListenPort = int.Parse(cs.GetWidget<TextFieldWidget>("LISTEN_PORT").Text);
|
Game.Settings.ListenPort = int.Parse(cs.GetWidget<TextFieldWidget>("LISTEN_PORT").Text);
|
||||||
|
|||||||
@@ -209,7 +209,7 @@ namespace OpenRA.Widgets.Delegates
|
|||||||
{
|
{
|
||||||
if (MapUid == Game.LobbyInfo.GlobalSettings.Map) return;
|
if (MapUid == Game.LobbyInfo.GlobalSettings.Map) return;
|
||||||
MapUid = Game.LobbyInfo.GlobalSettings.Map;
|
MapUid = Game.LobbyInfo.GlobalSettings.Map;
|
||||||
Map = Game.AvailableMaps[MapUid];
|
Map = Game.modData.AvailableMaps[MapUid];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -45,7 +45,7 @@ namespace OpenRA.Widgets.Delegates
|
|||||||
|
|
||||||
var itemTemplate = ml.GetWidget<LabelWidget>("MAP_TEMPLATE");
|
var itemTemplate = ml.GetWidget<LabelWidget>("MAP_TEMPLATE");
|
||||||
int offset = itemTemplate.Bounds.Y;
|
int offset = itemTemplate.Bounds.Y;
|
||||||
foreach (var kv in Game.AvailableMaps)
|
foreach (var kv in Game.modData.AvailableMaps)
|
||||||
{
|
{
|
||||||
var map = kv.Value;
|
var map = kv.Value;
|
||||||
if (!map.Selectable)
|
if (!map.Selectable)
|
||||||
@@ -72,9 +72,9 @@ namespace OpenRA.Widgets.Delegates
|
|||||||
// Set the default selected map
|
// Set the default selected map
|
||||||
var uid = uidobj as string;
|
var uid = uidobj as string;
|
||||||
if (uid != null)
|
if (uid != null)
|
||||||
Map = Game.AvailableMaps[uid];
|
Map = Game.modData.AvailableMaps[uid];
|
||||||
else
|
else
|
||||||
Map = Game.AvailableMaps.FirstOrDefault().Value;
|
Map = Game.modData.AvailableMaps.FirstOrDefault().Value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -150,8 +150,8 @@ namespace OpenRA.Widgets.Delegates
|
|||||||
|
|
||||||
MapStub CurrentMap()
|
MapStub CurrentMap()
|
||||||
{
|
{
|
||||||
return (currentServer == null || !Game.AvailableMaps.ContainsKey(currentServer.Map))
|
return (currentServer == null || !Game.modData.AvailableMaps.ContainsKey(currentServer.Map))
|
||||||
? null : Game.AvailableMaps[currentServer.Map];
|
? null : Game.modData.AvailableMaps[currentServer.Map];
|
||||||
}
|
}
|
||||||
|
|
||||||
void RefreshServerList(IEnumerable<GameServer> games)
|
void RefreshServerList(IEnumerable<GameServer> games)
|
||||||
|
|||||||
Reference in New Issue
Block a user