Skip to content

Commit

Permalink
fix: Array.prototype.toString should be called by ES value (#227)
Browse files Browse the repository at this point in the history
* feat: Implement Array.prototype.toString

* fix: fix the missing arguments for Array.prototype.toString's inner join

* refactor: use fmt to beautify the code

* refactor: Array.prototype.toString——smplify error formating

* fix: Array.prototype.toString should be called by ES value

* fix: fix the error message

* refactor: Array.prototype.toString remove the duplicated logic
  • Loading branch information
cisen authored Jan 31, 2020
1 parent fe4a889 commit d8f33ab
Showing 1 changed file with 19 additions and 1 deletion.
20 changes: 19 additions & 1 deletion src/lib/builtins/array.rs
Original file line number Diff line number Diff line change
Expand Up @@ -205,7 +205,25 @@ pub fn join(this: &Value, args: &[Value], _: &mut Interpreter) -> ResultValue {
/// other kinds of objects for use as a method.
/// <https://tc39.es/ecma262/#sec-array.prototype.tostring>
pub fn to_string(this: &Value, _args: &[Value], _ctx: &mut Interpreter) -> ResultValue {
let join_result = join(this, &[to_value(",")], _ctx);
let method_name = "join";
let mut arguments = vec![to_value(",")];
// 2.
let mut method: Value =
from_value(this.get_field_slice(method_name)).expect("failed to get Array.prototype.join");
// 3.
if !method.is_function() {
method = _ctx
.realm
.global_obj
.get_field_slice("Object")
.get_field_slice(PROTOTYPE)
.get_field_slice("toString");

method = from_value(method).expect("failed to get Object.prototype.toString");
arguments = vec![];
}
// 4.
let join_result = _ctx.call(&method, this, arguments);
let match_string = match join_result {
Ok(v) => match *v {
ValueData::String(ref s) => (*s).clone(),
Expand Down

0 comments on commit d8f33ab

Please sign in to comment.