// NAnt - A .NET build tool // Copyright (C) 2001-2003 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 // // Gert Driesen (gert.driesen@ardatis.com) // Scott Hernandez (ScottHernandez_at_HOtMail_dot_dot_dot_com?) using System; namespace NAnt.Core.Attributes { /// /// Indicates that the property should be treated as a container for a /// collection of build elements. /// /// /// /// Should only be applied to properties exposing strongly typed arrays or /// strongly typed collections. /// /// /// The XML format is like this: /// /// /// /// /// /// /// /// /// /// ]]> /// /// /// [AttributeUsage(AttributeTargets.Property, Inherited=true)] public sealed class BuildElementCollectionAttribute : BuildElementArrayAttribute{ #region Public Instance Constructors /// /// Initializes a new instance of the with the /// specified name and child element name. /// /// The name of the collection. /// The name of the child elements in the collection /// is . /// is a zero-length . public BuildElementCollectionAttribute(string collectionName, string childName) : base(collectionName) { if (childName == null) { throw new ArgumentNullException("childName"); } _elementName = childName.Trim(); if (_elementName.Length == 0) { throw new ArgumentOutOfRangeException("childName", childName, "A zero-length string is not an allowed value."); } } #endregion Public Instance Constructors #region Public Instance Constructors /// /// The name of the child element within the collection. /// /// /// The name to check for in the XML of the elements in the collection. /// /// /// This can be used for validation and schema generation. /// public string ChildElementName { get { return _elementName; } } #endregion Public Instance Constructors #region Private Instance Fields private string _elementName = null; #endregion Private Instance Fields } }