~ubuntu-branches/ubuntu/trusty/monodevelop/trusty-proposed

« back to all changes in this revision

Viewing changes to external/mono-addins/docs/Mono.Addins/ExtensionNode.xml

  • Committer: Package Import Robot
  • Author(s): Jo Shields
  • Date: 2013-05-12 09:46:03 UTC
  • mto: This revision was merged to the branch mainline in revision 29.
  • Revision ID: package-import@ubuntu.com-20130512094603-mad323bzcxvmcam0
Tags: upstream-4.0.5+dfsg
ImportĀ upstreamĀ versionĀ 4.0.5+dfsg

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
<Type Name="ExtensionNode" FullName="Mono.Addins.ExtensionNode">
 
2
  <TypeSignature Language="C#" Value="public class ExtensionNode" />
 
3
  <AssemblyInfo>
 
4
    <AssemblyName>Mono.Addins</AssemblyName>
 
5
    <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
6
    <AssemblyVersion>1.0.0.0</AssemblyVersion>
 
7
  </AssemblyInfo>
 
8
  <Base>
 
9
    <BaseTypeName>System.Object</BaseTypeName>
 
10
  </Base>
 
11
  <Interfaces />
 
12
  <Docs>
 
13
    <summary>A node of the extension tree.</summary>
 
14
    <remarks>
 
15
      <para>
 
16
An extension node is an element registered by an add-in in an extension point. A host can get nodes registered in an extension point using methods such as <see cref="M:Mono.Addins.AddinManager.GetExtensionNodes(System.String)" />, which returns a collection of ExtensionNode objects.
 
17
</para>
 
18
      <para>
 
19
ExtensionNode will normally be used as a base class of more complex extension point types. The most common subclass is <see cref="T:Mono.Addins.TypeExtensionNode" />, which allows registering a class implemented in an add-in.
 
20
</para>
 
21
      <para>
 
22
EXAMPLE: An application has a toolbar that must be extensible by add-ins. The application could define the following extension node type:
 
23
</para>
 
24
      <example>
 
25
        <code lang="C#">
 
26
        public class ToolbarItemNode: ExtensionNode
 
27
        {
 
28
                [NodeAttribute]
 
29
                string icon;
 
30
                
 
31
                [NodeAttribute]
 
32
                string label;
 
33
                
 
34
                public string Icon {
 
35
                        get { return icon; }
 
36
                }
 
37
                
 
38
                public string Label {
 
39
                        get { return label; }
 
40
                }
 
41
        }
 
42
  </code>
 
43
      </example>
 
44
      <para>
 
45
In the implementation of an ExtensionNode, the <see cref="T:Mono.Addins.NodeAttributeAttribute" /> attribute can be applied to fields to specify which attributes must be loaded from the node.
 
46
</para>
 
47
      <para>
 
48
The extension point could be defined like this:
 
49
</para>
 
50
      <example>
 
51
        <code lang="XML">
 
52
&lt;Addin id = "SomeApplication" version = "0.1.0" isroot="true"&gt;
 
53
        ...
 
54
        &lt;ExtensionPoint path = "/MainWindow/Toolbar"&gt;
 
55
                &lt;ExtensionNode id="ToolbarItem" type="ToolbarItemNode"/&gt;
 
56
        &lt;/ExtensionPoint&gt;
 
57
        ...
 
58
&lt;/Addin&gt;
 
59
  </code>
 
60
      </example>
 
61
      <para>
 
62
An add-in could extend the toolbar by registering new nodes in the extension point like this:
 
63
</para>
 
64
      <example>
 
65
        <code lang="XML">
 
66
&lt;Addin id = "SomeAddin" version = "0.1.0"&gt;
 
67
        ...
 
68
        &lt;Extension path = "/MainWindow/Toolbar"&gt;
 
69
                &lt;ToolbarItem label="Open" icon="gtk-open"/&gt;
 
70
                &lt;ToolbarItem label="New" icon="gtk-new"/&gt;
 
