// NAnt - A .NET build tool // Copyright (C) 2001 Gerry Shaw // // This program is free software; you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation; either version 2 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program; if not, write to the Free Software // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // // Gerry Shaw (gerry_shaw@yahoo.com) // Scott Hernandez (ScottHernandez@hotmail.com) using System; using System.Collections; using System.Globalization; using NAnt.Core.Util; namespace NAnt.Core { [Serializable()] public class TargetCollection : ArrayList { private static readonly log4net.ILog logger = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType); public virtual int Add(Target t){ // throw an exception if an attempt is made to add a null target if (t == null) { throw new BuildException("Null Target!"); } logger.Debug(string.Format( CultureInfo.InvariantCulture, ResourceUtils.GetString("String_AddingTarget"), t.Name)); // check for existing target with same name. if (Find(t.Name) == null) { return base.Add(t); } else { throw new BuildException(string.Format(CultureInfo.InvariantCulture, ResourceUtils.GetString("NA1073"), t.Name)); } } /// /// Finds a target by name. /// /// The name of the target to find. /// /// The with the specified name, or /// if no exists with /// the given name. /// public Target Find(string targetName) { foreach (Target target in this) { if (target.Name == targetName) return target; } return null; } /// /// Gets the names of the targets in the /// combined into one list separated by the given . /// /// /// A that contains a list of the names of the /// targets in the , separated by /// the specified . /// public string ToString(string separator) { string[] targetNames = new string[Count]; for (int i = 0; i < Count; i++) { targetNames[i] = ((Target) this[i]).Name; } return string.Join(separator, targetNames); } public override int Add(object value) { // call typed version above. return Add(value as Target); } #region Override implementation of Object /// /// Gets the names of the targets in the /// combined into one comma-separated list. /// /// /// A that contains a comma-separated list of the /// names of the targets in the . /// public override string ToString() { return ToString(", "); } #endregion Override implementation of Object } }