mirror of
https://github.com/servo/servo.git
synced 2025-08-07 06:25:32 +01:00
Impl Setlike and Maplike (#30237)
* MallocSizeOf for Index{Set, Map} * like as iterable in WebIDL * Codegen magic for like interfaces * TestBinding for like * Test for Setlike and Maplike test bindings * Some fixes * Switch to any.js * nit * Keep order
This commit is contained in:
parent
3df284cf54
commit
e0a6281e73
19 changed files with 1088 additions and 4 deletions
72
third_party/WebIDL/like-as-iterable.patch
vendored
Normal file
72
third_party/WebIDL/like-as-iterable.patch
vendored
Normal file
|
@ -0,0 +1,72 @@
|
|||
diff --git a/third_party/WebIDL/WebIDL.py b/third_party/WebIDL/WebIDL.py
|
||||
index 2366e3f702..e1d973f5fe 100644
|
||||
--- a/third_party/WebIDL/WebIDL.py
|
||||
+++ b/third_party/WebIDL/WebIDL.py
|
||||
@@ -9022,6 +9022,67 @@ class Parser(Tokenizer):
|
||||
itr_iface.asyncIterableInterface = iface
|
||||
self._productions.append(itr_iface)
|
||||
iterable.iteratorType = IDLWrapperType(iface.location, itr_iface)
|
||||
+ if not iterable:
|
||||
+ # We haven't run finish() on the interface yet, so we don't know
|
||||
+ # whether our interface is maplike/setlike/iterable or not. This
|
||||
+ # means we have to loop through the members to see if we have an
|
||||
+ # iterable member.
|
||||
+ for m in iface.members:
|
||||
+ if isinstance(m, IDLMaplikeOrSetlike):
|
||||
+ iterable = m
|
||||
+ break
|
||||
+ if iterable and (iterable.isSetlike() or iterable.isMaplike()):
|
||||
+
|
||||
+ def simpleExtendedAttr(str):
|
||||
+ return IDLExtendedAttribute(iface.location, (str,))
|
||||
+
|
||||
+ if isinstance(iterable, IDLAsyncIterable):
|
||||
+ nextReturnType = IDLPromiseType(
|
||||
+ iterable.location, BuiltinTypes[IDLBuiltinType.Types.any]
|
||||
+ )
|
||||
+ else:
|
||||
+ nextReturnType = BuiltinTypes[IDLBuiltinType.Types.object]
|
||||
+ nextMethod = IDLMethod(
|
||||
+ iterable.location,
|
||||
+ IDLUnresolvedIdentifier(iterable.location, "next"),
|
||||
+ nextReturnType,
|
||||
+ [],
|
||||
+ )
|
||||
+ nextMethod.addExtendedAttributes([simpleExtendedAttr("Throws")])
|
||||
+
|
||||
+ methods = [nextMethod]
|
||||
+
|
||||
+ if iterable.isSetlike():
|
||||
+ itr_suffix = "Setlike"
|
||||
+ else:
|
||||
+ itr_suffix = "Maplike"
|
||||
+ itr_ident = IDLUnresolvedIdentifier(
|
||||
+ iface.location, iface.identifier.name + itr_suffix
|
||||
+ )
|
||||
+ classNameOverride = iface.identifier.name + " " + itr_suffix
|
||||
+ itr_iface = IDLInterface(
|
||||
+ iface.location,
|
||||
+ self.globalScope(),
|
||||
+ itr_ident,
|
||||
+ None,
|
||||
+ methods,
|
||||
+ isKnownNonPartial=True,
|
||||
+ classNameOverride=classNameOverride,
|
||||
+ )
|
||||
+ itr_iface.addExtendedAttributes(
|
||||
+ [simpleExtendedAttr("LegacyNoInterfaceObject")]
|
||||
+ )
|
||||
+ # Make sure the exposure set for the iterator interface is the
|
||||
+ # same as the exposure set for the iterable interface, because
|
||||
+ # we're going to generate methods on the iterable that return
|
||||
+ # instances of the iterator.
|
||||
+ itr_iface._exposureGlobalNames = set(iface._exposureGlobalNames)
|
||||
+ # Always append generated iterable interfaces after the
|
||||
+ # interface they're a member of, otherwise nativeType generation
|
||||
+ # won't work correctly.
|
||||
+ itr_iface.iterableInterface = iface
|
||||
+ self._productions.append(itr_iface)
|
||||
+ iterable.iteratorType = IDLWrapperType(iface.location, itr_iface)
|
||||
|
||||
# Make sure we finish IDLIncludesStatements before we finish the
|
||||
# IDLInterfaces.
|
Loading…
Add table
Add a link
Reference in a new issue