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