%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /home/riacommer/public_html/admin/vendor/messenger/docs/welcome/lib/executr/lib/
Upload File :
Create Path :
Current File : /home/riacommer/public_html/admin/vendor/messenger/docs/welcome/lib/executr/lib/js2coffee.min.js

if (typeof module == 'undefined') {
this.Narcissus = new Object;
}
(function() {
var narcissus = {
options: {
version: 185,
},
hostGlobal: this
};
Narcissus = narcissus;
})();
Narcissus.definitions = (function() {
var tokens = [
"END",
"\n", ";",
",",
"=",
"?", ":", "CONDITIONAL",
"||",
"&&",
"|",
"^",
"&",
"==", "!=", "===", "!==",
"<", "<=", ">=", ">",
"<<", ">>", ">>>",
"+", "-",
"*", "/", "%",
"!", "~", "UNARY_PLUS", "UNARY_MINUS",
"++", "--",
".",
"[", "]",
"{", "}",
"(", ")",
"SCRIPT", "BLOCK", "LABEL", "FOR_IN", "CALL", "NEW_WITH_ARGS", "INDEX",
"ARRAY_INIT", "OBJECT_INIT", "PROPERTY_INIT", "GETTER", "SETTER",
"GROUP", "LIST", "LET_BLOCK", "ARRAY_COMP", "GENERATOR", "COMP_TAIL",
"IDENTIFIER", "NUMBER", "STRING", "REGEXP",
"break",
"case", "catch", "const", "continue",
"debugger", "default", "delete", "do",
"else",
"false", "finally", "for", "function",
"if", "in", "instanceof",
"let",
"new", "null",
"return",
"switch",
"this", "throw", "true", "try", "typeof",
"var", "void",
"yield",
"while", "with",
];
var statementStartTokens = [
"break",
"const", "continue",
"debugger", "do",
"for",
"if",
"return",
"switch",
"throw", "try",
"var",
"yield",
"while", "with",
];
var opTypeNames = {
'\n':   "NEWLINE",
';':    "SEMICOLON",
',':    "COMMA",
'?':    "HOOK",
':':    "COLON",
'||':   "OR",
'&&':   "AND",
'|':    "BITWISE_OR",
'^':    "BITWISE_XOR",
'&':    "BITWISE_AND",
'===':  "STRICT_EQ",
'==':   "EQ",
'=':    "ASSIGN",
'!==':  "STRICT_NE",
'!=':   "NE",
'<<':   "LSH",
'<=':   "LE",
'<':    "LT",
'>>>':  "URSH",
'>>':   "RSH",
'>=':   "GE",
'>':    "GT",
'++':   "INCREMENT",
'--':   "DECREMENT",
'+':    "PLUS",
'-':    "MINUS",
'*':    "MUL",
'/':    "DIV",
'%':    "MOD",
'!':    "NOT",
'~':    "BITWISE_NOT",
'.':    "DOT",
'[':    "LEFT_BRACKET",
']':    "RIGHT_BRACKET",
'{':    "LEFT_CURLY",
'}':    "RIGHT_CURLY",
'(':    "LEFT_PAREN",
')':    "RIGHT_PAREN"
};
var keywords = {__proto__: null};
var tokenIds = {};
var consts = "const ";
for (var i = 0, j = tokens.length; i < j; i++) {
if (i > 0)
consts += ", ";
var t = tokens[i];
var name;
if (/^[a-z]/.test(t)) {
name = t.toUpperCase();
keywords[t] = i;
} else {
name = (/^\W/.test(t) ? opTypeNames[t] : t);
}
consts += name + " = " + i;
tokenIds[name] = i;
tokens[t] = i;
}
consts += ";";
var isStatementStartCode = {__proto__: null};
for (i = 0, j = statementStartTokens.length; i < j; i++)
isStatementStartCode[keywords[statementStartTokens[i]]] = true;
var assignOps = ['|', '^', '&', '<<', '>>', '>>>', '+', '-', '*', '/', '%'];
for (i = 0, j = assignOps.length; i < j; i++) {
t = assignOps[i];
assignOps[t] = tokens[t];
}
function defineGetter(obj, prop, fn, dontDelete, dontEnum) {
Object.defineProperty(obj, prop,
{ get: fn, configurable: !dontDelete, enumerable: !dontEnum });
}
function defineProperty(obj, prop, val, dontDelete, readOnly, dontEnum) {
Object.defineProperty(obj, prop,
{ value: val, writable: !readOnly, configurable: !dontDelete,
enumerable: !dontEnum });
}
function isNativeCode(fn) {
return ((typeof fn) === "function") && fn.toString().match(/\[native code\]/);
}
function getPropertyDescriptor(obj, name) {
while (obj) {
if (({}).hasOwnProperty.call(obj, name))
return Object.getOwnPropertyDescriptor(obj, name);
obj = Object.getPrototypeOf(obj);
}
}
function getOwnProperties(obj) {
var map = {};
for (var name in Object.getOwnPropertyNames(obj))
map[name] = Object.getOwnPropertyDescriptor(obj, name);
return map;
}
function makePassthruHandler(obj) {
return {
getOwnPropertyDescriptor: function(name) {
var desc = Object.getOwnPropertyDescriptor(obj, name);
desc.configurable = true;
return desc;
},
getPropertyDescriptor: function(name) {
var desc = getPropertyDescriptor(obj, name);
desc.configurable = true;
return desc;
},
getOwnPropertyNames: function() {
return Object.getOwnPropertyNames(obj);
},
defineProperty: function(name, desc) {
Object.defineProperty(obj, name, desc);
},
"delete": function(name) { return delete obj[name]; },
fix: function() {
if (Object.isFrozen(obj)) {
return getOwnProperties(obj);
}
return undefined;
},
has: function(name) { return name in obj; },
hasOwn: function(name) { return ({}).hasOwnProperty.call(obj, name); },
get: function(receiver, name) { return obj[name]; },
set: function(receiver, name, val) { obj[name] = val; return true; },
enumerate: function() {
var result = [];
for (name in obj) { result.push(name); };
return result;
},
keys: function() { return Object.keys(obj); }
};
}
function noPropFound() { return undefined; }
var hasOwnProperty = ({}).hasOwnProperty;
function StringMap() {
this.table = Object.create(null, {});
this.size = 0;
}
StringMap.prototype = {
has: function(x) { return hasOwnProperty.call(this.table, x); },
set: function(x, v) {
if (!hasOwnProperty.call(this.table, x))
this.size++;
this.table[x] = v;
},
get: function(x) { return this.table[x]; },
getDef: function(x, thunk) {
if (!hasOwnProperty.call(this.table, x)) {
this.size++;
this.table[x] = thunk();
}
return this.table[x];
},
forEach: function(f) {
var table = this.table;
for (var key in table)
f.call(this, key, table[key]);
},
toString: function() { return "[object StringMap]" }
};
function Stack(elts) {
this.elts = elts || null;
}
Stack.prototype = {
push: function(x) {
return new Stack({ top: x, rest: this.elts });
},
top: function() {
if (!this.elts)
throw new Error("empty stack");
return this.elts.top;
},
isEmpty: function() {
return this.top === null;
},
find: function(test) {
for (var elts = this.elts; elts; elts = elts.rest) {
if (test(elts.top))
return elts.top;
}
return null;
},
has: function(x) {
return Boolean(this.find(function(elt) { return elt === x }));
},
forEach: function(f) {
for (var elts = this.elts; elts; elts = elts.rest) {
f(elts.top);
}
}
};
return {
tokens: tokens,
opTypeNames: opTypeNames,
keywords: keywords,
isStatementStartCode: isStatementStartCode,
tokenIds: tokenIds,
consts: consts,
assignOps: assignOps,
defineGetter: defineGetter,
defineProperty: defineProperty,
isNativeCode: isNativeCode,
makePassthruHandler: makePassthruHandler,
noPropFound: noPropFound,
StringMap: StringMap,
Stack: Stack
};
}());
Narcissus.lexer = (function() {
var definitions = Narcissus.definitions;
eval(definitions.consts);
var opTokens = {};
for (var op in definitions.opTypeNames) {
if (op === '\n' || op === '.')
continue;
var node = opTokens;
for (var i = 0; i < op.length; i++) {
var ch = op[i];
if (!(ch in node))
node[ch] = {};
node = node[ch];
node.op = op;
}
}
function Tokenizer(s, f, l) {
this.cursor = 0;
this.source = String(s);
this.tokens = [];
this.tokenIndex = 0;
this.lookahead = 0;
this.scanNewlines = false;
this.unexpectedEOF = false;
this.filename = f || "";
this.lineno = l || 1;
this.comments = [];
}
Tokenizer.prototype = {
get done() {
return this.peek(true) === END;
},
get token() {
return this.tokens[this.tokenIndex];
},
match: function (tt, scanOperand) {
return this.get(scanOperand) === tt || this.unget();
},
mustMatch: function (tt) {
if (!this.match(tt)) {
throw this.newSyntaxError("Missing " +
definitions.tokens[tt].toLowerCase());
}
return this.token;
},
peek: function (scanOperand) {
var tt, next;
if (this.lookahead) {
next = this.tokens[(this.tokenIndex + this.lookahead) & 3];
tt = (this.scanNewlines && next.lineno !== this.lineno)
? NEWLINE
: next.type;
} else {
tt = this.get(scanOperand);
this.unget();
}
return tt;
},
peekOnSameLine: function (scanOperand) {
this.scanNewlines = true;
var tt = this.peek(scanOperand);
this.scanNewlines = false;
return tt;
},
skip: function () {
var input = this.source;
var cstart;
var clineno;
var comments = [];
var comment;
var nlcount = 0;
for (;;) {
var ch = input[this.cursor++];
var next = input[this.cursor];
if (ch === '\n' && !this.scanNewlines) {
this.lineno++;
nlcount++;
} else if (ch === '/' && next === '*') {
cstart = this.cursor;
clineno = this.lineno;
this.cursor++;
for (;;) {
ch = input[this.cursor++];
if (ch === undefined)
throw this.newSyntaxError("Unterminated comment");
if (ch === '*') {
next = input[this.cursor];
if (next === '/') {
this.cursor++;
comment = {
type: "BLOCK_COMMENT",
nlcount: nlcount,
start:cstart-1, end:this.cursor, lineno:clineno, endlineno: this.lineno,
value: input.substring(cstart+1,this.cursor-2)
}
this.comments.push(comment);
nlcount = 0;
break;
}
} else if (ch === '\n') {
this.lineno++;
}
}
} else if (ch === '/' && next === '/') {
cstart = this.cursor;
this.cursor++;
for (;;) {
ch = input[this.cursor++];
if (ch === undefined) {
comment = {
type: "LINE_COMMENT",
start: cstart, end:this.cursor,
lineno: this.lineno, nlcount: nlcount,
value: input.substring(cstart+1,this.cursor-1)
};
this.comments.push(comment);
return;
}
if (ch === '\n') {
comment = {
type: "LINE_COMMENT",
start: cstart, end:this.cursor,
lineno: this.lineno, nlcount: nlcount,
value: input.substring(cstart+1,this.cursor-1)
};
this.comments.push(comment);
nlcount = 0;
this.lineno++;
break;
}
}
} else if (ch !== ' ' && ch !== '\t') {
this.cursor--;
return;
}
}
},
lexExponent: function() {
var input = this.source;
var next = input[this.cursor];
if (next === 'e' || next === 'E') {
this.cursor++;
ch = input[this.cursor++];
if (ch === '+' || ch === '-')
ch = input[this.cursor++];
if (ch < '0' || ch > '9')
throw this.newSyntaxError("Missing exponent");
do {
ch = input[this.cursor++];
} while (ch >= '0' && ch <= '9');
this.cursor--;
return true;
}
return false;
},
lexZeroNumber: function (ch) {
var token = this.token, input = this.source;
token.type = NUMBER;
ch = input[this.cursor++];
if (ch === '.') {
do {
ch = input[this.cursor++];
} while (ch >= '0' && ch <= '9');
this.cursor--;
this.lexExponent();
token.value = parseFloat(token.start, this.cursor);
} else if (ch === 'x' || ch === 'X') {
do {
ch = input[this.cursor++];
} while ((ch >= '0' && ch <= '9') || (ch >= 'a' && ch <= 'f') ||
(ch >= 'A' && ch <= 'F'));
this.cursor--;
token.value = parseInt(input.substring(token.start, this.cursor));
} else if (ch >= '0' && ch <= '7') {
do {
ch = input[this.cursor++];
} while (ch >= '0' && ch <= '7');
this.cursor--;
token.value = parseInt(input.substring(token.start, this.cursor));
} else {
this.cursor--;
this.lexExponent();
token.value = 0;
}
},
lexNumber: function (ch) {
var token = this.token, input = this.source;
token.type = NUMBER;
var floating = false;
do {
ch = input[this.cursor++];
if (ch === '.' && !floating) {
floating = true;
ch = input[this.cursor++];
}
} while (ch >= '0' && ch <= '9');
this.cursor--;
var exponent = this.lexExponent();
floating = floating || exponent;
var str = input.substring(token.start, this.cursor);
token.value = floating ? parseFloat(str) : parseInt(str);
},
lexDot: function (ch) {
var token = this.token, input = this.source;
var next = input[this.cursor];
if (next >= '0' && next <= '9') {
do {
ch = input[this.cursor++];
} while (ch >= '0' && ch <= '9');
this.cursor--;
this.lexExponent();
token.type = NUMBER;
token.value = parseFloat(token.start, this.cursor);
} else {
token.type = DOT;
token.assignOp = null;
token.value = '.';
}
},
lexString: function (ch) {
var token = this.token, input = this.source;
token.type = STRING;
var hasEscapes = false;
var delim = ch;
while ((ch = input[this.cursor++]) !== delim) {
if (this.cursor >= input.length)
throw this.newSyntaxError("Unterminated string literal");
if (ch === '\\') {
hasEscapes = true;
if (++this.cursor == input.length)
throw this.newSyntaxError("Unterminated string literal");
}
}
token.value = hasEscapes
? eval(input.substring(token.start, this.cursor))
: input.substring(token.start + 1, this.cursor - 1);
},
lexRegExp: function (ch) {
var token = this.token, input = this.source;
token.type = REGEXP;
do {
ch = input[this.cursor++];
if (ch === '\\') {
this.cursor++;
} else if (ch === '[') {
do {
if (ch === undefined)
throw this.newSyntaxError("Unterminated character class");
if (ch === '\\')
this.cursor++;
ch = input[this.cursor++];
} while (ch !== ']');
} else if (ch === undefined) {
throw this.newSyntaxError("Unterminated regex");
}
} while (ch !== '/');
do {
ch = input[this.cursor++];
} while (ch >= 'a' && ch <= 'z');
this.cursor--;
token.value = eval(input.substring(token.start, this.cursor));
},
lexOp: function (ch) {
var token = this.token, input = this.source;
var node = opTokens[ch];
var next = input[this.cursor];
if (next in node) {
node = node[next];
this.cursor++;
next = input[this.cursor];
if (next in node) {
node = node[next];
this.cursor++;
next = input[this.cursor];
}
}
var op = node.op;
if (definitions.assignOps[op] && input[this.cursor] === '=') {
this.cursor++;
token.type = ASSIGN;
token.assignOp = definitions.tokenIds[definitions.opTypeNames[op]];
op += '=';
} else {
token.type = definitions.tokenIds[definitions.opTypeNames[op]];
token.assignOp = null;
}
token.value = op;
},
lexIdent: function (ch) {
var token = this.token, input = this.source;
do {
ch = input[this.cursor++];
} while ((ch >= 'a' && ch <= 'z') || (ch >= 'A' && ch <= 'Z') ||
(ch >= '0' && ch <= '9') || ch === '$' || ch === '_');
this.cursor--;
var id = input.substring(token.start, this.cursor);
token.type = definitions.keywords[id] || IDENTIFIER;
token.value = id;
},
get: function (scanOperand) {
var token;
while (this.lookahead) {
--this.lookahead;
this.tokenIndex = (this.tokenIndex + 1) & 3;
token = this.tokens[this.tokenIndex];
if (token.type !== NEWLINE || this.scanNewlines)
return token.type;
}
this.skip();
this.tokenIndex = (this.tokenIndex + 1) & 3;
token = this.tokens[this.tokenIndex];
if (!token)
this.tokens[this.tokenIndex] = token = {};
var input = this.source;
if (this.cursor === input.length)
return token.type = END;
token.start = this.cursor;
token.lineno = this.lineno;
var ch = input[this.cursor++];
if ((ch >= 'a' && ch <= 'z') || (ch >= 'A' && ch <= 'Z') || ch === '$' || ch === '_') {
this.lexIdent(ch);
} else if (scanOperand && ch === '/') {
this.lexRegExp(ch);
} else if (ch in opTokens) {
this.lexOp(ch);
} else if (ch === '.') {
this.lexDot(ch);
} else if (ch >= '1' && ch <= '9') {
this.lexNumber(ch);
} else if (ch === '0') {
this.lexZeroNumber(ch);
} else if (ch === '"' || ch === "'") {
this.lexString(ch);
} else if (this.scanNewlines && ch === '\n') {
token.type = NEWLINE;
token.value = '\n';
this.lineno++;
} else {
throw this.newSyntaxError("Illegal token");
}
token.end = this.cursor;
return token.type;
},
unget: function () {
if (++this.lookahead === 4) throw "PANIC: too much lookahead!";
this.tokenIndex = (this.tokenIndex - 1) & 3;
},
newSyntaxError: function (m) {
var e = new SyntaxError(m, this.filename, this.lineno);
e.source = this.source;
e.cursor = this.lookahead
? this.tokens[(this.tokenIndex + this.lookahead) & 3].start
: this.cursor;
return e;
},
};
return { Tokenizer: Tokenizer };
}());
Narcissus.parser = (function() {
var lexer = Narcissus.lexer;
var definitions = Narcissus.definitions;
const StringMap = definitions.StringMap;
const Stack = definitions.Stack;
eval(definitions.consts);
function pushDestructuringVarDecls(n, s) {
for (var i in n) {
var sub = n[i];
if (sub.type === IDENTIFIER) {
s.varDecls.push(sub);
} else {
pushDestructuringVarDecls(sub, s);
}
}
}
const NESTING_TOP = 0, NESTING_SHALLOW = 1, NESTING_DEEP = 2;
function StaticContext(parentScript, parentBlock, inFunction, inForLoopInit, nesting) {
this.parentScript = parentScript;
this.parentBlock = parentBlock;
this.inFunction = inFunction;
this.inForLoopInit = inForLoopInit;
this.nesting = nesting;
this.allLabels = new Stack();
this.currentLabels = new Stack();
this.labeledTargets = new Stack();
this.defaultTarget = null;
Narcissus.options.ecma3OnlyMode && (this.ecma3OnlyMode = true);
Narcissus.options.parenFreeMode && (this.parenFreeMode = true);
}
StaticContext.prototype = {
ecma3OnlyMode: false,
parenFreeMode: false,
update: function(ext) {
var desc = {};
for (var key in ext) {
desc[key] = {
value: ext[key],
writable: true,
enumerable: true,
configurable: true
}
}
return Object.create(this, desc);
},
pushLabel: function(label) {
return this.update({ currentLabels: this.currentLabels.push(label),
allLabels: this.allLabels.push(label) });
},
pushTarget: function(target) {
var isDefaultTarget = target.isLoop || target.type === SWITCH;
if (this.currentLabels.isEmpty()) {
return isDefaultTarget
? this.update({ defaultTarget: target })
: this;
}
target.labels = new StringMap();
this.currentLabels.forEach(function(label) {
target.labels.set(label, true);
});
return this.update({ currentLabels: new Stack(),
labeledTargets: this.labeledTargets.push(target),
defaultTarget: isDefaultTarget
? target
: this.defaultTarget });
},
nest: function(atLeast) {
var nesting = Math.max(this.nesting, atLeast);
return (nesting !== this.nesting)
? this.update({ nesting: nesting })
: this;
}
};
function Script(t, inFunction) {
var n = new Node(t, scriptInit());
var x = new StaticContext(n, n, inFunction, false, NESTING_TOP);
Statements(t, x, n);
return n;
}
definitions.defineProperty(Array.prototype, "top",
function() {
return this.length && this[this.length-1];
}, false, false, true);
function Node(t, init) {
var token = t.token;
if (token) {
this.type = token.type;
this.value = token.value;
this.lineno = token.lineno;
this.start = token.start;
this.end = token.end;
} else {
this.lineno = t.lineno;
}
this.tokenizer = t;
this.children = [];
for (var prop in init)
this[prop] = init[prop];
}
var Np = Node.prototype = {};
Np.constructor = Node;
Np.toSource = Object.prototype.toSource;
Np.push = function (kid) {
if (kid !== null) {
if (kid.start < this.start)
this.start = kid.start;
if (this.end < kid.end)
this.end = kid.end;
}
return this.children.push(kid);
}
Node.indentLevel = 0;
function tokenString(tt) {
var t = definitions.tokens[tt];
return /^\W/.test(t) ? definitions.opTypeNames[t] : t.toUpperCase();
}
Np.toString = function () {
var a = [];
for (var i in this) {
if (this.hasOwnProperty(i) && i !== 'type' && i !== 'target')
a.push({id: i, value: this[i]});
}
a.sort(function (a,b) { return (a.id < b.id) ? -1 : 1; });
const INDENTATION = "    ";
var n = ++Node.indentLevel;
var s = "{\n" + INDENTATION.repeat(n) + "type: " + tokenString(this.type);
for (i = 0; i < a.length; i++)
s += ",\n" + INDENTATION.repeat(n) + a[i].id + ": " + a[i].value;
n = --Node.indentLevel;
s += "\n" + INDENTATION.repeat(n) + "}";
return s;
}
Np.getSource = function () {
return this.tokenizer.source.slice(this.start, this.end);
};
const LOOP_INIT = { isLoop: true };
function blockInit() {
return { type: BLOCK, varDecls: [] };
}
function scriptInit() {
return { type: SCRIPT,
funDecls: [],
varDecls: [],
modDecls: [],
impDecls: [],
expDecls: [],
loadDeps: [],
hasEmptyReturn: false,
hasReturnWithValue: false,
isGenerator: false };
}
definitions.defineGetter(Np, "filename",
function() {
return this.tokenizer.filename;
});
definitions.defineGetter(Np, "length",
function() {
throw new Error("Node.prototype.length is gone; " +
"use n.children.length instead");
});
definitions.defineProperty(String.prototype, "repeat",
function(n) {
var s = "", t = this + s;
while (--n >= 0)
s += t;
return s;
}, false, false, true);
function MaybeLeftParen(t, x) {
if (x.parenFreeMode)
return t.match(LEFT_PAREN) ? LEFT_PAREN : END;
return t.mustMatch(LEFT_PAREN).type;
}
function MaybeRightParen(t, p) {
if (p === LEFT_PAREN)
t.mustMatch(RIGHT_PAREN);
}
function Statements(t, x, n) {
try {
while (!t.done && t.peek(true) !== RIGHT_CURLY)
{ n.push(Statement(t, x)); }
} catch (e) {
if (t.done)
{ t.unexpectedEOF = true; }
throw(e);
}
}
function Block(t, x) {
t.mustMatch(LEFT_CURLY);
var n = new Node(t, blockInit());
Statements(t, x.update({ parentBlock: n }).pushTarget(n), n);
t.mustMatch(RIGHT_CURLY);
return n;
}
const DECLARED_FORM = 0, EXPRESSED_FORM = 1, STATEMENT_FORM = 2;
function Statement(t, x) {
var i, label, n, n2, p, c, ss, tt = t.get(true), tt2, x2, x3;
switch (tt) {
case FUNCTION:
return FunctionDefinition(t, x, true,
(x.nesting !== NESTING_TOP)
? STATEMENT_FORM
: DECLARED_FORM);
case LEFT_CURLY:
n = new Node(t, blockInit());
Statements(t, x.update({ parentBlock: n }).pushTarget(n).nest(NESTING_SHALLOW), n);
t.mustMatch(RIGHT_CURLY);
return n;
case IF:
n = new Node(t);
n.condition = HeadExpression(t, x);
x2 = x.pushTarget(n).nest(NESTING_DEEP);
n.thenPart = Statement(t, x2);
n.elsePart = t.match(ELSE) ? Statement(t, x2) : null;
return n;
case SWITCH:
n = new Node(t, { cases: [], defaultIndex: -1 });
n.discriminant = HeadExpression(t, x);
x2 = x.pushTarget(n).nest(NESTING_DEEP);
t.mustMatch(LEFT_CURLY);
while ((tt = t.get()) !== RIGHT_CURLY) {
switch (tt) {
case DEFAULT:
if (n.defaultIndex >= 0)
throw t.newSyntaxError("More than one switch default");
case CASE:
n2 = new Node(t);
if (tt === DEFAULT)
n.defaultIndex = n.cases.length;
else
n2.caseLabel = Expression(t, x2, COLON);
break;
default:
throw t.newSyntaxError("Invalid switch case");
}
t.mustMatch(COLON);
n2.statements = new Node(t, blockInit());
while ((tt=t.peek(true)) !== CASE && tt !== DEFAULT &&
tt !== RIGHT_CURLY)
n2.statements.push(Statement(t, x2));
n.cases.push(n2);
}
return n;
case FOR:
n = new Node(t, LOOP_INIT);
if (t.match(IDENTIFIER)) {
if (t.token.value === "each")
n.isEach = true;
else
t.unget();
}
if (!x.parenFreeMode)
t.mustMatch(LEFT_PAREN);
x2 = x.pushTarget(n).nest(NESTING_DEEP);
x3 = x.update({ inForLoopInit: true });
if ((tt = t.peek()) !== SEMICOLON) {
if (tt === VAR || tt === CONST) {
t.get();
n2 = Variables(t, x3);
} else if (tt === LET) {
t.get();
if (t.peek() === LEFT_PAREN) {
n2 = LetBlock(t, x3, false);
} else {
x3.parentBlock = n;
n.varDecls = [];
n2 = Variables(t, x3);
}
} else {
n2 = Expression(t, x3);
}
}
if (n2 && t.match(IN)) {
n.type = FOR_IN;
n.object = Expression(t, x3);
if (n2.type === VAR || n2.type === LET) {
c = n2.children;
if (c.length !== 1 && n2.destructurings.length !== 1) {
throw new SyntaxError("Invalid for..in left-hand side",
t.filename, n2.lineno);
}
if (n2.destructurings.length > 0) {
n.iterator = n2.destructurings[0];
} else {
n.iterator = c[0];
}
n.varDecl = n2;
} else {
if (n2.type === ARRAY_INIT || n2.type === OBJECT_INIT) {
n2.destructuredNames = checkDestructuring(t, x3, n2);
}
n.iterator = n2;
}
} else {
n.setup = n2;
t.mustMatch(SEMICOLON);
if (n.isEach)
throw t.newSyntaxError("Invalid for each..in loop");
n.condition = (t.peek() === SEMICOLON)
? null
: Expression(t, x3);
t.mustMatch(SEMICOLON);
tt2 = t.peek();
n.update = (x.parenFreeMode
? tt2 === LEFT_CURLY || definitions.isStatementStartCode[tt2]
: tt2 === RIGHT_PAREN)
? null
: Expression(t, x3);
}
if (!x.parenFreeMode)
t.mustMatch(RIGHT_PAREN);
n.body = Statement(t, x2);
return n;
case WHILE:
n = new Node(t, { isLoop: true });
n.condition = HeadExpression(t, x);
n.body = Statement(t, x.pushTarget(n).nest(NESTING_DEEP));
return n;
case DO:
n = new Node(t, { isLoop: true });
n.body = Statement(t, x.pushTarget(n).nest(NESTING_DEEP));
t.mustMatch(WHILE);
n.condition = HeadExpression(t, x);
if (!x.ecmaStrictMode) {
t.match(SEMICOLON);
return n;
}
break;
case BREAK:
case CONTINUE:
n = new Node(t);
x2 = x.pushTarget(n);
if (t.peekOnSameLine() === IDENTIFIER) {
t.get();
n.label = t.token.value;
}
n.target = n.label
? x2.labeledTargets.find(function(target) { return target.labels.has(n.label) })
: x2.defaultTarget;
if (!n.target)
throw t.newSyntaxError("Invalid " + ((tt === BREAK) ? "break" : "continue"));
if (!n.target.isLoop && tt === CONTINUE)
throw t.newSyntaxError("Invalid continue");
break;
case TRY:
n = new Node(t, { catchClauses: [] });
n.tryBlock = Block(t, x);
while (t.match(CATCH)) {
n2 = new Node(t);
p = MaybeLeftParen(t, x);
switch (t.get()) {
case LEFT_BRACKET:
case LEFT_CURLY:
t.unget();
n2.varName = DestructuringExpression(t, x, true);
break;
case IDENTIFIER:
n2.varName = t.token.value;
break;
default:
throw t.newSyntaxError("missing identifier in catch");
break;
}
if (t.match(IF)) {
if (x.ecma3OnlyMode)
throw t.newSyntaxError("Illegal catch guard");
if (n.catchClauses.length && !n.catchClauses.top().guard)
throw t.newSyntaxError("Guarded catch after unguarded");
n2.guard = Expression(t, x);
}
MaybeRightParen(t, p);
n2.block = Block(t, x);
n.catchClauses.push(n2);
}
if (t.match(FINALLY))
n.finallyBlock = Block(t, x);
if (!n.catchClauses.length && !n.finallyBlock)
throw t.newSyntaxError("Invalid try statement");
return n;
case CATCH:
case FINALLY:
throw t.newSyntaxError(definitions.tokens[tt] + " without preceding try");
case THROW:
n = new Node(t);
n.exception = Expression(t, x);
break;
case RETURN:
n = ReturnOrYield(t, x);
break;
case WITH:
n = new Node(t);
n.object = HeadExpression(t, x);
n.body = Statement(t, x.pushTarget(n).nest(NESTING_DEEP));
return n;
case VAR:
case CONST:
n = Variables(t, x);
break;
case LET:
if (t.peek() === LEFT_PAREN)
n = LetBlock(t, x, true);
else
n = Variables(t, x);
break;
case DEBUGGER:
n = new Node(t);
break;
case NEWLINE:
case SEMICOLON:
n = new Node(t, { type: SEMICOLON });
n.expression = null;
return n;
default:
if (tt === IDENTIFIER) {
tt = t.peek();
if (tt === COLON) {
label = t.token.value;
if (x.allLabels.has(label))
throw t.newSyntaxError("Duplicate label");
t.get();
n = new Node(t, { type: LABEL, label: label });
n.statement = Statement(t, x.pushLabel(label).nest(NESTING_SHALLOW));
n.target = (n.statement.type === LABEL) ? n.statement.target : n.statement;
return n;
}
}
n = new Node(t, { type: SEMICOLON });
t.unget();
n.expression = Expression(t, x);
n.end = n.expression.end;
break;
}
MagicalSemicolon(t);
return n;
}
function MagicalSemicolon(t) {
var tt;
if (t.lineno === t.token.lineno) {
tt = t.peekOnSameLine();
if (tt !== END && tt !== NEWLINE && tt !== SEMICOLON && tt !== RIGHT_CURLY)
throw t.newSyntaxError("missing ; before statement");
}
t.match(SEMICOLON);
}
function ReturnOrYield(t, x) {
var n, b, tt = t.token.type, tt2;
var parentScript = x.parentScript;
if (tt === RETURN) {
if (!x.inFunction)
throw t.newSyntaxError("Return not in function");
} else   {
if (!x.inFunction)
throw t.newSyntaxError("Yield not in function");
parentScript.isGenerator = true;
}
n = new Node(t, { value: undefined });
tt2 = t.peek(true);
if (tt2 !== END && tt2 !== NEWLINE &&
tt2 !== SEMICOLON && tt2 !== RIGHT_CURLY
&& (tt !== YIELD ||
(tt2 !== tt && tt2 !== RIGHT_BRACKET && tt2 !== RIGHT_PAREN &&
tt2 !== COLON && tt2 !== COMMA))) {
if (tt === RETURN) {
n.value = Expression(t, x);
parentScript.hasReturnWithValue = true;
} else {
n.value = AssignExpression(t, x);
}
} else if (tt === RETURN) {
parentScript.hasEmptyReturn = true;
}
if (parentScript.hasReturnWithValue && parentScript.isGenerator)
throw t.newSyntaxError("Generator returns a value");
return n;
}
function FunctionDefinition(t, x, requireName, functionForm) {
var tt;
var f = new Node(t, { params: [] });
if (f.type !== FUNCTION)
f.type = (f.value === "get") ? GETTER : SETTER;
if (t.match(IDENTIFIER))
f.name = t.token.value;
else if (requireName)
throw t.newSyntaxError("missing function identifier");
var x2 = new StaticContext(null, null, true, false, NESTING_TOP);
t.mustMatch(LEFT_PAREN);
if (!t.match(RIGHT_PAREN)) {
do {
switch (t.get()) {
case LEFT_BRACKET:
case LEFT_CURLY:
t.unget();
f.params.push(DestructuringExpression(t, x2));
break;
case IDENTIFIER:
f.params.push(t.token.value);
break;
default:
throw t.newSyntaxError("missing formal parameter");
break;
}
} while (t.match(COMMA));
t.mustMatch(RIGHT_PAREN);
}
tt = t.get();
if (tt !== LEFT_CURLY)
t.unget();
if (tt !== LEFT_CURLY) {
f.body = AssignExpression(t, x2);
if (f.body.isGenerator)
throw t.newSyntaxError("Generator returns a value");
} else {
f.body = Script(t, true);
}
if (tt === LEFT_CURLY)
t.mustMatch(RIGHT_CURLY);
f.end = t.token.end;
f.functionForm = functionForm;
if (functionForm === DECLARED_FORM)
x.parentScript.funDecls.push(f);
return f;
}
function Variables(t, x, letBlock) {
var n, n2, ss, i, s, tt;
tt = t.token.type;
switch (tt) {
case VAR:
case CONST:
s = x.parentScript;
break;
case LET:
s = x.parentBlock;
break;
case LEFT_PAREN:
tt = LET;
s = letBlock;
break;
}
n = new Node(t, { type: tt, destructurings: [] });
do {
tt = t.get();
if (tt === LEFT_BRACKET || tt === LEFT_CURLY) {
t.unget();
var dexp = DestructuringExpression(t, x, true);
n2 = new Node(t, { type: IDENTIFIER,
name: dexp,
readOnly: n.type === CONST });
n.push(n2);
pushDestructuringVarDecls(n2.name.destructuredNames, s);
n.destructurings.push({ exp: dexp, decl: n2 });
if (x.inForLoopInit && t.peek() === IN) {
continue;
}
t.mustMatch(ASSIGN);
if (t.token.assignOp)
throw t.newSyntaxError("Invalid variable initialization");
n2.initializer = AssignExpression(t, x);
continue;
}
if (tt !== IDENTIFIER)
throw t.newSyntaxError("missing variable name");
n2 = new Node(t, { type: IDENTIFIER,
name: t.token.value,
readOnly: n.type === CONST });
n.push(n2);
s.varDecls.push(n2);
if (t.match(ASSIGN)) {
if (t.token.assignOp)
throw t.newSyntaxError("Invalid variable initialization");
n2.initializer = AssignExpression(t, x);
}
} while (t.match(COMMA));
return n;
}
function LetBlock(t, x, isStatement) {
var n, n2;
n = new Node(t, { type: LET_BLOCK, varDecls: [] });
t.mustMatch(LEFT_PAREN);
n.variables = Variables(t, x, n);
t.mustMatch(RIGHT_PAREN);
if (isStatement && t.peek() !== LEFT_CURLY) {
n2 = new Node(t, { type: SEMICOLON,
expression: n });
isStatement = false;
}
if (isStatement)
n.block = Block(t, x);
else
n.expression = AssignExpression(t, x);
return n;
}
function checkDestructuring(t, x, n, simpleNamesOnly) {
if (n.type === ARRAY_COMP)
throw t.newSyntaxError("Invalid array comprehension left-hand side");
if (n.type !== ARRAY_INIT && n.type !== OBJECT_INIT)
return;
var lhss = {};
var nn, n2, idx, sub, cc, c = n.children;
for (var i = 0, j = c.length; i < j; i++) {
if (!(nn = c[i]))
continue;
if (nn.type === PROPERTY_INIT) {
cc = nn.children;
sub = cc[1];
idx = cc[0].value;
} else if (n.type === OBJECT_INIT) {
sub = nn;
idx = nn.value;
} else {
sub = nn;
idx = i;
}
if (sub.type === ARRAY_INIT || sub.type === OBJECT_INIT) {
lhss[idx] = checkDestructuring(t, x, sub, simpleNamesOnly);
} else {
if (simpleNamesOnly && sub.type !== IDENTIFIER) {
throw t.newSyntaxError("missing name in pattern");
}
lhss[idx] = sub;
}
}
return lhss;
}
function DestructuringExpression(t, x, simpleNamesOnly) {
var n = PrimaryExpression(t, x);
n.destructuredNames = checkDestructuring(t, x, n, simpleNamesOnly);
return n;
}
function GeneratorExpression(t, x, e) {
return new Node(t, { type: GENERATOR,
expression: e,
tail: ComprehensionTail(t, x) });
}
function ComprehensionTail(t, x) {
var body, n, n2, n3, p;
body = new Node(t, { type: COMP_TAIL });
do {
n = new Node(t, { type: FOR_IN, isLoop: true });
if (t.match(IDENTIFIER)) {
if (t.token.value === "each")
n.isEach = true;
else
t.unget();
}
p = MaybeLeftParen(t, x);
switch(t.get()) {
case LEFT_BRACKET:
case LEFT_CURLY:
t.unget();
n.iterator = DestructuringExpression(t, x);
break;
case IDENTIFIER:
n.iterator = n3 = new Node(t, { type: IDENTIFIER });
n3.name = n3.value;
n.varDecl = n2 = new Node(t, { type: VAR });
n2.push(n3);
x.parentScript.varDecls.push(n3);
break;
default:
throw t.newSyntaxError("missing identifier");
}
t.mustMatch(IN);
n.object = Expression(t, x);
MaybeRightParen(t, p);
body.push(n);
} while (t.match(FOR));
if (t.match(IF))
body.guard = HeadExpression(t, x);
return body;
}
function HeadExpression(t, x) {
var p = MaybeLeftParen(t, x);
var n = ParenExpression(t, x);
MaybeRightParen(t, p);
if (p === END && !n.parenthesized) {
var tt = t.peek();
if (tt !== LEFT_CURLY && !definitions.isStatementStartCode[tt])
throw t.newSyntaxError("Unparenthesized head followed by unbraced body");
}
return n;
}
function ParenExpression(t, x) {
var n = Expression(t, x.update({ inForLoopInit: x.inForLoopInit &&
(t.token.type === LEFT_PAREN) }));
if (t.match(FOR)) {
if (n.type === YIELD && !n.parenthesized)
throw t.newSyntaxError("Yield expression must be parenthesized");
if (n.type === COMMA && !n.parenthesized)
throw t.newSyntaxError("Generator expression must be parenthesized");
n = GeneratorExpression(t, x, n);
}
return n;
}
function Expression(t, x) {
var n, n2;
n = AssignExpression(t, x);
if (t.match(COMMA)) {
n2 = new Node(t, { type: COMMA });
n2.push(n);
n = n2;
do {
n2 = n.children[n.children.length-1];
if (n2.type === YIELD && !n2.parenthesized)
throw t.newSyntaxError("Yield expression must be parenthesized");
n.push(AssignExpression(t, x));
} while (t.match(COMMA));
}
return n;
}
function AssignExpression(t, x) {
var n, lhs;
if (t.match(YIELD, true))
return ReturnOrYield(t, x);
n = new Node(t, { type: ASSIGN });
lhs = ConditionalExpression(t, x);
if (!t.match(ASSIGN)) {
return lhs;
}
switch (lhs.type) {
case OBJECT_INIT:
case ARRAY_INIT:
lhs.destructuredNames = checkDestructuring(t, x, lhs);
case IDENTIFIER: case DOT: case INDEX: case CALL:
break;
default:
throw t.newSyntaxError("Bad left-hand side of assignment");
break;
}
n.assignOp = t.token.assignOp;
n.push(lhs);
n.push(AssignExpression(t, x));
return n;
}
function ConditionalExpression(t, x) {
var n, n2;
n = OrExpression(t, x);
if (t.match(HOOK)) {
n2 = n;
n = new Node(t, { type: HOOK });
n.push(n2);
n.push(AssignExpression(t, x.update({ inForLoopInit: false })));
if (!t.match(COLON))
throw t.newSyntaxError("missing : after ?");
n.push(AssignExpression(t, x));
}
return n;
}
function OrExpression(t, x) {
var n, n2;
n = AndExpression(t, x);
while (t.match(OR)) {
n2 = new Node(t);
n2.push(n);
n2.push(AndExpression(t, x));
n = n2;
}
return n;
}
function AndExpression(t, x) {
var n, n2;
n = BitwiseOrExpression(t, x);
while (t.match(AND)) {
n2 = new Node(t);
n2.push(n);
n2.push(BitwiseOrExpression(t, x));
n = n2;
}
return n;
}
function BitwiseOrExpression(t, x) {
var n, n2;
n = BitwiseXorExpression(t, x);
while (t.match(BITWISE_OR)) {
n2 = new Node(t);
n2.push(n);
n2.push(BitwiseXorExpression(t, x));
n = n2;
}
return n;
}
function BitwiseXorExpression(t, x) {
var n, n2;
n = BitwiseAndExpression(t, x);
while (t.match(BITWISE_XOR)) {
n2 = new Node(t);
n2.push(n);
n2.push(BitwiseAndExpression(t, x));
n = n2;
}
return n;
}
function BitwiseAndExpression(t, x) {
var n, n2;
n = EqualityExpression(t, x);
while (t.match(BITWISE_AND)) {
n2 = new Node(t);
n2.push(n);
n2.push(EqualityExpression(t, x));
n = n2;
}
return n;
}
function EqualityExpression(t, x) {
var n, n2;
n = RelationalExpression(t, x);
while (t.match(EQ) || t.match(NE) ||
t.match(STRICT_EQ) || t.match(STRICT_NE)) {
n2 = new Node(t);
n2.push(n);
n2.push(RelationalExpression(t, x));
n = n2;
}
return n;
}
function RelationalExpression(t, x) {
var n, n2;
var x2 = x.update({ inForLoopInit: false });
n = ShiftExpression(t, x2);
while ((t.match(LT) || t.match(LE) || t.match(GE) || t.match(GT) ||
(!x.inForLoopInit && t.match(IN)) ||
t.match(INSTANCEOF))) {
n2 = new Node(t);
n2.push(n);
n2.push(ShiftExpression(t, x2));
n = n2;
}
return n;
}
function ShiftExpression(t, x) {
var n, n2;
n = AddExpression(t, x);
while (t.match(LSH) || t.match(RSH) || t.match(URSH)) {
n2 = new Node(t);
n2.push(n);
n2.push(AddExpression(t, x));
n = n2;
}
return n;
}
function AddExpression(t, x) {
var n, n2;
n = MultiplyExpression(t, x);
while (t.match(PLUS) || t.match(MINUS)) {
n2 = new Node(t);
n2.push(n);
n2.push(MultiplyExpression(t, x));
n = n2;
}
return n;
}
function MultiplyExpression(t, x) {
var n, n2;
n = UnaryExpression(t, x);
while (t.match(MUL) || t.match(DIV) || t.match(MOD)) {
n2 = new Node(t);
n2.push(n);
n2.push(UnaryExpression(t, x));
n = n2;
}
return n;
}
function UnaryExpression(t, x) {
var n, n2, tt;
switch (tt = t.get(true)) {
case DELETE: case VOID: case TYPEOF:
case NOT: case BITWISE_NOT: case PLUS: case MINUS:
if (tt === PLUS)
n = new Node(t, { type: UNARY_PLUS });
else if (tt === MINUS)
n = new Node(t, { type: UNARY_MINUS });
else
n = new Node(t);
n.push(UnaryExpression(t, x));
break;
case INCREMENT:
case DECREMENT:
n = new Node(t);
n.push(MemberExpression(t, x, true));
break;
default:
t.unget();
n = MemberExpression(t, x, true);
if (t.tokens[(t.tokenIndex + t.lookahead - 1) & 3].lineno ===
t.lineno) {
if (t.match(INCREMENT) || t.match(DECREMENT)) {
n2 = new Node(t, { postfix: true });
n2.push(n);
n = n2;
}
}
break;
}
return n;
}
function MemberExpression(t, x, allowCallSyntax) {
var n, n2, name, tt;
if (t.match(NEW)) {
n = new Node(t);
n.push(MemberExpression(t, x, false));
if (t.match(LEFT_PAREN)) {
n.type = NEW_WITH_ARGS;
n.push(ArgumentList(t, x));
}
} else {
n = PrimaryExpression(t, x);
}
while ((tt = t.get()) !== END) {
switch (tt) {
case DOT:
n2 = new Node(t);
n2.push(n);
t.mustMatch(IDENTIFIER);
n2.push(new Node(t));
break;
case LEFT_BRACKET:
n2 = new Node(t, { type: INDEX });
n2.push(n);
n2.push(Expression(t, x));
t.mustMatch(RIGHT_BRACKET);
break;
case LEFT_PAREN:
if (allowCallSyntax) {
n2 = new Node(t, { type: CALL });
n2.push(n);
n2.push(ArgumentList(t, x));
break;
}
default:
t.unget();
return n;
}
n = n2;
}
return n;
}
function ArgumentList(t, x) {
var n, n2;
n = new Node(t, { type: LIST });
if (t.match(RIGHT_PAREN, true))
return n;
do {
n2 = AssignExpression(t, x);
if (n2.type === YIELD && !n2.parenthesized && t.peek() === COMMA)
throw t.newSyntaxError("Yield expression must be parenthesized");
if (t.match(FOR)) {
n2 = GeneratorExpression(t, x, n2);
if (n.children.length > 1 || t.peek(true) === COMMA)
throw t.newSyntaxError("Generator expression must be parenthesized");
}
n.push(n2);
} while (t.match(COMMA));
t.mustMatch(RIGHT_PAREN);
return n;
}
function PrimaryExpression(t, x) {
var n, n2, tt = t.get(true);
switch (tt) {
case FUNCTION:
n = FunctionDefinition(t, x, false, EXPRESSED_FORM);
break;
case LEFT_BRACKET:
n = new Node(t, { type: ARRAY_INIT });
while ((tt = t.peek(true)) !== RIGHT_BRACKET) {
if (tt === COMMA) {
t.get();
n.push(null);
continue;
}
n.push(AssignExpression(t, x));
if (tt !== COMMA && !t.match(COMMA))
break;
}
if (n.children.length === 1 && t.match(FOR)) {
n2 = new Node(t, { type: ARRAY_COMP,
expression: n.children[0],
tail: ComprehensionTail(t, x) });
n = n2;
}
t.mustMatch(RIGHT_BRACKET);
break;
case LEFT_CURLY:
var id, fd;
n = new Node(t, { type: OBJECT_INIT });
object_init:
if (!t.match(RIGHT_CURLY)) {
do {
tt = t.get();
if ((t.token.value === "get" || t.token.value === "set") &&
t.peek() === IDENTIFIER) {
if (x.ecma3OnlyMode)
throw t.newSyntaxError("Illegal property accessor");
n.push(FunctionDefinition(t, x, true, EXPRESSED_FORM));
} else {
switch (tt) {
case IDENTIFIER: case NUMBER: case STRING:
id = new Node(t, { type: IDENTIFIER });
break;
case RIGHT_CURLY:
if (x.ecma3OnlyMode)
throw t.newSyntaxError("Illegal trailing ,");
break object_init;
default:
if (t.token.value in definitions.keywords) {
id = new Node(t, { type: IDENTIFIER });
break;
}
throw t.newSyntaxError("Invalid property name");
}
if (t.match(COLON)) {
n2 = new Node(t, { type: PROPERTY_INIT });
n2.push(id);
n2.push(AssignExpression(t, x));
n.push(n2);
} else {
if (t.peek() !== COMMA && t.peek() !== RIGHT_CURLY)
throw t.newSyntaxError("missing : after property");
n.push(id);
}
}
} while (t.match(COMMA));
t.mustMatch(RIGHT_CURLY);
}
break;
case LEFT_PAREN:
n = ParenExpression(t, x);
t.mustMatch(RIGHT_PAREN);
n.parenthesized = true;
break;
case LET:
n = LetBlock(t, x, false);
break;
case NULL: case THIS: case TRUE: case FALSE:
case IDENTIFIER: case NUMBER: case STRING: case REGEXP:
n = new Node(t);
break;
default:
throw t.newSyntaxError("missing operand");
break;
}
return n;
}
function parse(s, f, l) {
var t = new lexer.Tokenizer(s, f, l);
var n = Script(t, false);
if (!t.done)
throw t.newSyntaxError("Syntax error");
return n;
}
function parseStdin(s, ln) {
for (;;) {
try {
var t = new lexer.Tokenizer(s, "stdin", ln.value);
var n = Script(t, false);
ln.value = t.lineno;
return n;
} catch (e) {
if (!t.unexpectedEOF)
throw e;
var more = readline();
if (!more)
throw e;
s += "\n" + more;
}
}
}
return {
parse: parse,
parseStdin: parseStdin,
Node: Node,
DECLARED_FORM: DECLARED_FORM,
EXPRESSED_FORM: EXPRESSED_FORM,
STATEMENT_FORM: STATEMENT_FORM,
Tokenizer: lexer.Tokenizer,
FunctionDefinition: FunctionDefinition
};
}());
var exports = {
definitions: Narcissus.definitions,
lexer: Narcissus.lexer,
parser: Narcissus.parser
};
if (typeof module != 'undefined') {
module.exports = exports;
};
(function() {
var Node, Typenames, Types, exports, narcissus, parser, tokens, _,
__indexOf = Array.prototype.indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; },
__slice = Array.prototype.slice;
narcissus = this.Narcissus || require('./narcissus_packed');
_ = this._ || require('underscore');
tokens = narcissus.definitions.tokens;
parser = narcissus.parser;
Node = parser.Node;
Node.prototype.left = function() {
return this.children[0];
};
Node.prototype.right = function() {
return this.children[1];
};
Node.prototype.last = function() {
return this.children[this.children.length - 1];
};
Node.prototype.walk = function(options, fn, parent, list) {
if (parent == null) parent = null;
if (list == null) list = null;
if (parent) fn(parent, this, list);
if (options.last) if (this.last() != null) this.last().walk(options, fn, this);
if (this.thenPart != null) this.thenPart.walk(options, fn, this, 'thenPart');
if (this.elsePart != null) this.elsePart.walk(options, fn, this, 'elsePart');
if (this.cases) {
return _.each(this.cases, function(item) {
return item.statements.walk(options, fn, item, 'cases');
});
}
};
Node.prototype.clone = function(hash) {
var i;
for (i in this) {
if (i === 'tokenizer' || i === 'length' || i === 'filename') continue;
if (hash[i] == null) hash[i] = this[i];
}
return new Node(this.tokenizer, hash);
};
Node.prototype.toHash = function(done) {
var hash, i, toHash;
if (done == null) done = [];
hash = {};
toHash = function(what) {
if (!what) return null;
if (what.toHash) {
if (__indexOf.call(done, what) >= 0) {
return "--recursive " + what.id + "--";
}
what.id = done.push(what);
return what.toHash(done);
} else {
return what;
}
};
hash.type = this.typeName();
hash.src = this.src();
for (i in this) {
if (i === 'filename' || i === 'length' || i === 'type' || i === 'start' || i === 'end' || i === 'tokenizer') {
continue;
}
if (typeof this[i] === 'function') continue;
if (!this[i]) continue;
if (this[i].constructor === Array) {
hash[i] = _.map(this[i], function(item) {
return toHash(item);
});
} else {
hash[i] = toHash(this[i]);
}
}
return hash;
};
Node.prototype.inspect = function() {
return JSON.stringify(this.toHash(), null, '  ');
};
Node.prototype.src = function() {
return this.tokenizer.source.substr(this.start, this.end - this.start);
};
Node.prototype.typeName = function() {
return Types[this.type];
};
Node.prototype.isA = function() {
var what, _ref;
what = 1 <= arguments.length ? __slice.call(arguments, 0) : [];
return _ref = Types[this.type], __indexOf.call(what, _ref) >= 0;
};
Types = (function() {
var dict, i, last;
dict = {};
last = 0;
for (i in tokens) {
if (typeof tokens[i] === 'number') {
dict[tokens[i]] = i.toLowerCase();
last = tokens[i];
}
}
dict[++last] = 'call_statement';
dict[++last] = 'existence_check';
return dict;
})();
Typenames = (function() {
var dict, i;
dict = {};
for (i in Types) {
dict[Types[i]] = i;
}
return dict;
})();
this.NodeExt = exports = {
Types: Types,
Typenames: Typenames,
Node: Node
};
if (typeof module !== "undefined" && module !== null) module.exports = exports;
}).call(this);
(function() {
var Code, CoffeeScript, blockTrim, coffeescript_reserved, exports, indentLines, isSingleLine, ltrim, p, paren, rtrim, strEscape, strRepeat, trim, truthy, unreserve, unshift, word,
__indexOf = Array.prototype.indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; };
CoffeeScript = this.CoffeeScript || require('coffee-script');
Code = (function() {
function Code() {
this.code = '';
}
Code.prototype.add = function(str) {
this.code += str.toString();
return this;
};
Code.prototype.scope = function(str, level) {
var indent;
if (level == null) level = 1;
indent = strRepeat("  ", level);
this.code = rtrim(this.code) + "\n";
this.code += indent + rtrim(str).replace(/\n/g, "\n" + indent) + "\n";
return this;
};
Code.prototype.toString = function() {
return this.code;
};
return Code;
})();
paren = function(string) {
var str;
str = string.toString();
if (str.substr(0, 1) === '(' && str.substr(-1, 1) === ')') {
return str;
} else {
return "(" + str + ")";
}
};
strRepeat = function(str, times) {
var i;
return ((function() {
var _results;
_results = [];
for (i = 0; 0 <= times ? i < times : i > times; 0 <= times ? i++ : i--) {
_results.push(str);
}
return _results;
})()).join('');
};
ltrim = function(str) {
return ("" + str).replace(/^\s*/g, '');
};
rtrim = function(str) {
return ("" + str).replace(/\s*$/g, '');
};
blockTrim = function(str) {
return ("" + str).replace(/^\s*\n|\s*$/g, '');
};
trim = function(str) {
return ("" + str).replace(/^\s*|\s*$/g, '');
};
isSingleLine = function(str) {
return trim(str).indexOf("\n") === -1;
};
unshift = function(str) {
var m1, m2;
str = "" + str;
while (true) {
m1 = str.match(/^/gm);
m2 = str.match(/^ /gm);
if (!m1 || !m2 || m1.length !== m2.length) return str;
str = str.replace(/^ /gm, '');
}
};
truthy = function(n) {
return n.isA('true') || (n.isA('number') && parseFloat(n.src()) !== 0.0);
};
strEscape = function(str) {
return JSON.stringify("" + str);
};
p = function(str) {
if (str.constructor === String) {
console.log(JSON.stringify(str));
} else {
console.log(str);
}
return '';
};
coffeescript_reserved = (function() {
var _i, _len, _ref, _results;
_ref = CoffeeScript.RESERVED;
_results = [];
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
word = _ref[_i];
if (word !== 'undefined') _results.push(word);
}
return _results;
})();
unreserve = function(str) {
var _ref;
if (_ref = "" + str, __indexOf.call(coffeescript_reserved, _ref) >= 0) {
return "" + str + "_";
} else {
return "" + str;
}
};
indentLines = function(indent, lines) {
return indent + lines.replace(/\n/g, "\n" + indent);
};
this.Js2coffeeHelpers = exports = {
Code: Code,
p: p,
strEscape: strEscape,
unreserve: unreserve,
unshift: unshift,
isSingleLine: isSingleLine,
trim: trim,
blockTrim: blockTrim,
ltrim: ltrim,
rtrim: rtrim,
strRepeat: strRepeat,
paren: paren,
truthy: truthy,
indentLines: indentLines
};
if (typeof module !== "undefined" && module !== null) module.exports = exports;
}).call(this);
(function() {
var Builder, Code, Node, Transformer, Typenames, Types, UnsupportedError, blockTrim, buildCoffee, exports, indentLines, isSingleLine, ltrim, p, paren, parser, rtrim, strEscape, strRepeat, trim, truthy, unreserve, unshift, _, _ref, _ref2,
__indexOf = Array.prototype.indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; },
__slice = Array.prototype.slice,
__hasProp = Object.prototype.hasOwnProperty;
parser = (this.Narcissus || require('./narcissus_packed')).parser;
_ = this._ || require('underscore');
_ref = this.NodeExt || require('./node_ext'), Types = _ref.Types, Typenames = _ref.Typenames, Node = _ref.Node;
_ref2 = this.Js2coffeeHelpers || require('./helpers'), Code = _ref2.Code, p = _ref2.p, strEscape = _ref2.strEscape, unreserve = _ref2.unreserve, unshift = _ref2.unshift, isSingleLine = _ref2.isSingleLine, trim = _ref2.trim, blockTrim = _ref2.blockTrim, ltrim = _ref2.ltrim, rtrim = _ref2.rtrim, strRepeat = _ref2.strRepeat, paren = _ref2.paren, truthy = _ref2.truthy, indentLines = _ref2.indentLines;
buildCoffee = function(str, opts) {
var builder, comments, indent, keepLineNumbers, l, line, minline, output, precomments, res, scriptNode, srclines, text, _i, _len, _ref3;
if (opts == null) opts = {};
str = str.replace(/\r/g, '');
str += "\n";
builder = new Builder(opts);
scriptNode = parser.parse(str);
output = trim(builder.build(scriptNode));
if (opts.no_comments) {
return ((function() {
var _i, _len, _ref3, _results;
_ref3 = output.split('\n');
_results = [];
for (_i = 0, _len = _ref3.length; _i < _len; _i++) {
line = _ref3[_i];
_results.push(rtrim(line));
}
return _results;
})()).join('\n');
} else {
keepLineNumbers = opts.show_src_lineno;
res = [];
_ref3 = output.split("\n");
for (_i = 0, _len = _ref3.length; _i < _len; _i++) {
l = _ref3[_i];
srclines = [];
text = l.replace(/\uFEFE([0-9]+).*?\uFEFE/g, function(m, g) {
srclines.push(parseInt(g));
return "";
});
srclines = _.sortBy(_.uniq(srclines), function(i) {
return i;
});
text = rtrim(text);
indent = text.match(/^\s*/);
if (srclines.length > 0) {
minline = _.last(srclines);
precomments = builder.commentsNotDoneTo(minline);
if (precomments) res.push(indentLines(indent, precomments));
}
if (text) {
if (keepLineNumbers) text = text + "#" + srclines.join(",") + "#  ";
res.push(rtrim(text + " " + ltrim(builder.lineComments(srclines))));
} else {
res.push("");
}
}
comments = builder.commentsNotDoneTo(1e10);
if (comments) res.push(comments);
return res.join("\n");
}
};
Builder = (function() {
function Builder(options) {
this.options = options != null ? options : {};
this.transformer = new Transformer;
}
Builder.prototype.l = function(n) {
if (this.options.no_comments) return '';
if (n && n.lineno) {
return "\uFEFE" + n.lineno + "\uFEFE";
} else {
return "";
}
};
Builder.prototype.makeComment = function(comment) {
var c, line;
if (comment.type === "BLOCK_COMMENT") {
c = comment.value.split("\n");
if (c.length > 0 && c[0].length > 0 && c[0][0] === "*") {
c = (function() {
var _i, _len, _results;
_results = [];
for (_i = 0, _len = c.length; _i < _len; _i++) {
line = c[_i];
_results.push(line.replace(/^[\s\*]*/, ''));
}
return _results;
})();
c = (function() {
var _i, _len, _results;
_results = [];
for (_i = 0, _len = c.length; _i < _len; _i++) {
line = c[_i];
_results.push(line.replace(/[\s]*$/, ''));
}
return _results;
})();
while (c.length > 0 && c[0].length === 0) {
c.shift();
}
while (c.length > 0 && c[c.length - 1].length === 0) {
c.pop();
}
c.unshift('###');
c.push('###');
} else {
c = (function() {
var _i, _len, _results;
_results = [];
for (_i = 0, _len = c.length; _i < _len; _i++) {
line = c[_i];
_results.push("#" + line);
}
return _results;
})();
}
} else {
c = ['#' + comment.value];
}
if (comment.nlcount > 0) c.unshift('');
return c.join('\n');
};
Builder.prototype.commentsNotDoneTo = function(lineno) {
var c, res;
res = [];
while (true) {
if (this.comments.length === 0) break;
c = this.comments[0];
if (c.lineno < lineno) {
res.push(this.makeComment(c));
this.comments.shift();
continue;
}
break;
}
return res.join("\n");
};
Builder.prototype.lineComments = function(linenos) {
var c, selection;
selection = (function() {
var _i, _len, _ref3, _ref4, _results;
_ref3 = this.comments;
_results = [];
for (_i = 0, _len = _ref3.length; _i < _len; _i++) {
c = _ref3[_i];
if (_ref4 = c.lineno, __indexOf.call(linenos, _ref4) >= 0) {
_results.push(c);
}
}
return _results;
}).call(this);
this.comments = _.difference(this.comments, selection);
return ((function() {
var _i, _len, _results;
_results = [];
for (_i = 0, _len = selection.length; _i < _len; _i++) {
c = selection[_i];
_results.push(this.makeComment(c));
}
return _results;
}).call(this)).join("\n");
};
Builder.prototype.build = function() {
var args, fn, name, node, out;
args = 1 <= arguments.length ? __slice.call(arguments, 0) : [];
node = args[0];
if (!(this.comments != null)) {
this.comments = _.sortBy(node.tokenizer.comments, function(n) {
return n.start;
});
}
this.transform(node);
name = 'other';
if (node !== void 0 && node.typeName) name = node.typeName();
fn = this[name] || this.other;
out = fn.apply(this, args);
if (node.parenthesized) {
return paren(out);
} else {
return out;
}
};
Builder.prototype.transform = function() {
var args;
args = 1 <= arguments.length ? __slice.call(arguments, 0) : [];
return this.transformer.transform.apply(this.transformer, args);
};
Builder.prototype.body = function(node, opts) {
var str;
if (opts == null) opts = {};
str = this.build(node, opts);
str = blockTrim(str);
str = unshift(str);
if (str.length > 0) {
return str;
} else {
return "";
}
};
Builder.prototype['script'] = function(n, opts) {
var c,
_this = this;
if (opts == null) opts = {};
c = new Code;
_.each(n.functions, function(item) {
return c.add(_this.build(item));
});
_.each(n.nonfunctions, function(item) {
return c.add(_this.build(item));
});
return c.toString();
};
Builder.prototype['property_identifier'] = function(n) {
var str;
str = n.value.toString();
if (str.match(/^([_\$a-z][_\$a-z0-9]*)$/i) || str.match(/^[0-9]+$/i)) {
return this.l(n) + str;
} else {
return this.l(n) + strEscape(str);
}
};
Builder.prototype['identifier'] = function(n) {
if (n.value === 'undefined') {
return this.l(n) + '`undefined`';
} else if (n.property_accessor) {
return this.l(n) + n.value.toString();
} else {
return this.l(n) + unreserve(n.value.toString());
}
};
Builder.prototype['number'] = function(n) {
return this.l(n) + ("" + (n.src()));
};
Builder.prototype['id'] = function(n) {
if (n.property_accessor) {
return this.l(n) + n;
} else {
return this.l(n) + unreserve(n);
}
};
Builder.prototype['id_param'] = function(n) {
var _ref3;
if ((_ref3 = n.toString()) === 'undefined') {
return this.l(n) + ("" + n + "_");
} else {
return this.l(n) + this.id(n);
}
};
Builder.prototype['return'] = function(n) {
if (!(n.value != null)) {
return this.l(n) + "return\n";
} else {
return this.l(n) + ("return " + (this.build(n.value)) + "\n");
}
};
Builder.prototype[';'] = function(n) {
var src;
if (n.expression == null) {
return "";
} else if (n.expression.typeName() === 'object_init') {
src = this.object_init(n.expression);
if (n.parenthesized) {
return src;
} else {
return "" + (unshift(blockTrim(src))) + "\n";
}
} else {
return this.build(n.expression) + "\n";
}
};
Builder.prototype['new'] = function(n) {
return this.l(n) + ("new " + (this.build(n.left())));
};
Builder.prototype['new_with_args'] = function(n) {
return this.l(n) + ("new " + (this.build(n.left())) + "(" + (this.build(n.right())) + ")");
};
Builder.prototype['unary_plus'] = function(n) {
return "+" + (this.build(n.left()));
};
Builder.prototype['unary_minus'] = function(n) {
return "-" + (this.build(n.left()));
};
Builder.prototype['this'] = function(n) {
return this.l(n) + 'this';
};
Builder.prototype['null'] = function(n) {
return this.l(n) + 'null';
};
Builder.prototype['true'] = function(n) {
return this.l(n) + 'true';
};
Builder.prototype['false'] = function(n) {
return this.l(n) + 'false';
};
Builder.prototype['void'] = function(n) {
return this.l(n) + 'undefined';
};
Builder.prototype['debugger'] = function(n) {
return this.l(n) + "debugger\n";
};
Builder.prototype['break'] = function(n) {
return this.l(n) + "break\n";
};
Builder.prototype['continue'] = function(n) {
return this.l(n) + "continue\n";
};
Builder.prototype['~'] = function(n) {
return "~" + (this.build(n.left()));
};
Builder.prototype['typeof'] = function(n) {
return this.l(n) + ("typeof " + (this.build(n.left())));
};
Builder.prototype['index'] = function(n) {
var right;
right = this.build(n.right());
if (_.any(n.children, function(child) {
return child.typeName() === 'object_init' && child.children.length > 1;
})) {
right = "{" + right + "}";
}
return this.l(n) + ("" + (this.build(n.left())) + "[" + right + "]");
};
Builder.prototype['throw'] = function(n) {
return this.l(n) + ("throw " + (this.build(n.exception)));
};
Builder.prototype['!'] = function(n) {
var negations, target;
target = n.left();
negations = 1;
while ((target.isA('!')) && (target = target.left())) {
++negations;
}
if ((negations & 1) && target.isA('==', '!=', '===', '!==', 'in', 'instanceof')) {
target.negated = !target.negated;
return this.build(target);
}
return this.l(n) + ("" + (negations & 1 ? 'not ' : '!!') + (this.build(target)));
};
Builder.prototype["in"] = function(n) {
return this.binary_operator(n, 'of');
};
Builder.prototype['+'] = function(n) {
return this.binary_operator(n, '+');
};
Builder.prototype['-'] = function(n) {
return this.binary_operator(n, '-');
};
Builder.prototype['*'] = function(n) {
return this.binary_operator(n, '*');
};
Builder.prototype['/'] = function(n) {
return this.binary_operator(n, '/');
};
Builder.prototype['%'] = function(n) {
return this.binary_operator(n, '%');
};
Builder.prototype['>'] = function(n) {
return this.binary_operator(n, '>');
};
Builder.prototype['<'] = function(n) {
return this.binary_operator(n, '<');
};
Builder.prototype['&'] = function(n) {
return this.binary_operator(n, '&');
};
Builder.prototype['|'] = function(n) {
return this.binary_operator(n, '|');
};
Builder.prototype['^'] = function(n) {
return this.binary_operator(n, '^');
};
Builder.prototype['&&'] = function(n) {
return this.binary_operator(n, 'and');
};
Builder.prototype['||'] = function(n) {
return this.binary_operator(n, 'or');
};
Builder.prototype['<<'] = function(n) {
return this.binary_operator(n, '<<');
};
Builder.prototype['<='] = function(n) {
return this.binary_operator(n, '<=');
};
Builder.prototype['>>'] = function(n) {
return this.binary_operator(n, '>>');
};
Builder.prototype['>='] = function(n) {
return this.binary_operator(n, '>=');
};
Builder.prototype['==='] = function(n) {
return this.binary_operator(n, 'is');
};
Builder.prototype['!=='] = function(n) {
return this.binary_operator(n, 'isnt');
};
Builder.prototype['>>>'] = function(n) {
return this.binary_operator(n, '>>>');
};
Builder.prototype["instanceof"] = function(n) {
return this.binary_operator(n, 'instanceof');
};
Builder.prototype['=='] = function(n) {
return this.binary_operator(n, 'is');
};
Builder.prototype['!='] = function(n) {
return this.binary_operator(n, 'isnt');
};
Builder.prototype['binary_operator'] = (function() {
var INVERSIONS, k, v;
INVERSIONS = {
is: 'isnt',
"in": 'not in',
of: 'not of',
"instanceof": 'not instanceof'
};
for (k in INVERSIONS) {
if (!__hasProp.call(INVERSIONS, k)) continue;
v = INVERSIONS[k];
INVERSIONS[v] = k;
}
return function(n, sign) {
if (n.negated) sign = INVERSIONS[sign];
return this.l(n) + ("" + (this.build(n.left())) + " " + sign + " " + (this.build(n.right())));
};
})();
Builder.prototype['--'] = function(n) {
return this.increment_decrement(n, '--');
};
Builder.prototype['++'] = function(n) {
return this.increment_decrement(n, '++');
};
Builder.prototype['increment_decrement'] = function(n, sign) {
if (n.postfix) {
return this.l(n) + ("" + (this.build(n.left())) + sign);
} else {
return this.l(n) + ("" + sign + (this.build(n.left())));
}
};
Builder.prototype['='] = function(n) {
var sign;
sign = n.assignOp != null ? Types[n.assignOp] + '=' : '=';
return this.l(n) + ("" + (this.build(n.left())) + " " + sign + " " + (this.build(n.right())));
};
Builder.prototype[','] = function(n) {
var list,
_this = this;
list = _.map(n.children, function(item) {
return _this.l(item) + _this.build(item) + "\n";
});
return list.join('');
};
Builder.prototype['regexp'] = function(n) {
var begins_with, flag, m, value;
m = n.value.toString().match(/^\/(.*)\/([a-z]?)/);
value = m[1];
flag = m[2];
begins_with = value[0];
if (begins_with === ' ' || begins_with === '=') {
if (flag.length > 0) {
return this.l(n) + ("RegExp(" + (strEscape(value)) + ", \"" + flag + "\")");
} else {
return this.l(n) + ("RegExp(" + (strEscape(value)) + ")");
}
} else {
return this.l(n) + ("/" + value + "/" + flag);
}
};
Builder.prototype['string'] = function(n) {
return this.l(n) + strEscape(n.value);
};
Builder.prototype['call'] = function(n) {
if (n.right().children.length === 0) {
return ("" + (this.build(n.left())) + "()") + this.l(n);
} else {
return ("" + (this.build(n.left())) + "(" + (this.build(n.right())) + ")") + this.l(n);
}
};
Builder.prototype['call_statement'] = function(n) {
var left;
left = this.build(n.left());
if (n.left().isA('function')) left = paren(left);
if (n.right().children.length === 0) {
return ("" + left + "()") + this.l(n);
} else {
return ("" + left + " " + (this.build(n.right()))) + this.l(n);
}
};
Builder.prototype['list'] = function(n) {
var list,
_this = this;
list = _.map(n.children, function(item) {
if (n.children.length > 1) item.is_list_element = true;
return _this.build(item);
});
return this.l(n) + list.join(", ");
};
Builder.prototype['delete'] = function(n) {
var ids,
_this = this;
ids = _.map(n.children, function(el) {
return _this.build(el);
});
ids = ids.join(', ');
return this.l(n) + ("delete " + ids + "\n");
};
Builder.prototype['.'] = function(n) {
var left, right, right_obj;
left = this.build(n.left());
right_obj = n.right();
right_obj.property_accessor = true;
right = this.build(right_obj);
if (n.isThis && n.isPrototype) {
return this.l(n) + "@::";
} else if (n.isThis) {
return this.l(n) + ("@" + right);
} else if (n.isPrototype) {
return this.l(n) + ("" + left + "::");
} else if (n.left().isPrototype) {
return this.l(n) + ("" + left + right);
} else {
return this.l(n) + ("" + left + "." + right);
}
};
Builder.prototype['try'] = function(n) {
var c,
_this = this;
c = new Code;
c.add('try');
c.scope(this.body(n.tryBlock));
_.each(n.catchClauses, function(clause) {
return c.add(_this.build(clause));
});
if (n.finallyBlock != null) {
c.add("finally");
c.scope(this.body(n.finallyBlock));
}
return this.l(n) + c;
};
Builder.prototype['catch'] = function(n) {
var body_, c;
body_ = this.body(n.block);
if (trim(body_).length === 0) return '';
c = new Code;
if (n.varName != null) {
c.add("catch " + n.varName);
} else {
c.add('catch');
}
c.scope(this.body(n.block));
return this.l(n) + c;
};
Builder.prototype['?'] = function(n) {
return this.l(n) + ("(if " + (this.build(n.left())) + " then " + (this.build(n.children[1])) + " else " + (this.build(n.children[2])) + ")");
};
Builder.prototype['for'] = function(n) {
var c;
c = new Code;
if (n.setup != null) c.add("" + (this.build(n.setup)) + "\n");
if (n.condition != null) {
c.add("while " + (this.build(n.condition)) + "\n");
} else {
c.add("loop");
}
c.scope(this.body(n.body));
if (n.update != null) c.scope(this.body(n.update));
return this.l(n) + c;
};
Builder.prototype['for_in'] = function(n) {
var c;
c = new Code;
c.add("for " + (this.build(n.iterator)) + " of " + (this.build(n.object)));
c.scope(this.body(n.body));
return this.l(n) + c;
};
Builder.prototype['while'] = function(n) {
var body_, c, keyword, statement;
c = new Code;
keyword = n.positive ? "while" : "until";
body_ = this.body(n.body);
if (truthy(n.condition)) {
statement = "loop";
} else {
statement = "" + keyword + " " + (this.build(n.condition));
}
if (isSingleLine(body_) && statement !== "loop") {
c.add("" + (trim(body_)) + "  " + statement + "\n");
} else {
c.add(statement);
c.scope(body_);
}
return this.l(n) + c;
};
Builder.prototype['do'] = function(n) {
var c;
c = new Code;
c.add("loop");
c.scope(this.body(n.body));
if (n.condition != null) {
c.scope("break unless " + (this.build(n.condition)));
}
return this.l(n) + c;
};
Builder.prototype['if'] = function(n) {
var body_, c, keyword;
c = new Code;
keyword = n.positive ? "if" : "unless";
body_ = this.body(n.thenPart);
n.condition.parenthesized = false;
if (n.thenPart.isA('block') && n.thenPart.children.length === 0 && !(n.elsePart != null)) {
console.log(n.thenPart);
c.add("" + (this.build(n.condition)) + "\n");
} else if (isSingleLine(body_) && !(n.elsePart != null)) {
c.add("" + (trim(body_)) + "  " + keyword + " " + (this.build(n.condition)) + "\n");
} else {
c.add("" + keyword + " " + (this.build(n.condition)));
c.scope(this.body(n.thenPart));
if (n.elsePart != null) {
if (n.elsePart.typeName() === 'if') {
c.add("else " + (this.build(n.elsePart).toString()));
} else {
c.add(this.l(n.elsePart) + "else\n");
c.scope(this.body(n.elsePart));
}
}
}
return this.l(n) + c;
};
Builder.prototype['switch'] = function(n) {
var c, fall_through,
_this = this;
c = new Code;
c.add("switch " + (this.build(n.discriminant)) + "\n");
fall_through = false;
_.each(n.cases, function(item) {
var first;
if (item.value === 'default') {
c.scope(_this.l(item) + "else");
} else {
if (fall_through === true) {
c.add(_this.l(item) + (", " + (_this.build(item.caseLabel)) + "\n"));
} else {
c.add(_this.l(item) + ("  when " + (_this.build(item.caseLabel))));
}
}
if (_this.body(item.statements).length === 0) {
fall_through = true;
} else {
fall_through = false;
c.add("\n");
c.scope(_this.body(item.statements), 2);
}
return first = false;
});
return this.l(n) + c;
};
Builder.prototype['existence_check'] = function(n) {
return this.l(n) + ("" + (this.build(n.left())) + "?");
};
Builder.prototype['array_init'] = function(n) {
if (n.children.length === 0) {
return this.l(n) + "[]";
} else {
return this.l(n) + ("[" + (this.list(n)) + "]");
}
};
Builder.prototype['property_init'] = function(n) {
var left, right;
left = n.left();
right = n.right();
right.is_property_value = true;
return "" + (this.property_identifier(left)) + ": " + (this.build(right));
};
Builder.prototype['object_init'] = function(n, options) {
var c, list,
_this = this;
if (options == null) options = {};
if (n.children.length === 0) {
return this.l(n) + "{}";
} else if (n.children.length === 1 && !(n.is_property_value || n.is_list_element)) {
return this.build(n.children[0]);
} else {
list = _.map(n.children, function(item) {
return _this.build(item);
});
c = new Code(this, n);
c.scope(list.join("\n"));
if (options.brackets != null) c = "{" + c + "}";
return c;
}
};
Builder.prototype['function'] = function(n) {
var body, c, params,
_this = this;
c = new Code;
params = _.map(n.params, function(str) {
if (str.constructor === String) {
return _this.id_param(str);
} else {
return _this.build(str);
}
});
if (n.name) c.add("" + n.name + " = ");
if (n.params.length > 0) {
c.add("(" + (params.join(', ')) + ") ->");
} else {
c.add("->");
}
body = this.body(n.body);
if (trim(body).length > 0) {
c.scope(body);
} else {
c.add("\n");
}
return this.l(n) + c;
};
Builder.prototype['var'] = function(n) {
var list,
_this = this;
list = _.map(n.children, function(item) {
return "" + (unreserve(item.value)) + " = " + (item.initializer != null ? _this.build(item.initializer) : 'undefined');
});
return this.l(n) + _.compact(list).join("\n") + "\n";
};
Builder.prototype['other'] = function(n) {
return this.unsupported(n, "" + (n.typeName()) + " is not supported yet");
};
Builder.prototype['getter'] = function(n) {
return this.unsupported(n, "getter syntax is not supported; use __defineGetter__");
};
Builder.prototype['setter'] = function(n) {
return this.unsupported(n, "setter syntax is not supported; use __defineSetter__");
};
Builder.prototype['label'] = function(n) {
return this.unsupported(n, "labels are not supported by CoffeeScript");
};
Builder.prototype['const'] = function(n) {
return this.unsupported(n, "consts are not supported by CoffeeScript");
};
Builder.prototype['block'] = function() {
var args;
args = 1 <= arguments.length ? __slice.call(arguments, 0) : [];
return this.script.apply(this, args);
};
Builder.prototype['unsupported'] = function(node, message) {
throw new UnsupportedError("Unsupported: " + message, node);
};
return Builder;
})();
Transformer = (function() {
function Transformer() {}
Transformer.prototype.transform = function() {
var args, fn, node, type;
args = 1 <= arguments.length ? __slice.call(arguments, 0) : [];
node = args[0];
if (node.transformed != null) return;
type = node.typeName();
fn = this[type];
if (fn) {
fn.apply(this, args);
return node.transformed = true;
}
};
Transformer.prototype['script'] = function(n) {
var last,
_this = this;
n.functions = [];
n.nonfunctions = [];
_.each(n.children, function(item) {
if (item.isA('function')) {
return n.functions.push(item);
} else {
return n.nonfunctions.push(item);
}
});
last = null;
return _.each(n.nonfunctions, function(item) {
var expr;
if (item.expression != null) {
expr = item.expression;
if ((last != null ? last.isA('object_init') : void 0) && expr.isA('object_init')) {
item.parenthesized = true;
} else {
item.parenthesized = false;
}
return last = expr;
}
});
};
Transformer.prototype['.'] = function(n) {
n.isThis = n.left().isA('this');
return n.isPrototype = n.right().isA('identifier') && n.right().value === 'prototype';
};
Transformer.prototype[';'] = function(n) {
if (n.expression != null) {
n.expression.parenthesized = false;
if (n.expression.isA('call')) {
n.expression.type = Typenames['call_statement'];
return this.call_statement(n);
}
}
};
Transformer.prototype['function'] = function(n) {
return n.body.walk({
last: true
}, function(parent, node, list) {
var lastNode;
if (node.isA('return') && node.value) {
lastNode = list ? parent[list] : parent.children[parent.children.length - 1];
if (lastNode) {
lastNode.type = Typenames[';'];
return lastNode.expression = lastNode.value;
}
}
});
};
Transformer.prototype['switch'] = function(n) {
var _this = this;
return _.each(n.cases, function(item) {
var block, ch, _ref3;
block = item.statements;
ch = block.children;
if ((_ref3 = block.last()) != null ? _ref3.isA('break') : void 0) {
return delete ch[ch.length - 1];
}
});
};
Transformer.prototype['call_statement'] = function(n) {
if (n.children[1]) {
return _.each(n.children[1].children, function(child, i) {
if (child.isA('function') && i !== n.children[1].children.length - 1) {
return child.parenthesized = true;
}
});
}
};
Transformer.prototype['return'] = function(n) {
if (n.value && n.value.isA('object_init') && n.value.children.length > 1) {
return n.value.parenthesized = true;
}
};
Transformer.prototype['block'] = function(n) {
return this.script(n);
};
Transformer.prototype['if'] = function(n) {
var _ref3;
if (n.thenPart.children.length === 0 && ((_ref3 = n.elsePart) != null ? _ref3.children.length : void 0) > 0) {
n.positive = false;
n.thenPart = n.elsePart;
delete n.elsePart;
}
return this.inversible(n);
};
Transformer.prototype['while'] = function(n) {
if (n.body.children.length === 0) {
n.body.children.push(n.clone({
type: Typenames['continue'],
value: 'continue',
children: []
}));
}
return this.inversible(n);
};
Transformer.prototype['inversible'] = function(n) {
var positive;
this.transform(n.condition);
positive = n.positive != null ? n.positive : true;
if (n.condition.isA('!=')) {
n.condition.type = Typenames['=='];
return n.positive = !positive;
} else if (n.condition.isA('!')) {
n.condition = n.condition.left();
return n.positive = !positive;
} else {
return n.positive = positive;
}
};
Transformer.prototype['=='] = function(n) {
if (n.right().isA('null', 'void')) {
n.type = Typenames['!'];
return n.children = [
n.clone({
type: Typenames['existence_check'],
children: [n.left()]
})
];
}
};
Transformer.prototype['!='] = function(n) {
if (n.right().isA('null', 'void')) {
n.type = Typenames['existence_check'];
return n.children = [n.left()];
}
};
return Transformer;
})();
UnsupportedError = (function() {
function UnsupportedError(str, src) {
this.message = str;
this.cursor = src.start;
this.line = src.lineno;
this.source = src.tokenizer.source;
}
UnsupportedError.prototype.toString = function() {
return this.message;
};
return UnsupportedError;
})();
this.Js2coffee = exports = {
VERSION: '0.2.0',
build: buildCoffee,
UnsupportedError: UnsupportedError
};
if (typeof module !== "undefined" && module !== null) module.exports = exports;
}).call(this);

Zerion Mini Shell 1.0