// 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 // // Jaroslaw Kowalski (jkowalski@users.sourceforge.net) using System; namespace NAnt.Core.Attributes { /// /// Indicates that class should be treated as a set of functions. /// /// /// Attach this attribute to a class that derives from /// to have NAnt be able to recognize it as containing custom functions. /// [AttributeUsage(AttributeTargets.Class, Inherited=false, AllowMultiple=false)] public sealed class FunctionSetAttribute : Attribute { #region Public Instance Constructors /// /// Initializes a new instance of the /// class with the specified name. /// /// The prefix used to distinguish the functions. /// The category of the functions. /// /// is . /// -or- /// is . /// /// /// is a zero-length . /// -or- /// is a zero-length . /// public FunctionSetAttribute(string prefix, string category) { if (prefix == null) { throw new ArgumentNullException("prefix"); } if (category == null) { throw new ArgumentNullException("category"); } if (prefix.Trim().Length == 0) { throw new ArgumentOutOfRangeException("prefix", prefix, "A zero-length string is not an allowed value."); } if (category.Trim().Length == 0) { throw new ArgumentOutOfRangeException("category", category, "A zero-length string is not an allowed value."); } _prefix = prefix; _category = category; } #endregion Public Instance Constructors #region Public Instance Properties /// /// Gets or sets the category of the function set. /// /// /// The name of the category of the function set. /// /// /// This will be displayed in the user docs. /// public string Category { get { return _category; } set { _category = value; } } /// /// Gets or sets the prefix of all functions in this function set. /// /// /// The prefix of the functions in this function set. /// public string Prefix { get { return _prefix; } set { _prefix = value; } } #endregion Public Instance Properties #region Private Instance Fields private string _prefix; private string _category; #endregion Private Instance Fields } }