Free cookie consent management tool by TermsFeed Policy Generator

source: branches/PluginInfrastructure Refactoring/HeuristicLab.PluginInfrastructure/Attributes/ApplicationAttribute.cs @ 2503

Last change on this file since 2503 was 2488, checked in by gkronber, 15 years ago

Worked on plugin infrastructure refactoring. (Fully functional revision). #799

File size: 4.0 KB
Line 
1#region License Information
2/* HeuristicLab
3 * Copyright (C) 2002-2008 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
4 *
5 * This file is part of HeuristicLab.
6 *
7 * HeuristicLab is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation, either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * HeuristicLab is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with HeuristicLab. If not, see <http://www.gnu.org/licenses/>.
19 */
20#endregion
21
22using System;
23using System.Collections.Generic;
24using System.Text;
25
26namespace HeuristicLab.PluginInfrastructure {
27  /// <summary>
28  /// This attribute can be used to specify meta data for applications.
29  /// For example to specify name, version and description of applications.
30  /// </summary>
31  [AttributeUsage(AttributeTargets.Class)]
32  public class ApplicationAttribute : System.Attribute {
33    private string name;
34    /// <summary>
35    /// Gets or sets the name of the application.
36    /// </summary>
37    public string Name {
38      get { return name; }
39      set { name = value; }
40    }
41
42    //private string version;
43    ///// <summary>
44    ///// Gets or sets the version of the application.
45    ///// </summary>
46    //public string Version {
47    //  get { return version; }
48    //  set { version = value; }
49    //}
50
51    private string description;
52    /// <summary>
53    /// Gets or sets the description of the application.
54    /// </summary>
55    public string Description {
56      get { return description; }
57      set { description = value; }
58    }
59
60    private bool restartOnErrors;
61    /// <summary>
62    /// Gets or sets the boolean flag whether the plugin should be automatically restarted when it is closed because of an exception (for services).
63    /// </summary>
64    public bool RestartOnErrors {
65      get { return restartOnErrors; }
66      set { restartOnErrors = value; }
67    }
68
69    /// <summary>
70    /// Initializes a new instance of <see cref="ApplicationAttribute"/>.
71    /// <param name="name">Name of the application</param>
72    /// </summary>
73    public ApplicationAttribute(string name)
74      : this(name, "") {
75    }
76
77    /// <summary>
78    /// Initializes a new instance of <see cref="ApplicationAttribute"/>.
79    /// <param name="name">Name of the application</param>
80    /// <param name="description">Description of the application</param>
81    /// </summary>
82    public ApplicationAttribute(string name, string description)
83      : this(name, description, false) {
84    }
85
86    ///// <summary>
87    ///// Initializes a new instance of <see cref="ApplicationAttribute"/>.
88    ///// <param name="name">Name of the application</param>
89    ///// <param name="description">Description of the application</param>
90    ///// <param name="version">Version string of the application</param>
91    ///// </summary>
92    //public ApplicationAttribute(string name, string description, string version)
93    //  : this(name, description, version, false) {
94    //}
95
96    /// <summary>
97    /// Initializes a new instance of <see cref="ApplicationAttribute"/>.
98    /// <param name="name">Name of the application</param>
99    /// <param name="description">Description of the application</param>
100    /// <param name="version">Version string of the application</param>
101    /// <param name="restartOnErrors">Flag that indicates if the application should be restarted on exceptions (for services)</param>
102    /// </summary>
103    public ApplicationAttribute(string name, string description, bool restartOnErrors) {
104      this.name = name;
105      this.description = description;
106      this.restartOnErrors = restartOnErrors;
107    }
108  }
109}
Note: See TracBrowser for help on using the repository browser.