C'est dû à la façon dont le REPL évalue l'entrée, qui est finalement comme :
(hi)()
Les parenthèses supplémentaires sont ajoutées pour le forcer à être un Expression :
// First we attempt to eval as expression with parens.
// This catches '{a : 1}' properly.
self.eval('(' + evalCmd + ')',
// ...
L'objectif est de traiter {...}
como Object
littéraux/ initialisations plutôt que comme un bloc .
var stmt = '{ "foo": "bar" }';
var expr = '(' + stmt + ')';
console.log(eval(expr)); // Object {foo: "bar"}
console.log(eval(stmt)); // SyntaxError: Unexpected token :
Et, comme le mentionne leesei, cela a été modifié pour la 0.11.x, qui va juste envelopper { ... }
plutôt que toutes les entrées :
if (/^\s*\{/.test(evalCmd) && /\}\s*$/.test(evalCmd)) {
// It's confusing for `{ a : 1 }` to be interpreted as a block
// statement rather than an object literal. So, we first try
// to wrap it in parentheses, so that it will be interpreted as
// an expression.
evalCmd = '(' + evalCmd + ')\n';
} else {
// otherwise we just append a \n so that it will be either
// terminated, or continued onto the next expression if it's an
// unexpected end of input.
evalCmd = evalCmd + '\n';
}