71
        &lt;/Extension&gt;
 
72
        ...
 
73
&lt;/Addin&gt;
 
74
  </code>
 
75
      </example>
 
76
      <para>
 
77
To create the toolbar, the host application would get the nodes registered in the extension point:
 
78
</para>
 
79
      <example>
 
80
        <code lang="C#">
 
81
        foreach (ToolbarItemNode node in AddinManager.GetExtensionNodes ("/MainWindow/Toolbar")) {
 
82
                Gtk.ToolButton it = new Gtk.ToolButton (new Gtk.Image (node.Icon, IconSize.SmallToolbar), node.Label);
 
83
                // Add the button to the toolbar
 
84
        }
 
85
 
 
86
  </code>
 
87
      </example>
 
88
    </remarks>
 
89
  </Docs>
 
90
  <Members>
 
91
    <Member MemberName=".ctor">
 
92
      <MemberSignature Language="C#" Value="public ExtensionNode ();" />
 
93
      <MemberType>Constructor</MemberType>
 
94
      <Parameters />
 
95
      <Docs>
 
96
        <summary>Creates an extension node.</summary>
 
97
        <remarks />
 
98
      </Docs>
 
99
      <AssemblyInfo>
 
100
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
101
      </AssemblyInfo>
 
102
    </Member>
 
103
    <Member MemberName="Addin">
 
104
      <MemberSignature Language="C#" Value="public Mono.Addins.RuntimeAddin Addin { get; }" />
 
105
      <MemberType>Property</MemberType>
 
106
      <ReturnValue>
 
107
        <ReturnType>Mono.Addins.RuntimeAddin</ReturnType>
 
108
      </ReturnValue>
 
109
      <Docs>
 
110
        <summary>The add-in that registered this extension node.</summary>
 
111
        <value>The add-in that created the node.</value>
 
112
        <remarks>This property provides access to the resources and types of the add-in that created this extension node.</remarks>
 
113
      </Docs>
 
114
      <AssemblyInfo>
 
115
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
116
      </AssemblyInfo>
 
117
    </Member>
 
118
    <Member MemberName="ChildNodes">
 
119
      <MemberSignature Language="C#" Value="public Mono.Addins.ExtensionNodeList ChildNodes { get; }" />
 
120
      <MemberType>Property</MemberType>
 
121
      <ReturnValue>
 
122
        <ReturnType>Mono.Addins.ExtensionNodeList</ReturnType>
 
123
      </ReturnValue>
 
124
      <Docs>
 
125
        <summary>Child nodes of this extension node.</summary>
 
126
        <value>A list of child nodes.</value>
 
127
        <remarks />
 
128
      </Docs>
 
129
      <AssemblyInfo>
 
130
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
131
      </AssemblyInfo>
 
132
    </Member>
 
133
    <Member MemberName="ExtensionContext">
 
134
      <MemberSignature Language="C#" Value="public Mono.Addins.ExtensionContext ExtensionContext { get; }" />
 
135
      <MemberType>Property</MemberType>
 
136
      <AssemblyInfo>
 
137
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
138
      </AssemblyInfo>
 
139
      <ReturnValue>
 
140
        <ReturnType>Mono.Addins.ExtensionContext</ReturnType>
 
141
      </ReturnValue>
 
142
      <Docs>
 
143
        <summary>To be added.</summary>
 
144
        <value>To be added.</value>
 
145
        <remarks>To be added.</remarks>
 
146
      </Docs>
 
147
    </Member>
 
148
    <Member MemberName="ExtensionNodeChanged">
 
149
      <MemberSignature Language="C#" Value="public event Mono.Addins.ExtensionNodeEventHandler ExtensionNodeChanged;" />
 
150
      <MemberType>Event</MemberType>
 
151
      <ReturnValue>
 
152
        <ReturnType>Mono.Addins.ExtensionNodeEventHandler</ReturnType>
 
153
      </ReturnValue>
 
154
      <Docs>
 
