Free cookie consent management tool by TermsFeed Policy Generator

source: branches/HeuristicLab.Hive_Milestone2/sources/HeuristicLab.PluginInfrastructure/Interfaces/IPlugin.cs @ 6347

Last change on this file since 6347 was 1229, checked in by gkronber, 16 years ago

Merged implementation of #471 (OnLoad hook for plugins) (r1228) from CEDMA branch into the trunk.

File size: 2.7 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  /// Represents a plugin.
29  /// Plugin developers have to include exactly one class that implements this interface in one of the
30  /// assemblies of the plugin. Plugin developers can use the properties of this interface to store
31  /// 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.
35  /// </summary>
36  interface IPlugin {
37    string Name { get; }
38    Version Version { get; }
39    /// <summary>
40    /// a list of all files that are bundled with this plugin including all assembly files (*.dll)
41    /// </summary>
42    string[] Files { get; }
43
44
45    /// <summary>
46    /// 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.
48    /// </summary>
49    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();
68  }
69}
Note: See TracBrowser for help on using the repository browser.