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);
					}
				}
			}
		}
	}
}