155
        <summary>To be added.</summary>
 
156
        <remarks>To be added.</remarks>
 
157
      </Docs>
 
158
      <AssemblyInfo>
 
159
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
160
      </AssemblyInfo>
 
161
    </Member>
 
162
    <Member MemberName="GetChildObjects">
 
163
      <MemberSignature Language="C#" Value="public object[] GetChildObjects ();" />
 
164
      <MemberType>Method</MemberType>
 
165
      <ReturnValue>
 
166
        <ReturnType>System.Object[]</ReturnType>
 
167
      </ReturnValue>
 
168
      <Parameters />
 
169
      <Docs>
 
170
        <summary>Returns the child objects of a node.</summary>
 
171
        <returns>An array of child objects.</returns>
 
172
        <remarks>This method only works if all children of this node are of type <see cref="T:Mono.Addins.TypeExtensionNode" />. The returned array is composed by all objects created by calling the <see cref="M:Mono.Addins.TypeExtensionNode.GetInstance()" /> method for each node.</remarks>
 
173
      </Docs>
 
174
      <AssemblyInfo>
 
175
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
176
      </AssemblyInfo>
 
177
    </Member>
 
178
    <Member MemberName="GetChildObjects">
 
179
      <MemberSignature Language="C#" Value="public object[] GetChildObjects (bool reuseCachedInstance);" />
 
180
      <MemberType>Method</MemberType>
 
181
      <ReturnValue>
 
182
        <ReturnType>System.Object[]</ReturnType>
 
183
      </ReturnValue>
 
184
      <Parameters>
 
185
        <Parameter Name="reuseCachedInstance" Type="System.Boolean" />
 
186
      </Parameters>
 
187
      <Docs>
 
188
        <param name="reuseCachedInstance">True if the method can reuse instances created in previous calls.</param>
 
189
        <summary>Returns the child objects of a node.</summary>
 
190
        <returns>An array of child objects.</returns>
 
191
        <remarks>This method only works if all children of this node are of type <see cref="T:Mono.Addins.TypeExtensionNode" />. The returned array is composed by all objects created by calling the <see cref="M:Mono.Addins.TypeExtensionNode.CreateInstance()" /> method for each node (or <see cref="M:Mono.Addins.TypeExtensionNode.GetInstance()" /> if reuseCachedInstance is set to true).</remarks>
 
192
      </Docs>
 
193
      <AssemblyInfo>
 
194
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
195
      </AssemblyInfo>
 
196
    </Member>
 
197
    <Member MemberName="GetChildObjects">
 
198
      <MemberSignature Language="C#" Value="public object[] GetChildObjects (Type arrayElementType);" />
 
199
      <MemberType>Method</MemberType>
 
200
      <ReturnValue>
 
201
        <ReturnType>System.Object[]</ReturnType>
 
202
      </ReturnValue>
 
203
      <Parameters>
 
204
        <Parameter Name="arrayElementType" Type="System.Type" />
 
205
      </Parameters>
 
206
      <Docs>
 
207
        <param name="arrayElementType">Type of the return array elements.</param>
 
208
        <summary>Returns the child objects of a node (with type check).</summary>
 
209
        <returns>An array of child objects.</returns>
 
210
        <remarks>This method only works if all children of this node are of type <see cref="T:Mono.Addins.TypeExtensionNode" />. The returned array is composed by all objects created by calling the <see cref="M:Mono.Addins.TypeExtensionNode.GetInstance(System.Type)" /> method for each node.
 
211
 
 
212
<para>
 
213
A <see cref="T:System.InvalidOperationException" /> exception is thrown if one of the found child objects is not a subclass of the provided type.
 
214
</para></remarks>
 
215
      </Docs>
 
216
      <AssemblyInfo>
 
217
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
218
      </AssemblyInfo>
 
219
    </Member>
 
220
    <Member MemberName="GetChildObjects">
 
221
      <MemberSignature Language="C#" Value="public object[] GetChildObjects (Type arrayElementType, bool reuseCachedInstance);" />
 
