VirtualBox

source: vbox/trunk/src/VBox/Main/idl/VirtualBox.dtd@ 95512

Last change on this file since 95512 was 94601, checked in by vboxsync, 3 years ago

Main/idl: Prepare for RESTful API, including DTD. bugref:9166

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 8.3 KB
Line 
1<!--
2 Unofficial DTD for the VirtualBox.xidl file. This is not currently used:
3 neither by the VirtualBox build process nor at runtime, so it's not shipped
4 with the product either, and thus not guaranteed to be up to date.
5 It is still the only sort-of-documentation available about what is valid
6 XIDL syntax.
7
8 Copyright (C) 2008-2020 Oracle Corporation
9
10 This file is part of VirtualBox Open Source Edition (OSE), as
11 available from http://www.virtualbox.org. This file is free software;
12 you can redistribute it and/or modify it under the terms of the GNU
13 General Public License (GPL) as published by the Free Software
14 Foundation, in version 2 as it comes in the "COPYING" file of the
15 VirtualBox OSE distribution. VirtualBox OSE is distributed in the
16 hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
17-->
18 <!ELEMENT idl (desc|if|library)*> <!-- done -->
19 <!ELEMENT if ANY> <!-- done -->
20 <!ATTLIST if target (midl|xpidl|wsdl) #REQUIRED>
21 <!ELEMENT cpp ANY> <!-- done -->
22 <!ATTLIST cpp line CDATA #IMPLIED>
23 <!ELEMENT library (application|if)*> <!-- done -->
24 <!ATTLIST library name CDATA #REQUIRED>
25 <!ATTLIST library uuid CDATA #REQUIRED>
26 <!ATTLIST library version CDATA #REQUIRED>
27 <!ELEMENT application (descGroup|if|result|enum|interface|module)*> <!-- done -->
28 <!ATTLIST application name CDATA #REQUIRED>
29 <!ATTLIST application uuid CDATA #REQUIRED>
30 <!ATTLIST application supportsErrorInfo CDATA #REQUIRED>
31 <!ELEMENT result (#PCDATA|desc|link)*> <!-- done -->
32 <!ATTLIST result name CDATA #REQUIRED>
33 <!ATTLIST result value CDATA #IMPLIED>
34 <!ELEMENT module (class)*> <!-- done -->
35 <!ATTLIST module name CDATA #REQUIRED>
36 <!ATTLIST module context CDATA #REQUIRED>
37 <!ATTLIST module threadingModel CDATA #IMPLIED>
38 <!ELEMENT enum (desc?, const+)> <!-- done -->
39 <!ATTLIST enum name CDATA #REQUIRED>
40 <!ATTLIST enum uuid CDATA #REQUIRED>
41 <!ELEMENT const (desc?)> <!-- done -->
42 <!ATTLIST const name CDATA #REQUIRED>
43 <!ATTLIST const value CDATA #REQUIRED>
44 <!ATTLIST const wsmap (managed|suppress) "managed">
45 <!ELEMENT interface (desc?, (attribute|method|class|if)*)> <!-- done -->
46 <!ATTLIST interface name CDATA #REQUIRED>
47 <!ATTLIST interface extends CDATA #IMPLIED>
48 <!ATTLIST interface uuid CDATA #IMPLIED>
49 <!ATTLIST interface supportsErrorInfo (yes|no) #IMPLIED>
50 <!ATTLIST interface default (yes|no) "no">
51 <!ATTLIST interface internal (yes|no) "no">
52 <!ATTLIST interface wsmap (fail|global|struct|managed|suppress) "fail">
53 <!-- wsmap specifies how this interface is mapped to the
54 web services API (WSDL). One of the following must be specified:
55 fail: the default value, for which vboxweb.xsl will raise an error and die.
56 global: object is a singleton and resides in global variable in the web service.
57 managed: objects of this type are referenced by managed object referenced
58 struct: object is a simple struct and can be copied as such
59 suppress: Skip this interface entirely, and all methods that use it -->
60 <!ATTLIST interface wscpp (generate|hardcoded) "generate">
61 <!-- wscpp specifies whether C++ code should be generated in methodmaps.cpp
62 as a mapper to COM APIs. By default, this is "generate"; however, if set
63 to "hardcoded", then no automatic C++ code should be generated. This is done
64 for webservice APIs that have no counterpart in COM and are hard-coded in
65 the webservice server, such as IManagedObjectReference and ISessionManager. -->
66 <!ATTLIST interface rest (managed|suppress) "suppress">
67 <!-- rest specifies how this interface is mapped to the
68 web services API (RESTful). One of the following must be specified:
69 managed: objects of this type are represented
70 suppress: the default value, skip this interface entirely -->
71 <!ATTLIST interface autogen CDATA #IMPLIED>
72 <!-- autogen names the style of code auto-generation for this
73 interface (currently only VBoxEvent). -->
74 <!ATTLIST interface autogenflags CDATA #IMPLIED>
75 <!-- autogenflags contains autogen tweaks.
76 For autoget=VBoxEvent: 'BSTR' - generate IN_BSTR variants of the functions. -->
77 <!ATTLIST interface id CDATA #IMPLIED>
78 <!-- id is only relevant for event interfaces, and specifies
79 which const name will be generated. -->
80 <!ATTLIST interface waitable (yes|no) "no">
81 <!-- waitable is only relevant for event interfaces, and
82 specifies that this event can be waited for. -->
83 <!ATTLIST interface wrap-hint-server-addinterfaces CDATA #IMPLIED>
84 <!ATTLIST interface wrap-hint-server CDATA #IMPLIED>
85 <!ATTLIST interface wrap-gen-hook (yes|no) "no">
86 <!ATTLIST interface notdual (yes|no) "no">
87 <!-- DTrace has a probe name length limit, so dtracename helps dealing with excessivly long names. -->
88 <!ATTLIST interface dtracename CDATA #IMPLIED>
89 <!ATTLIST interface reservedAttributes CDATA #IMPLIED>
90 <!ATTLIST interface reservedMethods CDATA #IMPLIED>
91 <!ELEMENT class (interface)> <!-- done -->
92 <!ATTLIST class name CDATA #REQUIRED>
93 <!ATTLIST class uuid CDATA #REQUIRED>
94 <!ATTLIST class namespace CDATA #REQUIRED>
95 <!ELEMENT attribute (desc?)> <!-- done -->
96 <!ATTLIST attribute name CDATA #REQUIRED>
97 <!ATTLIST attribute type CDATA #REQUIRED>
98 <!ATTLIST attribute default CDATA #IMPLIED>
99 <!ATTLIST attribute readonly (yes|no) "no">
100 <!ATTLIST attribute mod (ptr|string) #IMPLIED>
101 <!ATTLIST attribute internal (yes|no) "no">
102 <!ATTLIST attribute safearray (yes|no) "no">
103 <!ATTLIST attribute wsmap (managed|suppress) "managed">
104 <!ATTLIST attribute rest (uuid|suppress|default) "default">
105 <!ATTLIST attribute wrap-hint-server CDATA #IMPLIED>
106 <!-- DTrace has a probe name length limit, so dtracename helps dealing with excessivly long names. -->
107 <!ATTLIST attribute dtracename CDATA #IMPLIED>
108 <!ELEMENT method (rest?,desc?,param*,result*)> <!-- done -->
109 <!ATTLIST method name CDATA #REQUIRED>
110 <!ATTLIST method const CDATA "no">
111 <!ATTLIST method internal (yes|no) "no">
112 <!ATTLIST method wsmap (managed|suppress) "managed">
113 <!ATTLIST method wrap-hint-server CDATA #IMPLIED>
114 <!-- DTrace has a probe name length limit, so dtracename helps dealing with excessivly long names. -->
115 <!ATTLIST method dtracename CDATA #IMPLIED>
116 <!ELEMENT rest ANY> <!-- done -->
117 <!ATTLIST rest name CDATA #IMPLIED>
118 <!ATTLIST rest request (get|put|post|delete|patch) "get">
119 <!ATTLIST rest path CDATA #REQUIRED>
120 <!ELEMENT param (desc?)> <!-- done -->
121 <!ATTLIST param name CDATA #REQUIRED>
122 <!ATTLIST param type CDATA #REQUIRED>
123 <!ATTLIST param dir (in|out|return) #REQUIRED>
124 <!ATTLIST param mod (ptr|string) #IMPLIED>
125 <!ATTLIST param safearray (yes|no) "no">
126 <!ELEMENT descGroup (desc)*> <!-- done (ignoring, butt-ugly hack, improper nesting enforced all over the .xsl files!) -->
127 <!ATTLIST descGroup id CDATA #IMPLIED>
128 <!ATTLIST descGroup title CDATA #IMPLIED>
129 <!ELEMENT desc (#PCDATA|link|note|see|b|tt|i|pre|para|ul|ol|h3|table|result)*> <!-- done (ignoring) -->
130 <!-- the following only appear within descriptions -->
131 <!ELEMENT link (#PCDATA)>
132 <!ATTLIST link to CDATA #REQUIRED>
133 <!ELEMENT h3 ANY>
134 <!ELEMENT para ANY>
135 <!ELEMENT b ANY>
136 <!ELEMENT i ANY>
137 <!ELEMENT ul (#PCDATA|li)*>
138 <!ELEMENT ol (#PCDATA|li)*>
139 <!ELEMENT li ANY>
140 <!ELEMENT pre ANY>
141 <!ELEMENT tt ANY>
142 <!ELEMENT see (#PCDATA|link)*>
143 <!ELEMENT note ANY>
144 <!ATTLIST note internal (yes|no) "no">
145 <!ELEMENT table (tr)+>
146 <!ELEMENT tr (td|th)+>
147 <!ELEMENT th ANY>
148 <!ELEMENT td ANY>
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette