Branch: refs/heads/main
  Home:   https://github.com/WebKit/WebKit
  Commit: 5209f3cb6908f44c6035c69004bd7c8dc1044f7f
      
https://github.com/WebKit/WebKit/commit/5209f3cb6908f44c6035c69004bd7c8dc1044f7f
  Author: Sosuke Suzuki <sosuke.suz...@dr-ubie.com>
  Date:   2024-03-27 (Wed, 27 Mar 2024)

  Changed paths:
    M JSTests/stress/map-groupBy.js
    M JSTests/stress/object-groupBy.js
    M Source/JavaScriptCore/builtins/MapConstructor.js
    M Source/JavaScriptCore/builtins/ObjectConstructor.js

  Log Message:
  -----------
  [JSC] `Object.groupBy` and `Map.groupBy` should allow iterable `items` that 
are not objects
https://bugs.webkit.org/show_bug.cgi?id=271524

Reviewed by Keith Miller.

Before this change, Object.groupBy and Map.groupBy would throw a TypeError if 
items were not objects.
Therefore, they would throw a TypeError even when passed primitive values with 
@@iterator, such as strings. This is incorrect behavior.
In this patch, following the specification[1], Object.groupBy and Map.groupBy 
are changed to throw a TypeError only when the first argument, items, is null 
or undefined.
Even after this change, according to the specification[2], they will throw a 
TypeError for primitives like Number or Symbol that do not have @@iterator.

[1]: https://tc39.es/ecma262/#sec-groupby
[2]: https://tc39.es/ecma262/#sec-getiterator

* JSTests/stress/map-groupBy.js:
(catch):
* JSTests/stress/object-groupBy.js:
(catch):
* Source/JavaScriptCore/builtins/MapConstructor.js:
(wrapper.iterator):
(groupBy):
* Source/JavaScriptCore/builtins/ObjectConstructor.js:
(wrapper.iterator):
(groupBy):

Canonical link: https://commits.webkit.org/276736@main



To unsubscribe from these emails, change your notification settings at 
https://github.com/WebKit/WebKit/settings/notifications
_______________________________________________
webkit-changes mailing list
webkit-changes@lists.webkit.org
https://lists.webkit.org/mailman/listinfo/webkit-changes

Reply via email to