222
      <MemberType>Method</MemberType>
 
223
      <ReturnValue>
 
224
        <ReturnType>System.Object[]</ReturnType>
 
225
      </ReturnValue>
 
226
      <Parameters>
 
227
        <Parameter Name="arrayElementType" Type="System.Type" />
 
228
        <Parameter Name="reuseCachedInstance" Type="System.Boolean" />
 
229
      </Parameters>
 
230
      <Docs>
 
231
        <param name="arrayElementType">Type of the return array elements.</param>
 
232
        <param name="reuseCachedInstance">True if the method can reuse instances created in previous calls.</param>
 
233
        <summary>Returns the child objects of a node (with type check).</summary>
 
234
        <returns>An array of child objects.</returns>
 
235
        <remarks>
 
236
          <para>This method only works if all children of this node are of type <see cref="T:Mono.Addins.TypeExtensionNode" />. The returned array is composed by all objects created by calling the <see cref="M:Mono.Addins.TypeExtensionNode.CreateInstance(System.Type)" /> method for each node (or <see cref="M:Mono.Addins.TypeExtensionNode.GetInstance(System.Type)" /> if reuseCachedInstance is set to true).</para>
 
237
          <para>
 
238
A <see cref="T:System.InvalidOperationException" /> exception will be thrown if one of the found child objects is not a subclass of the provided type.
 
239
</para>
 
240
        </remarks>
 
241
      </Docs>
 
242
      <AssemblyInfo>
 
243
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
244
      </AssemblyInfo>
 
245
    </Member>
 
246
    <Member MemberName="HasId">
 
247
      <MemberSignature Language="C#" Value="public bool HasId { get; }" />
 
248
      <MemberType>Property</MemberType>
 
249
      <ReturnValue>
 
250
        <ReturnType>System.Boolean</ReturnType>
 
251
      </ReturnValue>
 
252
      <Docs>
 
253
        <summary>Specifies whether the extension node has as an Id or not.</summary>
 
254
        <value>True if this node has an user-specified id.</value>
 
255
        <remarks>It is not mandatory to specify an 'id' for a node. When none is provided, the add-in manager will automatically generate an unique id for the node. This property will return true if an 'id' was provided for the node, and false if the id was assigned by the add-in manager.</remarks>
 
256
      </Docs>
 
257
      <AssemblyInfo>
 
258
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
259
      </AssemblyInfo>
 
260
    </Member>
 
261
    <Member MemberName="Id">
 
262
      <MemberSignature Language="C#" Value="public string Id { get; }" />
 
263
      <MemberType>Property</MemberType>
 
264
      <ReturnValue>
 
265
        <ReturnType>System.String</ReturnType>
 
266
      </ReturnValue>
 
267
      <Docs>
 
268
        <summary>Identifier of the node.</summary>
 
269
        <value>Identifier of the node.</value>
 
270
        <remarks>It is not mandatory to specify an 'id' for a node. When none is provided, the add-in manager will automatically generate an unique id for the node. The <see cref="P:Mono.Addins.ExtensionNode.HasId" /> property can be used to know if the 'id' has been specified by the developer or not.</remarks>
 
271
      </Docs>
 
272
      <AssemblyInfo>
 
273
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
274
      </AssemblyInfo>
 
275
    </Member>
 
276
    <Member MemberName="OnAddinLoaded">
 
277
      <MemberSignature Language="C#" Value="protected virtual void OnAddinLoaded ();" />
 
278
      <MemberType>Method</MemberType>
 
279
      <ReturnValue>
 
280
        <ReturnType>System.Void</ReturnType>
 
281
      </ReturnValue>
 
282
      <Parameters />
 
283
      <Docs>
 
284
        <summary>Notifies that the owner add-in has been loaded.</summary>
 
285
        <remarks>This overridable method is called when the add-in that registered this node has been loaded in memory.</remarks>
 
286
      </Docs>
 
287
      <AssemblyInfo>
 
