Mercurial > repos > snowblizz-super-API-ideas
view api/WarFoundryCore.cs @ 20:b7c93a5821cd
* Remove unnecessary project dependency
* Change logging on invalid file exception on load
* Add logging when a non-native loader is asked to load a file it doesn't understand
no-open-ticket
author | IBBoard <dev@ibboard.co.uk> |
---|---|
date | Sun, 01 Mar 2009 15:00:03 +0000 |
parents | 306558904c2a |
children | 548cfc776f54 |
line wrap: on
line source
// This file (WarFoundryCore.cs) is a part of the IBBoard.WarFoundry.API project and is copyright 2009 IBBoard. // // The file and the library/program it is in are licensed under the GNU LGPL license, either version 3 of the License or (at your option) any later version. Please see COPYING.LGPL for more information and the full license. using System; using IBBoard.Logging; using IBBoard.WarFoundry.API.Objects; namespace IBBoard.WarFoundry.API { public class WarFoundryCore { public static event GameSystemChangedDelegate GameSystemChanged; public static event ArmyChangedDelegate ArmyChanged; private static GameSystem system; private static Army currentArmy; public static GameSystem CurrentGameSystem { get { return system; } set { if (system==null || !system.Equals(value)) { GameSystem oldSystem = system; system = value; if (system==null) { LogNotifier.Debug(typeof(WarFoundryCore), "Game system set to null"); } else { LogNotifier.DebugFormat(typeof(WarFoundryCore), "Game system set to {0} with ID {1}", system.Name, system.ID); } if (GameSystemChanged!=null) { GameSystemChanged(oldSystem, system); } //If we've changed the game system then we can't keep the current army CurrentArmy = null; } } } public static Army CurrentArmy { get { return currentArmy; } set { if (currentArmy==null || !currentArmy.Equals(value)) { /*if (currentArmy!=null) { currentArmy.UnitAdded-= UnitAddedMethod; currentArmy.UnitRemoved-= UnitRemovedMethod; currentArmy.PointsValueChanged-= PointsValueChangedMethod; currentArmy.FailedRequirement-=FailedUnitRequirementMethod; }*/ Army oldArmy = currentArmy; currentArmy = value; if (currentArmy!=null) { CurrentGameSystem = currentArmy.GameSystem; //Set the game system in case the new army is from a different system } /*if (currentArmy!=null) { currentArmy.UnitAdded+= UnitAddedMethod; currentArmy.UnitRemoved+= UnitRemovedMethod; currentArmy.PointsValueChanged+= PointsValueChangedMethod; currentArmy.FailedRequirement+=FailedUnitRequirementMethod; }*/ if (ArmyChanged!=null) { ArmyChanged(oldArmy, currentArmy); } } } } } }