mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 19:07:34 +00:00
LibJS: Use "," separator in Array.prototype.join() if first arg is undefined
This is how the spec describes it, not "if the first arg is missing". Also swap length & separator steps to match spec.
This commit is contained in:
parent
3e0e84dcd1
commit
e5845ba3a0
2 changed files with 5 additions and 4 deletions
|
@ -316,15 +316,15 @@ JS_DEFINE_NATIVE_FUNCTION(ArrayPrototype::join)
|
|||
auto* this_object = vm.this_value(global_object).to_object(global_object);
|
||||
if (!this_object)
|
||||
return {};
|
||||
auto length = get_length(vm, *this_object);
|
||||
if (vm.exception())
|
||||
return {};
|
||||
String separator = ",";
|
||||
if (vm.argument_count()) {
|
||||
if (!vm.argument(0).is_undefined()) {
|
||||
separator = vm.argument(0).to_string(global_object);
|
||||
if (vm.exception())
|
||||
return {};
|
||||
}
|
||||
auto length = get_length(vm, *this_object);
|
||||
if (vm.exception())
|
||||
return {};
|
||||
StringBuilder builder;
|
||||
for (size_t i = 0; i < length; ++i) {
|
||||
if (i > 0)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue