LibJS: Fix String.prototype.match() for non-string argument
This is supposed to pass the to_string()'d argument to @@match, not the this value.
This commit is contained in:
parent
32052b3198
commit
b68509569e
Notes:
sideshowbarker
2024-07-18 21:22:29 +09:00
Author: https://github.com/linusg Commit: https://github.com/SerenityOS/serenity/commit/b68509569ed Pull-request: https://github.com/SerenityOS/serenity/pull/5781
1 changed files with 3 additions and 9 deletions
|
@ -666,19 +666,13 @@ JS_DEFINE_NATIVE_FUNCTION(StringPrototype::match)
|
|||
if (auto* matcher = get_method(global_object, regexp, vm.well_known_symbol_match()))
|
||||
return vm.call(*matcher, regexp, this_object);
|
||||
}
|
||||
auto s = this_object.to_primitive_string(global_object);
|
||||
if (!s)
|
||||
return {};
|
||||
auto regexp_string = regexp.to_string(global_object);
|
||||
if (regexp_string.is_null())
|
||||
auto s = this_object.to_string(global_object);
|
||||
if (vm.exception())
|
||||
return {};
|
||||
auto rx = regexp_create(global_object, regexp, js_undefined());
|
||||
if (!rx)
|
||||
return {};
|
||||
auto* matcher = get_method(global_object, rx, vm.well_known_symbol_match());
|
||||
if (!matcher)
|
||||
return {};
|
||||
return vm.call(*matcher, rx, this_object);
|
||||
return rx->invoke(vm.well_known_symbol_match(), js_string(vm, s));
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue