Bug 1685680 [wpt PR 27099] - Update wpt metadata, a=testonly
[gecko.git] / xpcom / ds / nsIVariant.idl
blob0d7f7e70c3a269c667e899b907602991750f49bd
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"
11 %{C++
12 #include "xptinfo.h"
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.
17 struct nsIDataType
19 enum {
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 ,
50 VTYPE_EMPTY = 255
56 /**
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
61 * JS type anyway.
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
110 * may not succeed.
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);
152 void setAsVoid();
153 void setAsEmpty();
154 void setAsEmptyArray();
156 void setFromVariant(in nsIVariant aValue);
159 %{C++
160 // The contractID for the generic implementation built in to xpcom.
161 #define NS_VARIANT_CONTRACTID "@mozilla.org/variant;1"