mirror of
https://github.com/LadybirdBrowser/ladybird
synced 2026-05-05 06:32:30 +02:00
LibJS: Correcly handle surrogates in escape()
Fixes test/annexB/built-ins/escape/escape-above{,-astral}.js in
test262. All tests in test/annexB/built-ins/escape pass now.
This commit is contained in:
Notes:
sideshowbarker
2024-07-17 20:55:16 +09:00
Author: https://github.com/nico Commit: https://github.com/SerenityOS/serenity/commit/23cde7685cf Pull-request: https://github.com/SerenityOS/serenity/pull/11883 Reviewed-by: https://github.com/davidot ✅
@@ -9,6 +9,7 @@
|
||||
#include <AK/CharacterTypes.h>
|
||||
#include <AK/Hex.h>
|
||||
#include <AK/Platform.h>
|
||||
#include <AK/Utf16View.h>
|
||||
#include <AK/Utf8View.h>
|
||||
#include <LibJS/Console.h>
|
||||
#include <LibJS/Heap/DeferGC.h>
|
||||
@@ -548,7 +549,7 @@ JS_DEFINE_NATIVE_FUNCTION(GlobalObject::escape)
|
||||
{
|
||||
auto string = TRY(vm.argument(0).to_string(global_object));
|
||||
StringBuilder escaped;
|
||||
for (auto code_point : Utf8View(string)) {
|
||||
for (auto code_point : utf8_to_utf16(string)) {
|
||||
if (code_point < 256) {
|
||||
if ("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789@*_+-./"sv.contains(code_point))
|
||||
escaped.append(code_point);
|
||||
@@ -556,7 +557,7 @@ JS_DEFINE_NATIVE_FUNCTION(GlobalObject::escape)
|
||||
escaped.appendff("%{:02X}", code_point);
|
||||
continue;
|
||||
}
|
||||
escaped.appendff("%u{:04X}", code_point); // FIXME: Handle utf-16 surrogate pairs
|
||||
escaped.appendff("%u{:04X}", code_point);
|
||||
}
|
||||
return js_string(vm, escaped.build());
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user