view API/Objects/InvalidContainershipException.cs @ 357:50d0d3b39a0b

Re #140: Add equality methods * Add equality method for RequiresAtLeastNUnitsRequirement * Update equality method on GameSystem and No More Than limit to use new helper class * Add equality methods on Race and UnitType as a dependent of equality of requirements
author IBBoard <dev@ibboard.co.uk>
date Tue, 26 Apr 2011 19:19:08 +0000
parents 3c4a6403a88c
children
line wrap: on
line source

//  This file (InvalidContainershipException.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 and distributed, without warranty, under the GNU Affero GPL license, either version 3 of the License or (at your option) any later version. Please see COPYING for more information and the full license.

using System;
using IBBoard.Lang;

namespace IBBoard.WarFoundry.API.Objects
{
	/// <summary>
	/// A custom exception for when a unit was added as a sub-unit of another unit, but was not of a <see cref=" UnitType"/> that can be contained
	/// by that unit.
	/// </summary>
	public class InvalidContainershipException : Exception
	{
		private Unit containing;
		private Unit contained;
		
		public InvalidContainershipException(Unit containingUnit, Unit containedUnit) : base(CreateMessageString(containingUnit, containedUnit))
		{
			containing = containingUnit;
			contained = containedUnit;
		}
		
		private static string CreateMessageString(Unit containingUnit, Unit containedUnit)
		{
			return String.Format("{0} cannot contain {1} because units of type {2} cannot contain units of type {3}", containingUnit.Name, containedUnit.Name, containingUnit.UnitType.Name, containedUnit.UnitType.Name);
		}
		
		/// <value>
		/// The <see cref=" Unit"/> that the contained unit was added to
		/// </value>
		public Unit ContainingUnit
		{
			get { return containing; }
		}
		
		/// <value>
		/// The <see cref=" Unit"/> that was added as a contained unit, but which was not of an allowed type
		/// </value>
		public Unit ContainedUnit
		{
			get { return contained; }
		}
	}
}