288
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
289
      </AssemblyInfo>
 
290
    </Member>
 
291
    <Member MemberName="OnAddinUnloaded">
 
292
      <MemberSignature Language="C#" Value="protected virtual void OnAddinUnloaded ();" />
 
293
      <MemberType>Method</MemberType>
 
294
      <ReturnValue>
 
295
        <ReturnType>System.Void</ReturnType>
 
296
      </ReturnValue>
 
297
      <Parameters />
 
298
      <Docs>
 
299
        <summary>Notifies that the owner add-in has been unloaded.</summary>
 
300
        <remarks>This overridable method is called when the add-in that registered this node has been unloaded from memory.</remarks>
 
301
      </Docs>
 
302
      <AssemblyInfo>
 
303
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
304
      </AssemblyInfo>
 
305
    </Member>
 
306
    <Member MemberName="OnChildNodeAdded">
 
307
      <MemberSignature Language="C#" Value="protected virtual void OnChildNodeAdded (Mono.Addins.ExtensionNode node);" />
 
308
      <MemberType>Method</MemberType>
 
309
      <ReturnValue>
 
310
        <ReturnType>System.Void</ReturnType>
 
311
      </ReturnValue>
 
312
      <Parameters>
 
313
        <Parameter Name="node" Type="Mono.Addins.ExtensionNode" />
 
314
      </Parameters>
 
315
      <Docs>
 
316
        <param name="node">The new child node.</param>
 
317
        <summary>Notifies the addition of a child node.</summary>
 
318
        <remarks>This method is called when a new child is added to this node. It may be due to changes in conditions or for an add-in being enabled. </remarks>
 
319
      </Docs>
 
320
      <AssemblyInfo>
 
321
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
322
      </AssemblyInfo>
 
323
    </Member>
 
324
    <Member MemberName="OnChildNodeRemoved">
 
325
      <MemberSignature Language="C#" Value="protected virtual void OnChildNodeRemoved (Mono.Addins.ExtensionNode node);" />
 
326
      <MemberType>Method</MemberType>
 
327
      <ReturnValue>
 
328
        <ReturnType>System.Void</ReturnType>
 
329
      </ReturnValue>
 
330
      <Parameters>
 
331
        <Parameter Name="node" Type="Mono.Addins.ExtensionNode" />
 
332
      </Parameters>
 
333
      <Docs>
 
334
        <param name="node">The removed node.</param>
 
335
        <summary>Notifies the removal of a child node.</summary>
 
336
        <remarks>This method is called when a child of this node is removed. It may be due to changes in conditions or for an add-in being disabled. </remarks>
 
337
      </Docs>
 
338
      <AssemblyInfo>
 
339
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
340
      </AssemblyInfo>
 
341
    </Member>
 
342
    <Member MemberName="OnChildrenChanged">
 
343
      <MemberSignature Language="C#" Value="protected virtual void OnChildrenChanged ();" />
 
344
      <MemberType>Method</MemberType>
 
345
      <ReturnValue>
 
346
        <ReturnType>System.Void</ReturnType>
 
347
      </ReturnValue>
 
348
      <Parameters />
 
349
      <Docs>
 
350
        <summary>Notifies changes in child nodes.</summary>
 
351
        <remarks>This method is called when child nodes are added or removed. It may be due to changes in conditions, or to add-ins being enabled or disabled.</remarks>
 
352
      </Docs>
 
353
      <AssemblyInfo>
 
354
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
355
      </AssemblyInfo>
 
356
    </Member>
 
357
    <Member MemberName="Parent">
 
358
      <MemberSignature Language="C#" Value="public Mono.Addins.ExtensionNode Parent { get; }" />
 
359
      <MemberType>Property</MemberType>
 
360
      <AssemblyInfo>
 
361
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
362
      </AssemblyInfo>
 
363
      <ReturnValue>
 
364
        <ReturnType>Mono.Addins.ExtensionNode</ReturnType>
 
