From ab63e396272d80a813aecc1de7c175f09a7d9d92 Mon Sep 17 00:00:00 2001 From: Arpit Saxena Date: Wed, 23 Sep 2020 15:15:55 +0530 Subject: [PATCH 1/2] Add support for unsigned right shift assignment --- boa/src/exec/operator/mod.rs | 1 + boa/src/syntax/ast/op.rs | 14 +++++++++++++- boa/src/syntax/ast/punctuator.rs | 1 + 3 files changed, 15 insertions(+), 1 deletion(-) diff --git a/boa/src/exec/operator/mod.rs b/boa/src/exec/operator/mod.rs index b3b1d8f296e..abb07ae9d27 100644 --- a/boa/src/exec/operator/mod.rs +++ b/boa/src/exec/operator/mod.rs @@ -173,6 +173,7 @@ impl BinOp { AssignOp::Xor => x.bitxor(&y, interpreter), AssignOp::Shl => x.shl(&y, interpreter), AssignOp::Shr => x.shr(&y, interpreter), + AssignOp::Ushr => x.ushr(&y, interpreter), } } } diff --git a/boa/src/syntax/ast/op.rs b/boa/src/syntax/ast/op.rs index 98d436ec313..0d3c816dcde 100644 --- a/boa/src/syntax/ast/op.rs +++ b/boa/src/syntax/ast/op.rs @@ -938,7 +938,18 @@ pub enum AssignOp { /// [spec]: https://tc39.es/ecma262/#prod-AssignmentOperator /// [mdn]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Assignment_Operators#Right_shift_assignment Shr, - // TODO: Add UShl (unsigned shift left). + + /// The unsigned right shift assignment operator moves the specified amount of bits to the right and assigns the result to the variable. + /// + /// Syntax: `x >>>= y` + /// + /// More information: + /// - [ECMAScript reference][spec] + /// - [MDN documentation][mdn] + /// + /// [spec]: https://tc39.es/ecma262/#prod-AssignmentOperator + /// [mdn]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Unsigned_right_shift_assignment + Ushr, } unsafe impl Trace for AssignOp { @@ -962,6 +973,7 @@ impl Display for AssignOp { Self::Xor => "^=", Self::Shl => "<<=", Self::Shr => ">>=", + Self::Ushr => ">>>=", } ) } diff --git a/boa/src/syntax/ast/punctuator.rs b/boa/src/syntax/ast/punctuator.rs index 8201268a5b7..c056bbe4234 100644 --- a/boa/src/syntax/ast/punctuator.rs +++ b/boa/src/syntax/ast/punctuator.rs @@ -145,6 +145,7 @@ impl Punctuator { Self::AssignPow => Some(BinOp::Assign(AssignOp::Exp)), Self::AssignRightSh => Some(BinOp::Assign(AssignOp::Shr)), Self::AssignSub => Some(BinOp::Assign(AssignOp::Sub)), + Self::AssignURightSh => Some(BinOp::Assign(AssignOp::Ushr)), Self::AssignXor => Some(BinOp::Assign(AssignOp::Xor)), Self::Add => Some(BinOp::Num(NumOp::Add)), Self::Sub => Some(BinOp::Num(NumOp::Sub)), From 3d023350b0fed9906a54985f01e770346ad01218 Mon Sep 17 00:00:00 2001 From: Arpit Saxena Date: Wed, 23 Sep 2020 15:25:37 +0530 Subject: [PATCH 2/2] Add test for unsigned right shift assignment --- boa/src/syntax/parser/expression/tests.rs | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/boa/src/syntax/parser/expression/tests.rs b/boa/src/syntax/parser/expression/tests.rs index 69816e4dff3..93642d43ba7 100644 --- a/boa/src/syntax/parser/expression/tests.rs +++ b/boa/src/syntax/parser/expression/tests.rs @@ -178,6 +178,10 @@ fn check_assign_operations() { "a >>= b", vec![BinOp::new(AssignOp::Shr, Identifier::from("a"), Identifier::from("b")).into()], ); + check_parser( + "a >>>= b", + vec![BinOp::new(AssignOp::Ushr, Identifier::from("a"), Identifier::from("b")).into()], + ); check_parser( "a %= 10 / 2", vec![BinOp::new(