Free cookie consent management tool by TermsFeed Policy Generator

Ignore:
Timestamp:
11/10/09 16:52:52 (15 years ago)
Author:
gkronber
Message:

worked on plugin infrastructure refactoring. #799

Location:
branches/PluginInfrastructure Refactoring/HeuristicLab.PluginInfrastructure
Files:
2 added
7 edited
4 moved

Legend:

Unmodified
Added
Removed
  • branches/PluginInfrastructure Refactoring/HeuristicLab.PluginInfrastructure/Attributes/AssemblyBuildDateAttribute.cs

    r2472 r2475  
    2727namespace HeuristicLab.PluginInfrastructure {
    2828  /// <summary>
    29   /// Attribute of an assembly when it was built.
     29  /// Build date attribute. Allows to declare the build date of assemblies.
    3030  /// </summary>
    3131  [AttributeUsage(AttributeTargets.Assembly, AllowMultiple = false)]
     
    3333    private DateTime buildDate;
    3434    /// <summary>
    35     /// Gets or sets the date when the assembly has been built.
     35    /// Gets or sets the build date.
    3636    /// </summary>
    3737    public DateTime BuildDate {
  • branches/PluginInfrastructure Refactoring/HeuristicLab.PluginInfrastructure/Attributes/PluginDependencyAttribute.cs

    r2472 r2475  
    2626namespace HeuristicLab.PluginInfrastructure {
    2727  /// <summary>
    28   /// This attribute can be used to specify that an assembly depends on a different plugin.
     28  /// This attribute can be used to declare that an plugin depends on a another plugin.
    2929  /// </summary>
    30   [AttributeUsage(AttributeTargets.Class,AllowMultiple=true)]
    31   public sealed class DependencyAttribute : System.Attribute {
     30  [AttributeUsage(AttributeTargets.Class, AllowMultiple = true)]
     31  public sealed class PluginDependencyAttribute : System.Attribute {
    3232    private string dependency;
    3333
    3434    /// <summary>
    35     /// Gets or sets the name of the plugin that is needed to load the assembly.
     35    /// Gets or sets the name of the plugin that is needed to load a plugin.
    3636    /// </summary>
    3737    public string Dependency {
     
    4141
    4242    /// <summary>
    43     /// Initializes a new instance of <see cref="DependencyAttribute"/>.
     43    /// Initializes a new instance of <see cref="PluginDependencyAttribute"/>.
     44    /// <param name="dependency">The name of the plugin that is needed to load a plugin.</param>
    4445    /// </summary>
    45     public DependencyAttribute() {
     46    public PluginDependencyAttribute(string dependency) {
     47      this.dependency = dependency;
    4648    }
    4749  }
  • branches/PluginInfrastructure Refactoring/HeuristicLab.PluginInfrastructure/Attributes/PluginDescriptionAttribute.cs

    r2472 r2475  
    2626namespace HeuristicLab.PluginInfrastructure {
    2727  /// <summary>
    28   /// This attribute can be used to specify meta data for classes.
    29   /// For example to specify name, version and description of applications or plugins.
     28  /// This attribute can be used to specify meta data for plugins.
     29  /// For example to specify name, version and description of plugins.
    3030  /// </summary>
    3131  [AttributeUsage(AttributeTargets.Class)]
    32   public class ClassInfoAttribute : System.Attribute {
     32  public class PluginDescriptionAttribute : System.Attribute {
    3333    private string name;
    3434    /// <summary>
    35     /// Gets or sets the name of the plugin to which the assembly belongs to.
     35    /// Gets or sets the name of the plugin.
    3636    /// </summary>
    3737    public string Name {
     
    5858    }
    5959
    60     private bool autoRestart;
    6160    /// <summary>
    62     /// Gets or sets the boolean flag whether the plugin should be automatically restarted.
     61    /// Initializes a new instance of <see cref="PluginDescriptionAttribute"/>.
     62    /// <param name="name">Name of the plugin</param>
    6363    /// </summary>
    64     public bool AutoRestart {
    65       get { return autoRestart; }
    66       set { autoRestart = value; }
     64    public PluginDescriptionAttribute(string name)
     65      : this(name, "") {
    6766    }
    6867
    6968    /// <summary>
    70     /// Initializes a new instance of <see cref="ClassInfoAttribute"/>.
     69    /// Initializes a new instance of <see cref="PluginDescriptionAttribute"/>.
     70    /// <param name="name">Name of the plugin</param>
     71    /// <param name="description">Description of the plugin</param>
    7172    /// </summary>
    72     public ClassInfoAttribute() {}
     73    public PluginDescriptionAttribute(string name, string description)
     74      : this(name, description, "") {
     75    }
     76
     77    /// <summary>
     78    /// Initializes a new instance of <see cref="PluginDescriptionAttribute"/>.
     79    /// <param name="name">Name of the plugin</param>
     80    /// <param name="description">Description of the plugin</param>
     81    /// <param name="version">Version string of the plugin</param>
     82    /// </summary>
     83    public PluginDescriptionAttribute(string name, string description, string version) {
     84      this.name = name;
     85      this.version = version;
     86      this.description = description;
     87    }
    7388  }
    7489}
  • branches/PluginInfrastructure Refactoring/HeuristicLab.PluginInfrastructure/Attributes/PluginFileAttribute.cs

    r2472 r2475  
    3636
    3737  /// <summary>
    38   /// Attribute for plugins providing information about their corresponding files.
     38  /// PluginFileAttribute can be used to declare which files make up an plugin.
     39  /// Multiple files can be associated to an plugin. Each file should be associated to only one plugin.
    3940  /// </summary>
    40   [AttributeUsage(AttributeTargets.Class, AllowMultiple=true)]
     41  [AttributeUsage(AttributeTargets.Class, AllowMultiple = true)]
    4142  public class PluginFileAttribute : System.Attribute {
    4243    private string filename;
     
    6263    /// <summary>
    6364    /// Initializes a new instance of <see cref="PluginFileAttribute"/>.
     65    /// <param name="filename">Name of the file</param>
     66    /// <param name="type">Type of the file (Assembly, Executable, Data, License)</param>
    6467    /// </summary>
    65     public PluginFileAttribute() { }
     68    public PluginFileAttribute(string filename, PluginFileType type) {
     69      this.filename = filename;
     70      this.filetype = type;
     71    }
    6672  }
    6773}
  • branches/PluginInfrastructure Refactoring/HeuristicLab.PluginInfrastructure/BaseClasses/ApplicationBase.cs

    r1189 r2475  
    2929  /// Default implementation for the IApplication interface.
    3030  /// </summary>
    31   public abstract class ApplicationBase : IApplication {
    32     private string name;
    33     private Version version;
    34     private string description;
    35     private bool autoRestart;
    36 
     31  internal abstract class ApplicationBase : IApplication {
    3732    /// <summary>
    3833    /// Initializes a new instance of <see cref="ApplicationBase"/>.
    3934    /// </summary>
    40     public ApplicationBase() {
    41       ReadAttributes();
    42     }
     35    public ApplicationBase() { }
    4336
    44     private void ReadAttributes() {
    45       object[] pluginAttributes = this.GetType().GetCustomAttributes(typeof(ClassInfoAttribute), false);
     37    private ApplicationDescriptionAttribute ApplicationDescriptionAttribute {
     38      get {
     39        object[] appDescAttributes = this.GetType().GetCustomAttributes(typeof(ApplicationDescriptionAttribute), false);
    4640
    47       // exactly one attribute of the type ClassInfoAttribute must be given
    48       if(pluginAttributes.Length != 1) {
    49         throw new InvalidPluginException();
    50       }
    51 
    52       // after the assertion we are sure that the array access will not fail
    53       ClassInfoAttribute pluginAttribute = (ClassInfoAttribute)pluginAttributes[0];
    54       if(pluginAttribute != null) {
    55         // if the plugin name is not explicitly set in the attribute then the default plugin name is the FullName of the type
    56         if(pluginAttribute.Name != null) {
    57           this.name = pluginAttribute.Name;
    58         } else {
    59           this.name = this.GetType().FullName;
     41        // exactly one attribute of the type ClassInfoAttribute must be given
     42        if (appDescAttributes.Length != 1) {
     43          throw new InvalidPluginException("Found multiple ApplicationDescriptionAttributes on type " + this.GetType());
    6044        }
    6145
    62         // if the version is not explicitly set in the attribute then the version of the assembly is used as default
    63         if(pluginAttribute.Version != null) {
    64           this.version = new Version(pluginAttribute.Version);
    65         } else {
    66           this.version = this.GetType().Assembly.GetName().Version;
    67         }
    68 
    69         // if the description is not explicitly set in the attribute then the name of name of the application is used as default
    70         if(pluginAttribute.Description != null) {
    71           this.description = pluginAttribute.Description;
    72         } else {
    73           this.description = name;
    74         }
    75 
    76         this.autoRestart = pluginAttribute.AutoRestart;
     46        return (ApplicationDescriptionAttribute)appDescAttributes[0];
    7747      }
    7848    }
    79 
    8049
    8150    #region IApplication Members
     
    8554    /// </summary>
    8655    public string Name {
    87       get { return name; }
     56      get { return ApplicationDescriptionAttribute.Name; }
    8857    }
    8958
     
    9261    /// </summary>
    9362    public Version Version {
    94       get { return version; }
     63      get {
     64        var appDescAttribute = ApplicationDescriptionAttribute;
     65        // if the version is not explicitly set in the attribute then the version of the assembly is used as default
     66        if (string.IsNullOrEmpty(appDescAttribute.Version)) {
     67          return this.GetType().Assembly.GetName().Version;
     68        } else {
     69          return new Version(appDescAttribute.Version);
     70        }
     71      }
    9572    }
    9673
     
    9976    /// </summary>
    10077    public string Description {
    101       get { return description; }
     78      get {
     79        var appDescAttribute = ApplicationDescriptionAttribute;
     80        // if the description is not explicitly set in the attribute then the name of the application is used as default
     81        if (string.IsNullOrEmpty(appDescAttribute.Description)) {
     82          return appDescAttribute.Name;
     83        } else {
     84          return appDescAttribute.Description;
     85        }
     86      }
    10287    }
    10388
    10489    /// <summary>
    105     /// Gets the boolean flag whether the application should automatically get restarted.
     90    /// Gets the boolean flag whether the application should by restarted after exceptions.
    10691    /// </summary>
    107     public bool AutoRestart {
    108       get { return autoRestart; }
     92    public bool RestartOnErrors {
     93      get {
     94        return ApplicationDescriptionAttribute.RestartOnErrors;
     95      }
    10996    }
    11097
  • branches/PluginInfrastructure Refactoring/HeuristicLab.PluginInfrastructure/BaseClasses/PluginBase.cs

    r1229 r2475  
    2525using System.Reflection;
    2626using System.Diagnostics;
     27using System.Linq;
    2728
    2829namespace HeuristicLab.PluginInfrastructure {
     
    3132  /// </summary>
    3233  public abstract class PluginBase : IPlugin {
    33     private string name;
    34     private Version version;
    35     private string[] files;
    36     private string description;
    37 
    3834    /// <summary>
    3935    /// Initializes a new instance of <see cref="PluginBase"/>.
    4036    /// </summary>
    41     public PluginBase() {
    42       ReadAttributes();
    43     }
     37    public PluginBase() { }
    4438
    45     private void ReadAttributes() {
    46       object[] pluginAttributes = this.GetType().GetCustomAttributes(typeof(ClassInfoAttribute), false);
    47 
    48       // exactly one attribute of the type ClassInfoAttribute must be given
    49       if (pluginAttributes.Length != 1) {
    50         throw new InvalidPluginException();
    51       }
    52 
    53       // after the assertion we are sure that the array access will not fail
    54       ClassInfoAttribute pluginAttribute = (ClassInfoAttribute)pluginAttributes[0];
    55 
    56       // if the plugin name is not explicitly set in the attribute then the default plugin name is the FullName of the type
    57       if (pluginAttribute != null && pluginAttribute.Name != null) {
    58         this.name = pluginAttribute.Name;
    59       } else {
    60         this.name = this.GetType().FullName;
    61       }
    62 
    63       // if the version is not explicitly set in the attribute then the version of the assembly is used as default
    64       if (pluginAttribute != null && pluginAttribute.Version != null) {
    65         this.version = new Version(pluginAttribute.Version);
    66       } else {
    67         this.version = this.GetType().Assembly.GetName().Version;
    68       }
    69 
    70       // if the description is not explicitly set in the attribute then the name of name of the plugin is used as default
    71       if (pluginAttribute != null && pluginAttribute.Description != null) {
    72         this.description = pluginAttribute.Description;
    73       } else {
    74         this.description = name;
    75       }
    76 
    77       // get all attributes of type PluginFileAttribute, multiple usage is possible
    78       PluginFileAttribute[] fileAttributes = (PluginFileAttribute[])this.GetType().GetCustomAttributes(typeof(PluginFileAttribute), false);
    79 
    80       // exctract the file names from the attributes
    81       this.files = new string[fileAttributes.Length];
    82       int i = 0;
    83       foreach (PluginFileAttribute fileAttr in fileAttributes) {
    84         files[i++] = fileAttr.Filename;
     39    private PluginDescriptionAttribute PluginDescriptionAttribute {
     40      get {
     41        object[] pluginAttributes = this.GetType().GetCustomAttributes(typeof(PluginDescriptionAttribute), false);
     42        // exactly one attribute of the type PluginDescriptionAttribute must be given
     43        if (pluginAttributes.Length != 1) {
     44          throw new InvalidPluginException("Found multiple PluginDescriptionAttributes on type " + this.GetType());
     45        }
     46        return (PluginDescriptionAttribute)pluginAttributes[0];
    8547      }
    8648    }
    8749
    8850    #region IPlugin Members
    89     /// <summary>
    90     /// Gets the name of the plugin.
    91     /// </summary>
     51    /// <inheritdoc />
    9252    public string Name {
    9353      get {
    94         return name;
     54        return PluginDescriptionAttribute.Name;
    9555      }
    9656    }
    9757
    98     /// <summary>
    99     /// Gets the version of the plugin.
    100     /// </summary>
     58    /// <inheritdoc />
    10159    public Version Version {
    10260      get {
    103         return version;
     61        var pluginAttribute = PluginDescriptionAttribute;
     62        // if the version is not set in the attribute then the version of the assembly is used as default
     63        if (string.IsNullOrEmpty(pluginAttribute.Version)) {
     64          return this.GetType().Assembly.GetName().Version;
     65        } else {
     66          return new Version(pluginAttribute.Version);
     67        }
    10468      }
    10569    }
    10670
    107     /// <summary>
    108     /// Gets the description of the plugin.
    109     /// </summary>
     71    /// <inheritdoc />
    11072    public string Description {
    11173      get {
    112         return description;
     74        var pluginAttribute = PluginDescriptionAttribute;
     75        // if the description is not explicitly set in the attribute then the name of the plugin is used as default
     76        if (string.IsNullOrEmpty(pluginAttribute.Description)) {
     77          return pluginAttribute.Name;
     78        } else {
     79          return pluginAttribute.Description;
     80        }
    11381      }
    11482    }
    11583
    11684    /// <inheritdoc/>
    117     public  string[] Files {
     85    public IEnumerable<string> FileNames {
    11886      get {
    119         return files;
     87        // get all attributes of type PluginFileAttribute, multiple usage is possible
     88        return from x in this.GetType().GetCustomAttributes(typeof(PluginFileAttribute), false)
     89               let pluginFileAttr = (PluginFileAttribute)x
     90               select pluginFileAttr.Filename;
    12091      }
    12192    }
    12293
    123     /// <inhertidoc>
     94    /// <inhertitdoc>
    12495    public virtual void OnLoad() { }
    125     /// <inhertidoc>
    126     public virtual void OnInstall() { }
    127     /// <inhertidoc>
    128     public virtual void OnDelete() { }
    129     /// <inhertidoc>
    130     public virtual void OnPreUpdate() { }
    131     /// <inhertidoc>
    132     public virtual void OnPostUpdate() { }
    133 
    13496    #endregion
    13597
  • branches/PluginInfrastructure Refactoring/HeuristicLab.PluginInfrastructure/HeuristicLab.PluginInfrastructure.csproj

    r1589 r2475  
    1919    <UpgradeBackupLocation>
    2020    </UpgradeBackupLocation>
     21    <TargetFrameworkVersion>v3.5</TargetFrameworkVersion>
    2122  </PropertyGroup>
    2223  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
     
    7576  <ItemGroup>
    7677    <Reference Include="System" />
     78    <Reference Include="System.Core">
     79      <RequiredTargetFramework>3.5</RequiredTargetFramework>
     80    </Reference>
    7781    <Reference Include="System.Data" />
    7882    <Reference Include="System.Deployment" />
     
    8387  <ItemGroup>
    8488    <Compile Include="ApplicationInfo.cs" />
    85     <Compile Include="AssemblyBuildDateAttribute.cs" />
     89    <Compile Include="Attributes\ApplicationDescriptionAttribute.cs" />
     90    <Compile Include="Attributes\AssemblyBuildDateAttribute.cs" />
     91    <Compile Include="Attributes\PluginDependencyAttribute.cs" />
     92    <Compile Include="Attributes\PluginDescriptionAttribute.cs" />
     93    <Compile Include="Attributes\PluginFileAttribute.cs" />
    8694    <Compile Include="BaseClasses\ApplicationBase.cs" />
    8795    <Compile Include="BaseClasses\PluginBase.cs" />
    88     <Compile Include="ClassInfoAttribute.cs" />
    8996    <Compile Include="Interfaces\IApplication.cs" />
    9097    <Compile Include="Interfaces\IControl.cs" />
     
    93100    <Compile Include="PluginManager.cs" />
    94101    <Compile Include="PluginManagerActionEventArgs.cs" />
    95     <Compile Include="DependencyAttribute.cs" />
    96102    <Compile Include="Interfaces\IPlugin.cs" />
    97103    <Compile Include="DiscoveryService.cs" />
    98     <Compile Include="PluginFileAttribute.cs" />
    99104    <Compile Include="PluginInfo.cs" />
    100105    <Compile Include="Loader.cs" />
  • branches/PluginInfrastructure Refactoring/HeuristicLab.PluginInfrastructure/Interfaces/IApplication.cs

    r242 r2475  
    2929    Version Version { get; }
    3030    string Description { get;}
    31     bool AutoRestart { get; }
     31    bool RestartOnErrors { get; }
    3232    void Run();
    3333  }
  • branches/PluginInfrastructure Refactoring/HeuristicLab.PluginInfrastructure/Interfaces/IPlugin.cs

    r1229 r2475  
    3030  /// assemblies of the plugin. Plugin developers can use the properties of this interface to store
    3131  /// plugin data (name, version, files, update location ...).
    32   /// The methods OnLoad(), OnInstall(), OnDelete(), OnPreUpdate(), OnPostUpdate() are called by the framework
    33   /// when the corresponding actions are executed. This mechanism allows that the plugin reacts to such
    34   /// events. For instance to store plugin specific settings.
     32  /// The method OnLoad() is called by the framework when the plugin is loaded (application start).
    3533  /// </summary>
    36   interface IPlugin {
     34  internal interface IPlugin {
     35    /// <summary>
     36    /// Gets the name of the plugin.
     37    /// </summary>
    3738    string Name { get; }
     39    /// <summary>
     40    /// Gets the version of the plugin.
     41    /// </summary>
    3842    Version Version { get; }
    3943    /// <summary>
    40     /// a list of all files that are bundled with this plugin including all assembly files (*.dll)
     44    /// Gets all file names that are bundled with this plugin including all assembly files (*.dll)
    4145    /// </summary>
    42     string[] Files { get; }
    43 
     46    IEnumerable<string> FileNames { get; }
    4447
    4548    /// <summary>
    4649    /// Called by the framework whenever the plugin is loaded.
    47     /// Plugins are loaded once at startup and then each time a new application is started from the starter.
     50    /// Plugins are loaded when a new application is started from the starter.
    4851    /// </summary>
    4952    void OnLoad();
    50     /// <summary>
    51     /// called by the framework after the plugin was successfully installed
    52     /// </summary>
    53     void OnInstall();
    54     /// <summary>
    55     /// called by the framework before the files of the plugin are deleted
    56     /// </summary>
    57     void OnDelete();
    58     /// <summary>
    59     /// called by the framework before the files of the plugin are deleted for an update
    60     /// OnPreUpdate() is sent only to the old instance of the plugin
    61     /// </summary>
    62     void OnPreUpdate();
    63     /// <summary>
    64     /// called by the framework after the updated files for the plugin have been installed
    65     /// OnPostUpdate() is sent only to the new updated instance of the plugin
    66     /// </summary>
    67     void OnPostUpdate();
    6853  }
    6954}
  • branches/PluginInfrastructure Refactoring/HeuristicLab.PluginInfrastructure/InvalidPluginException.cs

    r1189 r2475  
    2828  /// Exception class for invalid plugins.
    2929  /// </summary>
    30   class InvalidPluginException : Exception {
     30  internal class InvalidPluginException : Exception {
     31    public InvalidPluginException(string message) : base(message) { }
    3132  }
    3233}
  • branches/PluginInfrastructure Refactoring/HeuristicLab.PluginInfrastructure/Loader.cs

    r2168 r2475  
    127127        info.Version = application.Version;
    128128        info.Description = application.Description;
    129         info.AutoRestart = application.AutoRestart;
     129        info.AutoRestart = application.RestartOnErrors;
    130130        info.PluginAssembly = application.GetType().Assembly.GetName().Name;
    131131        info.PluginType = application.GetType().Namespace + "." + application.GetType().Name;
     
    380380      string baseDir = AppDomain.CurrentDomain.BaseDirectory;
    381381
    382       Array.ForEach<string>(plugin.Files, delegate(string file) {
     382      Array.ForEach<string>(plugin.FileNames, delegate(string file) {
    383383        string filename = pluginDir + "/" + file;
    384384        // always use \ as the directory separator
Note: See TracChangeset for help on using the changeset viewer.