1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32 package com.unitesk.atp.tool;
33
34 import com.unitesk.atp.messages.MessageBox;
35
36 /***
37 * Plugin manager interface.
38 *
39 * @author <A href="mailto:demakov@ispras.ru">Alexey Demakov</A>
40 * @version $Id: PluginManager.java,v 1.1 2004/10/09 06:43:21 all-x Exp $
41 */
42 public interface PluginManager
43 {
44 /***
45 * Get plugin manager name.
46 */
47 String getName();
48
49 /***
50 * Returns message box.
51 */
52 MessageBox getMessageBox();
53
54 /***
55 * Returns the plugin with the specified name.
56 *
57 * @param name The plugin name.
58 * @return The plugin with the specified name or <code>null</code>.
59 */
60 Object getPlugin( String name );
61
62 /***
63 * Gets the qualified property name for plugin property name
64 * of the specified plugin.
65 *
66 * @param plugin The specified plugin.
67 * @param name The name of <code>plugin</code> property.
68 * @return The corresponding qualified property name.
69 * For plugin property <code>property.name</code>
70 * of plugin with name <code>plugin</code>
71 * of manager <code>manager</code>
72 * qualified property name is
73 * <code>manager.plugin.property.name</code>.
74 *
75 * @throws IllegalArgumentException
76 * If <code>plugin</code> is not a plugin of this manager.
77 *
78 * @see DynamicVariablesTable#getPropertyName(Object,String)
79 */
80 String getPluginPropertyName( Object plugin, String name );
81
82 /***
83 * Gets the value of a plugin property with the specified name
84 * for the specified plugin.
85 *
86 * @param plugin The specified plugin.
87 * @param name The name of <code>plugin</code> property.
88 * @return The value of the plugin property
89 * for the specified plugin.
90 * @throws IllegalArgumentException
91 * If <code>plugin</code> is not a plugin of this manager.
92 * @see DynamicVariablesTable#getProperty(Object,String)
93 */
94 String getPluginProperty( Object plugin, String name );
95
96 /***
97 * Gets the value of a plugin property with the specified name
98 * for the specified plugin
99 * or default value if this property is not defined.
100 *
101 * @param plugin The specified plugin.
102 * @param name The name of <code>plugin</code> property.
103 * @param value The default value is used if for the specified plugin
104 * there is no property with the specified name.
105 * @return The value of the plugin property
106 * for the specified plugin.
107 * @throws IllegalArgumentException
108 * If <code>plugin</code> is not a plugin of this manager.
109 * @see DynamicVariablesTable#getProperty(Object,String,String)
110 */
111 String getPluginProperty( Object plugin, String name, String value );
112 }