From 9492715a28f736ed335f1a6b9181c232d1d5a220 Mon Sep 17 00:00:00 2001 From: Domenic Denicola Date: Wed, 26 Jun 2024 11:21:22 +0900 Subject: [PATCH] Disallow non-attribute frozen arrays Also an an example of how to specify frozen array attributes. Closes #1399. --- index.bs | 52 +++++++++++++++++++++++++++++++++++++++++++--------- 1 file changed, 43 insertions(+), 9 deletions(-) diff --git a/index.bs b/index.bs index 91559925..92ccbe7c 100644 --- a/index.bs +++ b/index.bs @@ -6539,6 +6539,44 @@ A frozen array type is a parameteri type whose values are references to objects that hold a fixed length array of unmodifiable values. The values in the array are of type |T|. +Frozen array types must only be used as the type of [=regular attributes=] or [=static attributes=] +defined on an [=interface=]. + +
+ The following [=IDL fragment=] defines an [=interface=] with two frozen array attributes, one + [=read only=] and one not. + +
+        [Exposed=Window]
+        interface PersonalPreferences {
+            readonly attribute FrozenArray<DOMString> favoriteColors;
+            attribute FrozenArray<DOMString> favoriteFoods;
+
+            undefined randomizeFavoriteColors();
+        };
+    
+ + The behavior of these attributes could be defined like so: + +
+ Each PersonalPreferences has associated favorite colors, a {{FrozenArray}}<{{DOMString}}>, initially equal to the result of [=creating a frozen array=] from « "purple", "aquamarine" ». + + Each PersonalPreferences has an associated favorite foods, a {{FrozenArray}}<{{DOMString}}>, initially equal to the result of [=creating a frozen array=] from the empty list. + + The favoriteColors [=getter steps=] are to return [=this=]'s favorite colors. + + The favoriteFoods [=getter steps=] are to return [=this=]'s favorite foods. + + The favoriteFoods [=setter steps=] are to set [=this=]'s favorite foods to [=the given value=]. + + The randomizeFavoriteColors() [=method steps=] are: + + 1. Let |newFavoriteColors| be a list of two strings representing colors, chosen randomly. + + 1. Set [=this=]'s favorite colors to the result of [=creating a frozen array=] from |newFavoriteColors|. +
+
+ Since FrozenArray<|T|> values are references, they are unlike [=sequence types=], which are lists of values that are passed by value. @@ -11189,11 +11227,10 @@ Note: The HTML Standard defines how a security check is performed. [[!HTML]] there is an entry in |S| that has one of the following types at position |i| of its type list, * a [=sequence type=] - * a [=frozen array type=] - * a [=nullable type|nullable=] version of any of the above types - * an [=annotated type=] whose [=annotated types/inner type=] is one of the above types + * a [=nullable type|nullable=] [=sequence type=] + * an [=annotated type=] whose [=annotated types/inner type=] is a [=sequence type=] * a [=union type=], [=nullable type|nullable=] union type, or [=annotated type|annotated=] union type - that has one of the above types in its [=flattened member types=] + that has a [=sequence type=] in its [=flattened member types=] and after performing the following steps, @@ -11290,13 +11327,10 @@ Note: The HTML Standard defines how a security check is performed. [[!HTML]] 1. Let |V| be |args|[|i|]. 1. Let |T| be the type at index |i| in the type list of the remaining entry in |S|. - 1. If |T| is a [=sequence type=], then - append to |values| the result of + 1. Assert: |T| is a [=sequence type=]. + 1. Append to |values| the result of [=creating a sequence from an iterable|creating a sequence=] of type |T| from |V| and |method|. - 1. Otherwise, |T| is a [=frozen array type=]. - Append to |values| the result of - [=Creating a frozen array from an iterable|creating a frozen array of type T from V and method=]. 1. Set |i| to |i| + 1. 1. While |i| < |argcount|: 1. Let |V| be |args|[|i|].