js/src/jit-test/tests/parser/bug-888002-3.js

Wed, 31 Dec 2014 07:53:36 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Wed, 31 Dec 2014 07:53:36 +0100
branch
TOR_BUG_3246
changeset 5
4ab42b5ab56c
permissions
-rw-r--r--

Correct small whitespace inconsistency, lost while renaming variables.

     1 // Constant folding doesn't affect strict delete either.
     2 // In particular, it doesn't affect whether |delete x| is a strict error.
     4 load(libdir + "asserts.js");
     6 (function (x) {
     7     "use strict";
     9     // These senseless delete-expressions are legal even in strict mode.
    10     // Per ES5.1 11.4.1 step 2, each one does nothing and returns true.
    11     assertEq(delete (1 ? x : x), true);
    12     assertEq(delete (0 || x), true);
    13     assertEq(delete (1 && x), true);
    15     // Plain `delete x` is a SyntaxError though.
    16     assertThrowsInstanceOf(() => eval('delete x'), SyntaxError);
    17     assertThrowsInstanceOf(() => Function('"use strict"; delete x'), SyntaxError);
    18 }());

mercurial