365
      </ReturnValue>
 
366
      <Docs>
 
367
        <summary>To be added.</summary>
 
368
        <value>To be added.</value>
 
369
        <remarks>To be added.</remarks>
 
370
      </Docs>
 
371
    </Member>
 
372
    <Member MemberName="Path">
 
373
      <MemberSignature Language="C#" Value="public string Path { get; }" />
 
374
      <MemberType>Property</MemberType>
 
375
      <ReturnValue>
 
376
        <ReturnType>System.String</ReturnType>
 
377
      </ReturnValue>
 
378
      <Docs>
 
379
        <summary>Location of this node in the extension tree.</summary>
 
380
        <value>Path of the node.</value>
 
381
        <remarks>
 
382
          <para>
 
383
The node path is composed by the path of the extension point where it is defined, the identifiers of its parent nodes, and its own identifier. For example:
 
384
</para>
 
385
          <example>
 
386
            <code lang="XML">
 
387
        &lt;Extension path="/MonoDevelop/Workbench/MainMenu"&gt;
 
388
                &lt;ItemSet id="File" _label="_File"&gt;
 
389
                        &lt;CommandItem id="NewFile" /&gt;
 
390
                        &lt;CommandItem id="NewProject" /&gt;
 
391
                &lt;/ItemSet&gt;
 
392
        &lt;/Extension&gt;
 
393
        </code>
 
394
          </example>
 
395
          <para>
 
396
The path of the node "NewProject" would be "/MonoDevelop/Workbench/MainMenu/File/NewProject".
 
397
</para>
 
398
        </remarks>
 
399
      </Docs>
 
400
      <AssemblyInfo>
 
401
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
402
      </AssemblyInfo>
 
403
    </Member>
 
404
    <Member MemberName="Read">
 
405
      <MemberSignature Language="C#" Value="protected virtual void Read (Mono.Addins.NodeElement elem);" />
 
406
      <MemberType>Method</MemberType>
 
407
      <ReturnValue>
 
408
        <ReturnType>System.Void</ReturnType>
 
409
      </ReturnValue>
 
410
      <Parameters>
 
411
        <Parameter Name="elem" Type="Mono.Addins.NodeElement" />
 
412
      </Parameters>
 
413
      <Docs>
 
414
        <param name="elem">To be added.</param>
 
415
        <summary>To be added.</summary>
 
416
        <remarks>
 
417
          <para>ExtensionNode subclasses can override this method to take control on the process of loading an ExtensionNode instance out of an extension node. If the Read method is overriden (and if it doesn't call the base class) [<see cref="T:Mono.Addins.NodeAttributeAttribute" />] attributes will be ignored.</para>
 
418
          <para>The following example would be equivalent to the example shown for the class <see cref="T:Mono.Addins.NodeAttributeAttribute" />, but this implementation would be more efficient since no reflection would be involved:</para>
 
419
          <example>
 
420
            <code lang="C#">
 
421
public class FileTemplateNode: ExtensionNode
 
422
{
 
423
        string resource;
 
424
        string name;
 
425
        
 
426
        public string Name {
 
427
                get { return name != null ? name : Id; }
 
428
        }
 
429
 
 
430
        public virtual string GetContent ()
 
431
        {
 
432
                using (StreamReader sr = new StreamReader(Addin.GetResource (resource))) {
 
433
                        return sr.ReadToEnd (); 
 
434
                }
 
435
        }
 
436
 
 
437
        protected override void Read (NodeElement elem)
 
438
        {
 
439
                resource = elem.GetAttribute ("resource-name");
 
440
                name = elem.GetAttribute ("name");
 
441
        }
 
442
}
 
443
  </code>
 
444
          </example>
 
445
        </remarks>
 
446
      </Docs>
 
447
      <AssemblyInfo>
 
448
        <AssemblyVersion>0.4.0.0</AssemblyVersion>
 
449
      </AssemblyInfo>
 
450
    </Member>
 
451
  </Members>
 
452
</Type>