fix: Reflec.defineProperty no longer returns Result

This commit is contained in:
Jannik Keye
2018-07-05 08:33:22 +02:00
parent 7790b34c07
commit 8dd8475000
2 changed files with 4 additions and 10 deletions

View File

@ -1003,8 +1003,8 @@ extern "C" {
/// but returns a Boolean. /// but returns a Boolean.
/// ///
/// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Reflect/defineProperty /// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Reflect/defineProperty
#[wasm_bindgen(static_method_of = Reflect, js_name = defineProperty, catch)] #[wasm_bindgen(static_method_of = Reflect, js_name = defineProperty)]
pub fn define_property(target: &Object, property_key: &JsValue, attributes: &Object) -> Result<JsValue, JsValue>; pub fn define_property(target: &Object, property_key: &JsValue, attributes: &Object) -> bool;
/// The static Reflect.deleteProperty() method allows to delete properties. /// The static Reflect.deleteProperty() method allows to delete properties.
/// It is like the delete operator as a function. /// It is like the delete operator as a function.

View File

@ -160,13 +160,8 @@ fn define_property() {
use wasm_bindgen::js; use wasm_bindgen::js;
#[wasm_bindgen] #[wasm_bindgen]
pub fn define_property(target: &js::Object, property_key: &JsValue, attributes: &js::Object) -> JsValue { pub fn define_property(target: &js::Object, property_key: &JsValue, attributes: &js::Object) -> bool {
let result = js::Reflect::define_property(target, property_key, attributes); js::Reflect::define_property(target, property_key, attributes)
match result {
Ok(val) => val,
Err(_err) => _err
}
} }
"#, "#,
) )
@ -180,7 +175,6 @@ fn define_property() {
const object = {}; const object = {};
assert.equal(wasm.define_property(object, "key", { value: 42}), true) assert.equal(wasm.define_property(object, "key", { value: 42}), true)
assert.equal(wasm.define_property("", "key", { value: 42 }), "TypeError: Reflect.defineProperty called on non-object");
} }
"#, "#,
) )