1 /* -*- Mode: IDL; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
3 * This Source Code Form is subject to the terms of the Mozilla Public
4 * License, v. 2.0. If a copy of the MPL was not distributed with this
5 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
7 /* The long avoided variant support for xpcom. */
9 #include
"nsISupports.idl"
14 // This enum class used to be a const-only XPIDL interface, containing literal
15 // integer descriptions of the different fields. Instead, it now directly
16 // references the nsXPTTypeTag variants VTYPE_ are intended to match.
20 // These MUST match the declarations in xptinfo.h.
21 // Otherwise the world is likely to explode.
22 VTYPE_INT8
= TD_INT8
,
23 VTYPE_INT16
= TD_INT16
,
24 VTYPE_INT32
= TD_INT32
,
25 VTYPE_INT64
= TD_INT64
,
26 VTYPE_UINT8
= TD_UINT8
,
27 VTYPE_UINT16
= TD_UINT16
,
28 VTYPE_UINT32
= TD_UINT32
,
29 VTYPE_UINT64
= TD_UINT64
,
30 VTYPE_FLOAT
= TD_FLOAT
,
31 VTYPE_DOUBLE
= TD_DOUBLE
,
32 VTYPE_BOOL
= TD_BOOL
,
33 VTYPE_CHAR
= TD_CHAR
,
34 VTYPE_WCHAR
= TD_WCHAR
,
35 VTYPE_VOID
= TD_VOID
,
36 VTYPE_ID
= TD_NSIDPTR
,
37 VTYPE_CHAR_STR
= TD_PSTRING
,
38 VTYPE_WCHAR_STR
= TD_PWSTRING
,
39 VTYPE_INTERFACE
= TD_INTERFACE_TYPE
,
40 VTYPE_INTERFACE_IS
= TD_INTERFACE_IS_TYPE
,
41 VTYPE_ARRAY
= TD_LEGACY_ARRAY
,
42 VTYPE_STRING_SIZE_IS
= TD_PSTRING_SIZE_IS
,
43 VTYPE_WSTRING_SIZE_IS
= TD_PWSTRING_SIZE_IS
,
44 VTYPE_UTF8STRING
= TD_UTF8STRING
,
45 VTYPE_CSTRING
= TD_CSTRING
,
46 VTYPE_ASTRING
= TD_ASTRING
,
48 // Non-xpt variant types
49 VTYPE_EMPTY_ARRAY
= 254 ,
57 * XPConnect has magic to transparently convert between nsIVariant and JS types.
58 * We mark the interface [scriptable] so that JS can use methods
59 * that refer to this interface. But we mark all the methods and attributes
60 * [noscript] since any nsIVariant object will be automatically converted to a
64 [scriptable
, builtinclass
, uuid(81e4c2de
-acac
-4ad6
-901a
-b5fb1b851a0d
)]
65 interface nsIVariant
: nsISupports
67 [notxpcom
,nostdcall
] readonly attribute uint16_t dataType
;
69 [noscript
] uint8_t getAsInt8
();
70 [noscript
] int16_t getAsInt16
();
71 [noscript
] int32_t getAsInt32
();
72 [noscript
] int64_t getAsInt64
();
73 [noscript
] uint8_t getAsUint8
();
74 [noscript
] uint16_t getAsUint16
();
75 [noscript
] uint32_t getAsUint32
();
76 [noscript
] uint64_t getAsUint64
();
77 [noscript
] float getAsFloat
();
78 [noscript
] double getAsDouble
();
79 [noscript
] boolean getAsBool
();
80 [noscript
] char getAsChar
();
81 [noscript
] wchar getAsWChar
();
82 [notxpcom
] nsresult getAsID
(out nsID
retval);
83 [noscript
] AString getAsAString
();
84 [noscript
] ACString getAsACString
();
85 [noscript
] AUTF8String getAsAUTF8String
();
86 [noscript
] string getAsString
();
87 [noscript
] wstring getAsWString
();
88 [noscript
] nsISupports getAsISupports
();
89 [noscript
] jsval getAsJSVal
();
91 [noscript
] void getAsInterface
(out nsIIDPtr iid
,
92 [iid_is(iid
), retval] out nsQIResult iface
);
94 [notxpcom
] nsresult getAsArray
(out uint16_t type
, out nsIID iid
,
95 out uint32_t count
, out voidPtr
ptr);
97 [noscript
] void getAsStringWithSize
(out uint32_t size
,
98 [size_is(size
), retval] out string str
);
100 [noscript
] void getAsWStringWithSize
(out uint32_t size
,
101 [size_is(size
), retval] out wstring str
);
105 * An object that implements nsIVariant may or may NOT also implement this
106 * nsIWritableVariant.
108 * If the 'writable' attribute is false then attempts to call any of the 'set'
109 * methods can be expected to fail. Setting the 'writable' attribute may or
114 [scriptable
, builtinclass
, uuid(5586a590
-8c82
-11d5
-90f3
-0010a4e73d9a
)]
115 interface nsIWritableVariant
: nsIVariant
117 attribute
boolean writable
;
119 void setAsInt8
(in uint8_t aValue
);
120 void setAsInt16
(in int16_t aValue
);
121 void setAsInt32
(in int32_t aValue
);
122 void setAsInt64
(in int64_t aValue
);
123 void setAsUint8
(in uint8_t aValue
);
124 void setAsUint16
(in uint16_t aValue
);
125 void setAsUint32
(in uint32_t aValue
);
126 void setAsUint64
(in uint64_t aValue
);
127 void setAsFloat
(in float aValue
);
128 void setAsDouble
(in double aValue
);
129 void setAsBool
(in boolean aValue
);
130 void setAsChar
(in char aValue
);
131 void setAsWChar
(in wchar aValue
);
132 void setAsID
(in nsIDRef aValue
);
133 void setAsAString
(in AString aValue
);
134 void setAsACString
(in ACString aValue
);
135 void setAsAUTF8String
(in AUTF8String aValue
);
136 void setAsString
(in string aValue
);
137 void setAsWString
(in wstring aValue
);
138 void setAsISupports
(in nsISupports aValue
);
140 void setAsInterface
(in nsIIDRef iid
,
141 [iid_is(iid
)] in nsQIResult iface
);
143 [noscript
] void setAsArray
(in uint16_t type
, in nsIIDPtr iid
,
144 in uint32_t count
, in voidPtr
ptr);
146 void setAsStringWithSize
(in uint32_t size
,
147 [size_is(size
)] in string str
);
149 void setAsWStringWithSize
(in uint32_t size
,
150 [size_is(size
)] in wstring str
);
154 void setAsEmptyArray
();
156 void setFromVariant
(in nsIVariant aValue
);
160 // The contractID for the generic implementation built in to xpcom.
161 #define NS_VARIANT_CONTRACTID
"@mozilla.org/variant;1"