Free cookie consent management tool by TermsFeed Policy Generator

source: trunk/sources/HeuristicLab.PluginInfrastructure/BaseClasses/ApplicationBase.cs @ 2

Last change on this file since 2 was 2, checked in by swagner, 16 years ago

Added HeuristicLab 3.0 sources from former SVN repository at revision 52

File size: 2.9 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;
25using System.Diagnostics;
26
27namespace HeuristicLab.PluginInfrastructure {
28  public abstract class ApplicationBase : IApplication {
29    private string name;
30    private Version version;
31    private string description;
32   
33    public ApplicationBase() {
34      ReadAttributes();
35    }
36
37    private void ReadAttributes() {
38      object[] pluginAttributes = this.GetType().GetCustomAttributes(typeof(ClassInfoAttribute), false);
39
40      // exactly one attribute of the type ClassInfoAttribute must be given
41      Trace.Assert(pluginAttributes.Length == 1);
42
43      // after the assertion we are sure that the array access will not fail
44      ClassInfoAttribute pluginAttribute = (ClassInfoAttribute)pluginAttributes[0];
45
46      // if the plugin name is not explicitly set in the attribute then the default plugin name is the FullName of the type
47      if(pluginAttribute != null && pluginAttribute.Name != null) {
48        this.name = pluginAttribute.Name;
49      } else {
50        this.name = this.GetType().FullName;
51      }
52
53      // if the version is not explicitly set in the attribute then the version of the assembly is used as default
54      if(pluginAttribute != null && pluginAttribute.Version != null) {
55        this.version = new Version(pluginAttribute.Version);
56      } else {
57        this.version = this.GetType().Assembly.GetName().Version;
58      }
59
60      // if the description is not explicitly set in the attribute then the name of name of the application is used as default
61      if(pluginAttribute != null && pluginAttribute.Description != null) {
62        this.description = pluginAttribute.Description;
63      } else {
64        this.description = name;
65      }
66    }
67
68
69    #region IApplication Members
70
71    public string Name {
72      get { return name; }
73    }
74
75    public Version Version {
76      get { return version; }
77    }
78
79    public string Description {
80      get { return description; }
81    }
82
83    public abstract void Run() ;
84
85    #endregion
86  }
87}
Note: See TracBrowser for help on using the repository browser.