From ca832c8f7ee2115551633a020c68cc28dce4fd49 Mon Sep 17 00:00:00 2001 From: Kagami Sascha Rosylight Date: Sun, 22 Nov 2020 14:53:26 +0100 Subject: [PATCH 1/2] Specify that dictionaries can't be the type of attr/constant --- index.bs | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/index.bs b/index.bs index c9e4f3c8..5b693864 100644 --- a/index.bs +++ b/index.bs @@ -6321,8 +6321,9 @@ implicitly understood from context that the map is being treated as an instance dictionary type. However, there is no way to represent a constant dictionary value inside IDL fragments. -The [=type name=] of a dictionary type -is the [=identifier=] of the dictionary. +Dictionaries must not be used as the type of an [=attribute=] or [=constant=]. + +The [=type name=] of a dictionary type is the [=identifier=] of the dictionary.

Enumeration types

@@ -6442,9 +6443,7 @@ The literal syntax for [=lists=] may also be used to represent sequences, when i understood from context that the list is being treated as a sequences. However, there is no way to represent a constant sequence value inside IDL fragments. -Sequences must not be used as the -type of an [=attribute=] or -[=constant=]. +Sequences must not be used as the type of an [=attribute=] or [=constant=]. Note: This restriction exists so that it is clear to specification writers and API users that [=sequence types|sequences=] @@ -6478,8 +6477,7 @@ being kept by that object. Similarly, any record returned from a platform object will be a copy and modifications made to it will not be visible to the platform object. -Records must not be used as the type of an [=attribute=] or -[=constant=]. +Records must not be used as the type of an [=attribute=] or [=constant=]. The [=type name=] of a record type is the concatenation of the type name for |K|, the type name for |V| and the string "Record". From 61b650d7580033d081f6c399994883bdd10f4d46 Mon Sep 17 00:00:00 2001 From: Kagami Sascha Rosylight Date: Fri, 6 Aug 2021 21:33:34 +0200 Subject: [PATCH 2/2] cover callback functions --- index.bs | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/index.bs b/index.bs index 5b693864..653b5e3c 100644 --- a/index.bs +++ b/index.bs @@ -5595,8 +5595,7 @@ and the return type and argument list (matching Typ and ArgumentList) on the right side of the equals sign gives the signature of the callback function type. -[=Callback functions=] must not -be used as the type of a [=constant=]. +[=Callback functions=] must not be used as the type of a [=constant=]. The following extended attribute is applicable to callback functions: [{{LegacyTreatNonObjectAsNull}}]. @@ -6365,6 +6364,8 @@ callback function type value. See [[#es-callback-function]]. There is no way to represent a constant [=callback function=] value in IDL. +Callback functions must not be used as the type of a [=constant=]. + The [=type name=] of a callback function type is the [=identifier=] of the callback function.