sergeyz
sergeyz

Reputation: 1328

Javascript and automatic semicolon insertion

test262 test suite has test containing source:

var x=0, y=0;
var z=
x
++
++
y

The annotation says:

Since LineTerminator(LT) between Postfix Increment/Decrement Operator(I/DO) and operand is not allowed, two IO(just as two DO and their combination) between two references separated by [LT] after automatic semicolon insertion lead to syntax error

Why does this code lead to syntax error? I think it's a valid code snippet. The code above equals to var z=x; ++ ++ y;. Expression ++ ++ y is allowed by javascript grammar. So what's the problem?

Upvotes: 0

Views: 459

Answers (3)

marcus erronius
marcus erronius

Reputation: 3703

This code will become:

var z = x;
++ ++ y;

The ++ ++ y is the root of the problem. Let’s look at why...

++ ++ y gets evaluated as ++(++y). The first step is to evaluate (++y). The ++ operator increments the value referenced by the variable it is next to, and returns the incremented value. The important part here is that it does not return a reference, just a value. So the second step would be ++(1), (or whatever ++y yielded), which is an error, since only references can be incremented.

Upvotes: 4

rici
rici

Reputation: 241931

The grammar does not allow a new-line to precede a ++ or -- operator; such a new-line must be converted to a ;. Consequently, the expression must be parsed as though it had been:

var x = 0 , y = 0 ;
var z = x ;
++ ;
++ y ;

The third line is illegal.

References:

Section 7.9.1, "Rules of Automatic Semicolon Insertion", rule 3

Section 11.3, "11.3 Postfix Expressions".

Upvotes: -1

Naftali
Naftali

Reputation: 146350

That evaluates to:

var x = 0, y = 0;
var z = x ++ ++ y; //MAKES NO SENSE!

Upvotes: -1

Related Questions