]> gerrit.simantics Code Review - simantics/platform.git/blob - bundles/org.simantics.ui/schema/resourceEditorAdapter.exsd
Testing SonarQube with Simantics Platform SDK
[simantics/platform.git] / bundles / org.simantics.ui / schema / resourceEditorAdapter.exsd
1 <?xml version='1.0' encoding='UTF-8'?>\r
2 <!-- Schema file written by PDE -->\r
3 <schema targetNamespace="org.simantics.ui" xmlns="http://www.w3.org/2001/XMLSchema">\r
4 <annotation>\r
5       <appInfo>\r
6          <meta.schema plugin="org.simantics.ui" id="resourceEditorAdapter" name="Resource Editor Adapter"/>\r
7       </appInfo>\r
8       <documentation>\r
9          &lt;p&gt;\r
10 This extension point allows definition of adapter classes that can open views or editors for specified input selections.\r
11 &lt;/p&gt;\r
12 \r
13 &lt;p&gt;\r
14 A priority can be associated to each adapter to provide an ordering for adapters that can handle a specified input. Default priority is 0.\r
15 &lt;/p&gt;\r
16 \r
17 &lt;p&gt;\r
18 A group can be assigned for adapters that allows shadowing based on adapter priority. Only the highest priority adapter of all adapters belonging to the same group will be selected when requesting for suitable adapters for an input. See the extension point description element descriptions for details.\r
19 &lt;/p&gt;\r
20       </documentation>\r
21    </annotation>\r
22 \r
23    <element name="extension">\r
24       <annotation>\r
25          <appInfo>\r
26             <meta.element />\r
27          </appInfo>\r
28       </annotation>\r
29       <complexType>\r
30          <sequence>\r
31             <element ref="group" minOccurs="0" maxOccurs="unbounded"/>\r
32             <element ref="adapter" minOccurs="0" maxOccurs="unbounded"/>\r
33             <element ref="adapterClass" minOccurs="0" maxOccurs="unbounded"/>\r
34          </sequence>\r
35          <attribute name="point" type="string" use="required">\r
36             <annotation>\r
37                <documentation>\r
38                   \r
39                </documentation>\r
40             </annotation>\r
41          </attribute>\r
42          <attribute name="id" type="string">\r
43             <annotation>\r
44                <documentation>\r
45                   \r
46                </documentation>\r
47             </annotation>\r
48          </attribute>\r
49          <attribute name="name" type="string">\r
50             <annotation>\r
51                <documentation>\r
52                   \r
53                </documentation>\r
54                <appInfo>\r
55                   <meta.attribute translatable="true"/>\r
56                </appInfo>\r
57             </annotation>\r
58          </attribute>\r
59       </complexType>\r
60    </element>\r
61 \r
62    <element name="adapter">\r
63       <annotation>\r
64          <appInfo>\r
65             <meta.element labelAttribute="editorId" icon="image"/>\r
66          </appInfo>\r
67          <documentation>\r
68             This element specifies an adapter that can be used to open an eclipse editor part for a database resource of the specified type.\r
69          </documentation>\r
70       </annotation>\r
71       <complexType>\r
72          <choice minOccurs="0" maxOccurs="1">\r
73             <element ref="inContext" minOccurs="1" maxOccurs="unbounded"/>\r
74          </choice>\r
75          <attribute name="editorId" type="string" use="required">\r
76             <annotation>\r
77                <documentation>\r
78                   The ID of an IEditorPart registered through the &lt;code&gt;org.eclipse.ui.editor&lt;/code&gt; extension point.\r
79                </documentation>\r
80             </annotation>\r
81          </attribute>\r
82          <attribute name="id" type="string">\r
83             <annotation>\r
84                <documentation>\r
85                   A unique identifier for this adapter.\r
86                </documentation>\r
87             </annotation>\r
88          </attribute>\r
89          <attribute name="groupId" type="string">\r
90             <annotation>\r
91                <documentation>\r
92                   A group identifier for this adapter. Adapters that belong to the same group shadow each other based on their priority - higher priority shadows lower.\r
93                </documentation>\r
94                <appInfo>\r
95                   <meta.attribute kind="identifier" basedOn="org.simantics.ui.resourceEditorAdapter/group/@id"/>\r
96                </appInfo>\r
97             </annotation>\r
98          </attribute>\r
99          <attribute name="type_uris" type="string">\r
100             <annotation>\r
101                <documentation>\r
102                   A comma-separated list of types that are accepted by this adapter, specified as URI strings. For example to accept only diagram instances, &lt;code&gt;http://www.vtt.fi/Simantics/Diagram/1.0/Types#Diagram&lt;/code&gt; would be given as the value.\r
103                </documentation>\r
104             </annotation>\r
105          </attribute>\r
106          <attribute name="priority" type="string" use="default" value="0">\r
107             <annotation>\r
108                <documentation>\r
109                   An integer number number to describe the importance of this adapter with respect to other adapters. A larger number means higher priority. A negative priority means that the action is never selected as a default performed action even if it is the only action available for the specified input.\r
110                </documentation>\r
111             </annotation>\r
112          </attribute>\r
113          <attribute name="label" type="string">\r
114             <annotation>\r
115                <documentation>\r
116                   An optional overriding label to describe this adapter. If not specified the label is retrieved from the &lt;code&gt;IEditorPart&lt;/code&gt; referenced by the editorId attribute.\r
117                </documentation>\r
118             </annotation>\r
119          </attribute>\r
120          <attribute name="image" type="string">\r
121             <annotation>\r
122                <documentation>\r
123                   An optional overriding image to describe this adapter. If not specified the image is retrieved from the &lt;code&gt;IEditorPart&lt;/code&gt; referenced by the editorId attribute.\r
124                </documentation>\r
125                <appInfo>\r
126                   <meta.attribute kind="resource"/>\r
127                </appInfo>\r
128             </annotation>\r
129          </attribute>\r
130       </complexType>\r
131    </element>\r
132 \r
133    <element name="adapterClass">\r
134       <annotation>\r
135          <appInfo>\r
136             <meta.element labelAttribute="class"/>\r
137          </appInfo>\r
138          <documentation>\r
139             This element specifies a customized adapter that can be used to perform any activity when the user selects a database resource of an allowed type. Both, the decision of which resources are allowed and what kind of action to perform on the resource, are up to the &lt;code&gt;ResourceEditorAdapter&lt;/code&gt; extension specified by the &lt;code&gt;class&lt;/code&gt; attribute.\r
140          </documentation>\r
141       </annotation>\r
142       <complexType>\r
143          <choice minOccurs="0" maxOccurs="1">\r
144             <element ref="inContext" minOccurs="1" maxOccurs="unbounded"/>\r
145          </choice>\r
146          <attribute name="id" type="string">\r
147             <annotation>\r
148                <documentation>\r
149                   A unique identifier for this adapter.\r
150                </documentation>\r
151             </annotation>\r
152          </attribute>\r
153          <attribute name="groupId" type="string">\r
154             <annotation>\r
155                <documentation>\r
156                   A group identifier for this adapter. Adapters that belong to the same group shadow each other based on their priority - higher priority shadows lower.\r
157                </documentation>\r
158                <appInfo>\r
159                   <meta.attribute kind="identifier" basedOn="org.simantics.ui.resourceEditorAdapter/group/@id"/>\r
160                </appInfo>\r
161             </annotation>\r
162          </attribute>\r
163          <attribute name="class" type="string" use="required">\r
164             <annotation>\r
165                <documentation>\r
166                   The class that implements the &lt;code&gt;org.simantics.ui.workbench.editor.EditorAdapter&lt;/code&gt; interface to perform the actions deemed necessary for a partciular adapter. Implementers must extend the AbstractResourceEditorAdapter class, otherwise the priority attribute will have no effect.\r
167                </documentation>\r
168                <appInfo>\r
169                   <meta.attribute kind="java" basedOn="org.simantics.ui.workbench.editor.AbstractResourceEditorAdapter:org.simantics.ui.workbench.editor.EditorAdapter"/>\r
170                </appInfo>\r
171             </annotation>\r
172          </attribute>\r
173          <attribute name="priority" type="string" use="default" value="0">\r
174             <annotation>\r
175                <documentation>\r
176                   An integer number number to describe the importance of this adapter with respect to other adapters. A larger number means higher priority. A negative priority means that the action is never selected as a default performed action even if it is the only action available for the specified input. This priority value will only have an effect if the class extends &lt;code&gt;org.simantics.proconf.ui.workbench.editor.AbstractResourceEditorAdapter&lt;/code&gt;.\r
177                </documentation>\r
178             </annotation>\r
179          </attribute>\r
180       </complexType>\r
181    </element>\r
182 \r
183    <element name="group">\r
184       <complexType>\r
185          <attribute name="id" type="string" use="required">\r
186             <annotation>\r
187                <documentation>\r
188                   \r
189                </documentation>\r
190             </annotation>\r
191          </attribute>\r
192       </complexType>\r
193    </element>\r
194 \r
195    <element name="inContext">\r
196       <annotation>\r
197          <documentation>\r
198             This element specifies a reference to a context (contributed via org.eclipse.ui.contexts).\r
199          </documentation>\r
200       </annotation>\r
201       <complexType>\r
202          <attribute name="id" type="string" use="required">\r
203             <annotation>\r
204                <documentation>\r
205                   A reference to the ID of a context extension in the org.eclipse.ui.contexts extension point.\r
206                </documentation>\r
207                <appInfo>\r
208                   <meta.attribute kind="identifier" basedOn="org.eclipse.ui.contexts/context/@id"/>\r
209                </appInfo>\r
210             </annotation>\r
211          </attribute>\r
212       </complexType>\r
213    </element>\r
214 \r
215 \r
216    <annotation>\r
217       <appInfo>\r
218          <meta.section type="examples"/>\r
219       </appInfo>\r
220       <documentation>\r
221          &lt;pre&gt;\r
222    &lt;extension\r
223          point=&quot;org.simantics.ui.resourceEditorAdapter&quot;&gt;\r
224       &lt;!-- A fully declarative editor adapter definition for graph resources. Editor is opened by SimpleEditorAdapter. --&gt;\r
225       &lt;adapter\r
226             editorId=&quot;org.simantics.example.diagramEditor&quot;\r
227             id=&quot;org.simantics.example.diagramEditor&quot;\r
228             priority=&quot;100&quot;\r
229             groupId=&quot;org.simantics.example.group&quot;\r
230             type_uris=&quot;http://www.simantics.org/Simantics/Diagram/2.0#Diagram&quot;&gt;\r
231          &lt;inContext\r
232                id=&quot;org.simantics.example.context&quot;&gt;\r
233          &lt;/inContext&gt;\r
234       &lt;/adapter&gt;\r
235       &lt;!-- A programmatic editor adapter definition, editor is opened by adapter class. --&gt;\r
236       &lt;adapterClass\r
237             class=&quot;org.simantics.example.MyEditorAdapter&quot;\r
238             id=&quot;org.simantics.example.myEditorAdapter&quot;\r
239             groupId=&quot;org.simantics.example.group&quot;\r
240             priority=&quot;50&quot;&gt;\r
241       &lt;/adapterClass&gt;\r
242    &lt;/extension&gt;\r
243 &lt;/pre&gt;\r
244       </documentation>\r
245    </annotation>\r
246 \r
247 \r
248    <annotation>\r
249       <appInfo>\r
250          <meta.section type="implementation"/>\r
251       </appInfo>\r
252       <documentation>\r
253          See &lt;code&gt;org.simantics.ui.workbench.editor.EditorRegistry&lt;/code&gt; for the front-end to this extension point.\r
254       </documentation>\r
255    </annotation>\r
256 \r
257 \r
258 </schema>\r