#region License Information /* HeuristicLab * Copyright (C) Heuristic and Evolutionary Algorithms Laboratory (HEAL) * * This file is part of HeuristicLab. * * HeuristicLab 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 3 of the License, or * (at your option) any later version. * * HeuristicLab 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 HeuristicLab. If not, see . */ #endregion using System; namespace HeuristicLab.PluginInfrastructure { /// /// This attribute can be used to specify meta data for plugins. /// For example to specify name and description of plugins. /// [AttributeUsage(AttributeTargets.Class)] public sealed class PluginAttribute : System.Attribute { private string name; /// /// Gets the name of the plugin. /// public string Name { get { return name; } } private string description; /// /// Gets the description of the plugin. /// public string Description { get { return description; } } private Version version; /// /// Gets the version of the plugin. /// public Version Version { get { return version; } } /// /// Initializes a new instance of . /// Name of the plugin /// Version of the plugin /// public PluginAttribute(string name, string version) : this(name, string.Empty, version) { } /// /// Initializes a new instance of . /// /// Name of the plugin /// Description of the plugin /// Version of the plugin public PluginAttribute(string name, string description, string version) { if (string.IsNullOrEmpty(name)) throw new ArgumentException("Plugin name is null or empty."); if (description == null) throw new ArgumentNullException("description"); if (string.IsNullOrEmpty(version)) throw new ArgumentException("Version string is null or empty."); this.name = name; this.description = description; this.version = new Version(version); // throws format exception if the version string can't be parsed } } }