From 45972f9a6a0b689abbf8815cf40511cf99e4bbdc Mon Sep 17 00:00:00 2001 From: Alessandro Warth Date: Tue, 2 Jun 2015 23:19:27 -0700 Subject: [PATCH] (1) brought back the ability to write semantic actions for _iter nodes. (2) added default behaviors for _iter and _terminal nodes, that way most people will never have to worry about them. (3) added default implementation of _default action that does what ohm.actions.passThrough used to do. (4) got rid of the default semantic actions (ohm.actions) because now that's what you get automatically. --- dist/ohm.js | 149 +++++++++++++++++++------------ dist/ohm.min.js | 10 +-- examples/math/index.html | 31 +++++-- examples/viz/index.html | 3 +- src/Grammar.js | 10 ++- src/Semantics.js | 77 ++++++++-------- src/main.js | 7 +- test/ohm-spec.js | 137 +++++++--------------------- test/test-parameterized-rules.js | 17 +--- test/test-semantics.js | 38 +++----- 10 files changed, 214 insertions(+), 265 deletions(-) diff --git a/dist/ohm.js b/dist/ohm.js index b43cc2a6..a72b2229 100644 --- a/dist/ohm.js +++ b/dist/ohm.js @@ -2240,6 +2240,12 @@ Grammar.prototype = { _terminal: function() { this._node.parent = stack[stack.length - 1]; }, + _iter: function(children) { + stack.push(this._node); + children.forEach(function(child) { child.setParents(); }); + stack.pop(); + this._node.parent = stack[stack.length - 1]; + }, _default: function(children) { stack.push(this._node); children.forEach(function(child) { child.setParents(); }); @@ -2277,7 +2283,7 @@ Grammar.prototype = { // a function of the correct arity. If not, throw an exception. _checkTopDownActionDict: function(what, name, actionDict) { function isSpecialAction(name) { - return name === '_terminal' || name === '_default'; + return name === '_terminal' || name === '_iter' || name === '_default'; } var problems = []; @@ -2311,7 +2317,7 @@ Grammar.prototype = { // Return the expected arity for a semantic action named `actionName`, which // is either a rule name or a special action name like '_default'. _topDownActionArity: function(actionName) { - if (actionName === '_default') { + if (actionName === '_default' || actionName === '_iter') { return 1; } else if (actionName === '_terminal') { return 0; @@ -2389,7 +2395,6 @@ Grammar.prototype = { // TODO: add the super-grammar's templates at the right place, e.g., a case for AddExpr_plus // should appear next to other cases of AddExpr. - var self = this; var sb = new common.StringBuffer(); sb.append('{'); @@ -3257,7 +3262,37 @@ Semantics.prototype.addOperationOrAttribute = function(type, name, actionDict) { var Ctor = type === 'operation' ? Operation : Attribute; this.assertNewName(name, type); - this[typePlural][name] = new Ctor(name, actionDict); + + // Create the action dictionary for this operation / attribute. We begin by defining the default + // behavior of terminal and iteration nodes, and add a '_default' action that throws an error if + // a rule in the grammar doesn't have a corresponding action in this operation / attribute... + var realActionDict = { + _terminal: function() { + return this.primitiveValue; + }, + _iter: function(children) { + // This CST node corresponds to an iteration expression in the grammar (*, +, or ?). The + // default behavior is to map this operation or attribute over all of its child nodes. + var thisSemantics = this._semantics; + var thisThing = thisSemantics[typePlural][name]; + return children.map(function(child) { return thisThing.execute(thisSemantics, child); }); + }, + _default: function(children) { + if (children.length === 1) { + var thisSemantics = this._semantics; + var thisThing = thisSemantics[typePlural][name]; + return thisThing.execute(thisSemantics, children[0]); + } + throw new Error('missing semantic action for ' + this.ctorName + ' in ' + name + ' ' + type); + } + }; + // ... and add in the actions supplied by the programmer, which may override some or all of the + // default ones. + Object.keys(actionDict).forEach(function(name) { + realActionDict[name] = actionDict[name]; + }); + + this[typePlural][name] = new Ctor(name, realActionDict); // The following check is not strictly necessary (it will happen later anyway) but it's better to // catch errors early. @@ -3386,19 +3421,6 @@ Semantics.createSemantics = function(grammar, optSuperSemantics) { return proxy; }; -// ----------------- Default semantic actions ----------------- - -var actions = { - getPrimitiveValue: function() { - return this.primitiveValue; - }, - passThrough: function(childNode) { - throw new Error('BUG: ohm.actions.passThrough should never be called'); - } -}; - -Semantics.actions = actions; - // ----------------- Operation ----------------- // An Operation represents a function to be applied to a concrete syntax tree (CST) -- it's very @@ -3420,34 +3442,19 @@ Operation.prototype.checkActionDict = function(grammar) { // Execute this operation on the CST node associated with `nodeWrapper` in the context of the given // Semantics instance. Operation.prototype.execute = function(semantics, nodeWrapper) { - if (nodeWrapper.isIteration()) { - // This CST node corresponds to an iteration expression in the grammar (*, +, or ?), so we map - // this operation over all of its child nodes. - var results = []; - for (var idx = 0; idx < nodeWrapper._node.numChildren(); idx++) { - results.push(this.execute(semantics, nodeWrapper.child(idx))); - } - return results; - } - // Look for a semantic action whose name matches the node's constructor name, which is either the - // name of a rule in the grammar, or the special value '_terminal'. + // name of a rule in the grammar, or '_terminal' (for a terminal node), or '_iter' (for an + // iteration node). In the latter case, the action function receives a single argument, which is + // an array containing all of the children of the CST node. var actionFn = this.actionDict[nodeWrapper._node.ctorName]; if (actionFn) { - return this.doAction(semantics, nodeWrapper, actionFn); + return this.doAction(semantics, nodeWrapper, actionFn, nodeWrapper.isIteration()); } // The action dictionary does not contain a semantic action for this specific type of node, so - // invoke the '_default' semantic action if it exists (but only if this node is not a terminal). - var defaultActionFn = this.actionDict._default; - if (defaultActionFn && !nodeWrapper.isTerminal()) { - return this.doAction(semantics, nodeWrapper, defaultActionFn, true); - } - - // The programmer hasn't written a semantic action for this type of node yet. - throw new Error( - 'missing semantic action for ' + nodeWrapper._node.ctorName + ' in ' + this.name + ' ' + - this.typeName); + // invoke the '_default' semantic action. The built-in implementation of the `_default` semantic + // action just throws an error, but the programmer may have overridden it. + return this.doAction(semantics, nodeWrapper, this.actionDict._default, true); }; // Invoke `actionFn` on the CST node that corresponds to `nodeWrapper`, in the context of @@ -3455,9 +3462,6 @@ Operation.prototype.execute = function(semantics, nodeWrapper) { // argument, which is an array of wrappers. Otherwise, the number of arguments to `actionFn` will // be equal to the number of children in the CST node. Operation.prototype.doAction = function(semantics, nodeWrapper, actionFn, optPassChildrenAsArray) { - if (actionFn === actions.passThrough) { - return this.execute(semantics, nodeWrapper._onlyChild()); - } return optPassChildrenAsArray ? actionFn.call(nodeWrapper, nodeWrapper._children()) : actionFn.apply(nodeWrapper, nodeWrapper._children()); @@ -3823,10 +3827,6 @@ var extend = _dereq_('util-extend'); // Helpers -function repeatStr(str, n) { - return new Array(n + 1).join(str); -} - var escapeStringFor = {}; for (var c = 0; c < 128; c++) { escapeStringFor[c] = String.fromCharCode(c); @@ -3849,6 +3849,12 @@ exports.abstract = function() { throw new Error('this method is abstract!'); }; +exports.assert = function(cond, message) { + if (!cond) { + throw new Error(message); + } +}; + // Define a lazily-computed, non-enumerable property named `propName` // on the object `obj`. `getterFn` will be called to compute the value the // first time the property is accessed. @@ -3881,6 +3887,10 @@ exports.repeatFn = function(fn, n) { return arr; }; +exports.repeatStr = function(str, n) { + return new Array(n + 1).join(str); +}; + exports.repeat = function(x, n) { return exports.repeatFn(function() { return x; }, n); }; @@ -3906,7 +3916,7 @@ exports.isSyntactic = function(ruleName) { exports.padLeft = function(str, len, optChar) { var ch = optChar || ' '; if (str.length < len) { - return repeatStr(ch, len - str.length) + str; + return exports.repeatStr(ch, len - str.length) + str; } return str; }; @@ -4288,7 +4298,6 @@ module.exports = { var Builder = _dereq_('./Builder'); var Grammar = _dereq_('./Grammar'); var Namespace = _dereq_('./Namespace'); -var Semantics = _dereq_('./Semantics'); var UnicodeCategories = _dereq_('../third_party/unicode').UnicodeCategories; var common = _dereq_('./common'); var errors = _dereq_('./errors'); @@ -4554,10 +4563,7 @@ function buildGrammar(match, namespace, optOhmGrammarForTesting) { }, ListOf_none: function() { return []; - }, - - _terminal: Semantics.actions.getPrimitiveValue, - _default: Semantics.actions.passThrough + } }); return helpers(match).visit(); } @@ -4658,7 +4664,6 @@ function makeRecipe(recipeFn) { // Stuff that users should know about module.exports = { - actions: Semantics.actions, createNamespace: Namespace.createNamespace, error: errors, grammar: grammar, @@ -4677,7 +4682,7 @@ module.exports._setDocumentInterfaceForTesting = function(doc) { documentInterfa module.exports.ohmGrammar = ohmGrammar; }).call(this,_dereq_("buffer").Buffer) -},{"../dist/built-in-rules":1,"../dist/ohm-grammar":2,"../third_party/unicode":46,"./Builder":15,"./Grammar":16,"./Namespace":21,"./Semantics":23,"./common":26,"./errors":27,"./util":45,"buffer":3}],29:[function(_dereq_,module,exports){ +},{"../dist/built-in-rules":1,"../dist/ohm-grammar":2,"../third_party/unicode":46,"./Builder":15,"./Grammar":16,"./Namespace":21,"./common":26,"./errors":27,"./util":45,"buffer":3}],29:[function(_dereq_,module,exports){ 'use strict'; var inherits = _dereq_('inherits'); @@ -6453,6 +6458,15 @@ function padNumbersToEqualLength(arr) { return strings.map(function(s) { return common.padLeft(s, maxLen); }); } +// Produce a new string that would be the result of copying the contents +// of the string `src` onto `dest` at offset `offest`. +function strcpy(dest, src, offset) { + var origDestLen = dest.length; + var start = dest.slice(0, offset); + var end = dest.slice(offset + src.length); + return (start + src + end).substr(0, origDestLen); +} + // -------------------------------------------------------------------- // Exports // -------------------------------------------------------------------- @@ -6515,7 +6529,9 @@ exports.getLineAndColumn = function(str, offset) { // Return a nicely-formatted string describing the line and column for the // given offset in `str`. -exports.getLineAndColumnMessage = function(str, offset) { +exports.getLineAndColumnMessage = function(str, offset /* ...ranges */) { + var repeatStr = common.repeatStr; + var lineAndCol = exports.getLineAndColumn(str, offset); var sb = new common.StringBuffer(); sb.append('Line ' + lineAndCol.lineNum + ', col ' + lineAndCol.colNum + ':\n'); @@ -6539,9 +6555,26 @@ exports.getLineAndColumnMessage = function(str, offset) { // Line that the error occurred on. appendLine(1, lineAndCol.line, '> '); - // Line indicating the column on which the error occurred. + // Build up the line that points to the offset and possible indicates one or more ranges. + // Start with a blank line, and indicate each range by overlaying a string of `~` chars. + var lineLen = lineAndCol.line.length; + var indicationLine = repeatStr(' ', lineLen + 1); + var ranges = Array.prototype.slice.call(arguments, 2); + for (var i = 0; i < ranges.length; ++i) { + var startIdx = ranges[i][0]; + var endIdx = ranges[i][1]; + common.assert(startIdx >= 0 && startIdx <= endIdx, 'range start must be >= 0 and <= end'); + + var lineStartOffset = offset - lineAndCol.colNum + 1; + startIdx = Math.max(0, startIdx - lineStartOffset); + endIdx = Math.min(endIdx - lineStartOffset, lineLen); + + indicationLine = strcpy(indicationLine, repeatStr('~', endIdx - startIdx), startIdx); + } var gutterWidth = 2 + lineNumbers[1].length + 3; - sb.append(common.padLeft('^', gutterWidth + lineAndCol.colNum) + '\n'); + sb.append(repeatStr(' ', gutterWidth)); + indicationLine = strcpy(indicationLine, '^', lineAndCol.colNum - 1); + sb.append(indicationLine.replace(/ +$/, '') + '\n'); // Include the next line for context if possible. if (lineAndCol.nextLine != null) { @@ -6584,6 +6617,6 @@ exports.UnicodeCategories = { }; },{}]},{},[28]) -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["/Users/awarth/prog/ohm/node_modules/browserify/node_modules/browser-pack/_prelude.js","/Users/awarth/prog/ohm/dist/built-in-rules.js","/Users/awarth/prog/ohm/dist/ohm-grammar.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/buffer/index.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/buffer/node_modules/base64-js/lib/b64.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/buffer/node_modules/ieee754/index.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/crypto-browserify/helpers.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/crypto-browserify/index.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/crypto-browserify/md5.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/crypto-browserify/rng.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/crypto-browserify/sha.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/crypto-browserify/sha256.js","/Users/awarth/prog/ohm/node_modules/inherits/inherits_browser.js","/Users/awarth/prog/ohm/node_modules/symbol/index.js","/Users/awarth/prog/ohm/node_modules/util-extend/extend.js","/Users/awarth/prog/ohm/src/Builder.js","/Users/awarth/prog/ohm/src/Grammar.js","/Users/awarth/prog/ohm/src/GrammarDecl.js","/Users/awarth/prog/ohm/src/InputStream.js","/Users/awarth/prog/ohm/src/Interval.js","/Users/awarth/prog/ohm/src/MatchResult.js","/Users/awarth/prog/ohm/src/Namespace.js","/Users/awarth/prog/ohm/src/PosInfo.js","/Users/awarth/prog/ohm/src/Semantics.js","/Users/awarth/prog/ohm/src/State.js","/Users/awarth/prog/ohm/src/Trace.js","/Users/awarth/prog/ohm/src/common.js","/Users/awarth/prog/ohm/src/errors.js","/Users/awarth/prog/ohm/src/main.js","/Users/awarth/prog/ohm/src/nodes.js","/Users/awarth/prog/ohm/src/pexprs-assertAllApplicationsAreValid.js","/Users/awarth/prog/ohm/src/pexprs-assertChoicesHaveUniformArity.js","/Users/awarth/prog/ohm/src/pexprs-assertIteratedExprsAreNotNullable.js","/Users/awarth/prog/ohm/src/pexprs-check.js","/Users/awarth/prog/ohm/src/pexprs-eval.js","/Users/awarth/prog/ohm/src/pexprs-getArity.js","/Users/awarth/prog/ohm/src/pexprs-introduceParams.js","/Users/awarth/prog/ohm/src/pexprs-isNullable.js","/Users/awarth/prog/ohm/src/pexprs-maybeRecordFailure.js","/Users/awarth/prog/ohm/src/pexprs-outputRecipe.js","/Users/awarth/prog/ohm/src/pexprs-substituteParams.js","/Users/awarth/prog/ohm/src/pexprs-toDisplayString.js","/Users/awarth/prog/ohm/src/pexprs-toExpected.js","/Users/awarth/prog/ohm/src/pexprs-toString.js","/Users/awarth/prog/ohm/src/pexprs.js","/Users/awarth/prog/ohm/src/util.js","/Users/awarth/prog/ohm/third_party/unicode.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrlCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChaA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5aA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);throw new Error(\"Cannot find module '\"+o+\"'\")}var f=n[o]={exports:{}};t[o][0].call(f.exports,function(e){var n=t[o][1][e];return s(n?n:e)},f,f.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","var ohm = require('..');\nmodule.exports = ohm.makeRecipe(function() {\n  return new this.newGrammar('BuiltInRules')\n    .define('alnum', [], this.prim(/[0-9a-zA-Z]/), 'an alpha-numeric character')\n    .define('letter', [], this.prim(/[a-zA-Z]/), 'a letter')\n    .define('lower', [], this.prim(/[a-z]/), 'a lower-case letter')\n    .define('upper', [], this.prim(/[A-Z]/), 'an upper-case letter')\n    .define('digit', [], this.prim(/[0-9]/), 'a digit')\n    .define('hexDigit', [], this.prim(/[0-9a-fA-F]/), 'a hexadecimal digit')\n    .define('ListOf_some', ['elem', 'sep'], this.seq(this.param(0), this.star(this.seq(this.param(1), this.param(0)))))\n    .define('ListOf_none', ['elem', 'sep'], this.seq())\n    .define('ListOf', ['elem', 'sep'], this.alt(this.app('ListOf_some', [this.app('elem'), this.app('sep')]), this.app('ListOf_none', [this.app('elem'), this.app('sep')])))\n    .build();\n});\n\n","var ohm = require('..');\nmodule.exports = ohm.makeRecipe(function() {\n  return new this.newGrammar('Ohm')\n    .withDefaultStartRule('Grammars')\n    .define('Grammars', [], this.star(this.app('Grammar')))\n    .define('Grammar', [], this.seq(this.app('ident'), this.opt(this.app('SuperGrammar')), this.prim('{'), this.star(this.app('Rule')), this.prim('}')))\n    .define('SuperGrammar', [], this.seq(this.prim('<:'), this.app('ident')))\n    .define('Rule_define', [], this.seq(this.app('ident'), this.opt(this.app('Formals')), this.opt(this.app('ruleDescr')), this.prim('='), this.app('Alt')))\n    .define('Rule_override', [], this.seq(this.app('ident'), this.opt(this.app('Formals')), this.prim(':='), this.app('Alt')))\n    .define('Rule_extend', [], this.seq(this.app('ident'), this.opt(this.app('Formals')), this.prim('+='), this.app('Alt')))\n    .define('Rule', [], this.alt(this.app('Rule_define'), this.app('Rule_override'), this.app('Rule_extend')))\n    .define('Formals', [], this.seq(this.prim('<'), this.app('ListOf', [this.app('ident'), this.prim(',')]), this.prim('>')))\n    .define('Params', [], this.seq(this.prim('<'), this.app('ListOf', [this.app('Seq'), this.prim(',')]), this.prim('>')))\n    .define('Alt', [], this.seq(this.app('Term'), this.star(this.seq(this.prim('|'), this.app('Term')))))\n    .define('Term_inline', [], this.seq(this.app('Seq'), this.app('caseName')))\n    .define('Term', [], this.alt(this.app('Term_inline'), this.app('Seq')))\n    .define('Seq', [], this.star(this.app('Iter')))\n    .define('Iter_star', [], this.seq(this.app('Pred'), this.prim('*')))\n    .define('Iter_plus', [], this.seq(this.app('Pred'), this.prim('+')))\n    .define('Iter_opt', [], this.seq(this.app('Pred'), this.prim('?')))\n    .define('Iter', [], this.alt(this.app('Iter_star'), this.app('Iter_plus'), this.app('Iter_opt'), this.app('Pred')))\n    .define('Pred_not', [], this.seq(this.prim('~'), this.app('Base')))\n    .define('Pred_lookahead', [], this.seq(this.prim('&'), this.app('Base')))\n    .define('Pred', [], this.alt(this.app('Pred_not'), this.app('Pred_lookahead'), this.app('Base')))\n    .define('Base_application', [], this.seq(this.app('ident'), this.opt(this.app('Params')), this.not(this.alt(this.seq(this.opt(this.app('ruleDescr')), this.prim('=')), this.prim(':='), this.prim('+=')))))\n    .define('Base_prim', [], this.alt(this.app('keyword'), this.app('string'), this.app('regExp'), this.app('number')))\n    .define('Base_paren', [], this.seq(this.prim('('), this.app('Alt'), this.prim(')')))\n    .define('Base_arr', [], this.seq(this.prim('['), this.app('Alt'), this.prim(']')))\n    .define('Base_str', [], this.seq(this.prim('``'), this.app('Alt'), this.prim(\"''\")))\n    .define('Base_obj', [], this.seq(this.prim('{'), this.opt(this.prim('...')), this.prim('}')))\n    .define('Base_objWithProps', [], this.seq(this.prim('{'), this.app('Props'), this.opt(this.seq(this.prim(','), this.prim('...'))), this.prim('}')))\n    .define('Base', [], this.alt(this.app('Base_application'), this.app('Base_prim'), this.app('Base_paren'), this.app('Base_arr'), this.app('Base_str'), this.app('Base_obj'), this.app('Base_objWithProps')))\n    .define('Props', [], this.seq(this.app('Prop'), this.star(this.seq(this.prim(','), this.app('Prop')))))\n    .define('Prop', [], this.seq(this.alt(this.app('name'), this.app('string')), this.prim(':'), this.app('Alt')))\n    .define('ruleDescr', [], this.seq(this.prim('('), this.app('ruleDescrText'), this.prim(')')), 'a rule description')\n    .define('ruleDescrText', [], this.star(this.seq(this.not(this.prim(')')), this.app('_'))))\n    .define('caseName', [], this.seq(this.prim('--'), this.star(this.seq(this.not(this.prim('\\n')), this.app('space'))), this.app('name'), this.star(this.seq(this.not(this.prim('\\n')), this.app('space'))), this.alt(this.prim('\\n'), this.la(this.prim('}')))))\n    .define('name', [], this.seq(this.app('nameFirst'), this.star(this.app('nameRest'))), 'a name')\n    .define('nameFirst', [], this.alt(this.prim('_'), this.app('letter')))\n    .define('nameRest', [], this.alt(this.prim('_'), this.app('alnum')))\n    .define('ident', [], this.seq(this.not(this.app('keyword')), this.app('name')), 'an identifier')\n    .define('keyword_null', [], this.seq(this.prim('null'), this.not(this.app('nameRest'))))\n    .define('keyword_true', [], this.seq(this.prim('true'), this.not(this.app('nameRest'))))\n    .define('keyword_false', [], this.seq(this.prim('false'), this.not(this.app('nameRest'))))\n    .define('keyword', [], this.alt(this.app('keyword_null'), this.app('keyword_true'), this.app('keyword_false')))\n    .define('string', [], this.seq(this.prim('\"'), this.star(this.app('strChar')), this.prim('\"')), 'a string literal')\n    .define('strChar', [], this.alt(this.app('escapeChar'), this.seq(this.not(this.prim('\\\\')), this.not(this.prim('\"')), this.not(this.prim('\\n')), this.app('_'))))\n    .define('escapeChar_backslash', [], this.prim('\\\\\\\\'))\n    .define('escapeChar_doubleQuote', [], this.prim('\\\\\"'))\n    .define('escapeChar_singleQuote', [], this.prim(\"\\\\'\"))\n    .define('escapeChar_backspace', [], this.prim('\\\\b'))\n    .define('escapeChar_lineFeed', [], this.prim('\\\\n'))\n    .define('escapeChar_carriageReturn', [], this.prim('\\\\r'))\n    .define('escapeChar_tab', [], this.prim('\\\\t'))\n    .define('escapeChar_unicodeEscape', [], this.seq(this.prim('\\\\u'), this.app('hexDigit'), this.app('hexDigit'), this.app('hexDigit'), this.app('hexDigit')))\n    .define('escapeChar_hexEscape', [], this.seq(this.prim('\\\\x'), this.app('hexDigit'), this.app('hexDigit')))\n    .define('escapeChar', [], this.alt(this.app('escapeChar_backslash'), this.app('escapeChar_doubleQuote'), this.app('escapeChar_singleQuote'), this.app('escapeChar_backspace'), this.app('escapeChar_lineFeed'), this.app('escapeChar_carriageReturn'), this.app('escapeChar_tab'), this.app('escapeChar_unicodeEscape'), this.app('escapeChar_hexEscape')))\n    .define('regExp', [], this.seq(this.prim('/'), this.app('reCharClass'), this.prim('/')), 'a regular expression')\n    .define('reCharClass_unicode', [], this.seq(this.prim('\\\\p{'), this.plus(this.prim(/[A-Za-z]/)), this.prim('}')))\n    .define('reCharClass_ordinary', [], this.seq(this.prim('['), this.star(this.alt(this.prim('\\\\]'), this.seq(this.not(this.prim(']')), this.app('_')))), this.prim(']')))\n    .define('reCharClass', [], this.alt(this.app('reCharClass_unicode'), this.app('reCharClass_ordinary')))\n    .define('number', [], this.seq(this.opt(this.prim('-')), this.plus(this.app('digit'))), 'a number')\n    .define('space_singleLine', [], this.seq(this.prim('//'), this.star(this.seq(this.not(this.prim('\\n')), this.app('_'))), this.prim('\\n')))\n    .define('space_multiLine', [], this.seq(this.prim('/*'), this.star(this.seq(this.not(this.prim('*/')), this.app('_'))), this.prim('*/')))\n    .extend('space', [], this.alt(this.alt(this.app('space_singleLine'), this.app('space_multiLine')), this.prim(/[\\s]/)), 'a space')\n    .build();\n});\n\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * @license  MIT\n */\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = Buffer\nexports.INSPECT_MAX_BYTES = 50\nBuffer.poolSize = 8192\n\n/**\n * If `Buffer._useTypedArrays`:\n *   === true    Use Uint8Array implementation (fastest)\n *   === false   Use Object implementation (compatible down to IE6)\n */\nBuffer._useTypedArrays = (function () {\n  // Detect if browser supports Typed Arrays. Supported browsers are IE 10+, Firefox 4+,\n  // Chrome 7+, Safari 5.1+, Opera 11.6+, iOS 4.2+. If the browser does not support adding\n  // properties to `Uint8Array` instances, then that's the same as no `Uint8Array` support\n  // because we need to be able to add all the node Buffer API methods. This is an issue\n  // in Firefox 4-29. Now fixed: https://bugzilla.mozilla.org/show_bug.cgi?id=695438\n  try {\n    var buf = new ArrayBuffer(0)\n    var arr = new Uint8Array(buf)\n    arr.foo = function () { return 42 }\n    return 42 === arr.foo() &&\n        typeof arr.subarray === 'function' // Chrome 9-10 lack `subarray`\n  } catch (e) {\n    return false\n  }\n})()\n\n/**\n * Class: Buffer\n * =============\n *\n * The Buffer constructor returns instances of `Uint8Array` that are augmented\n * with function properties for all the node `Buffer` API functions. We use\n * `Uint8Array` so that square bracket notation works as expected -- it returns\n * a single octet.\n *\n * By augmenting the instances, we can avoid modifying the `Uint8Array`\n * prototype.\n */\nfunction Buffer (subject, encoding, noZero) {\n  if (!(this instanceof Buffer))\n    return new Buffer(subject, encoding, noZero)\n\n  var type = typeof subject\n\n  // Workaround: node's base64 implementation allows for non-padded strings\n  // while base64-js does not.\n  if (encoding === 'base64' && type === 'string') {\n    subject = stringtrim(subject)\n    while (subject.length % 4 !== 0) {\n      subject = subject + '='\n    }\n  }\n\n  // Find the length\n  var length\n  if (type === 'number')\n    length = coerce(subject)\n  else if (type === 'string')\n    length = Buffer.byteLength(subject, encoding)\n  else if (type === 'object')\n    length = coerce(subject.length) // assume that object is array-like\n  else\n    throw new Error('First argument needs to be a number, array or string.')\n\n  var buf\n  if (Buffer._useTypedArrays) {\n    // Preferred: Return an augmented `Uint8Array` instance for best performance\n    buf = Buffer._augment(new Uint8Array(length))\n  } else {\n    // Fallback: Return THIS instance of Buffer (created by `new`)\n    buf = this\n    buf.length = length\n    buf._isBuffer = true\n  }\n\n  var i\n  if (Buffer._useTypedArrays && typeof subject.byteLength === 'number') {\n    // Speed optimization -- use set if we're copying from a typed array\n    buf._set(subject)\n  } else if (isArrayish(subject)) {\n    // Treat array-ish objects as a byte array\n    for (i = 0; i < length; i++) {\n      if (Buffer.isBuffer(subject))\n        buf[i] = subject.readUInt8(i)\n      else\n        buf[i] = subject[i]\n    }\n  } else if (type === 'string') {\n    buf.write(subject, 0, encoding)\n  } else if (type === 'number' && !Buffer._useTypedArrays && !noZero) {\n    for (i = 0; i < length; i++) {\n      buf[i] = 0\n    }\n  }\n\n  return buf\n}\n\n// STATIC METHODS\n// ==============\n\nBuffer.isEncoding = function (encoding) {\n  switch (String(encoding).toLowerCase()) {\n    case 'hex':\n    case 'utf8':\n    case 'utf-8':\n    case 'ascii':\n    case 'binary':\n    case 'base64':\n    case 'raw':\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      return true\n    default:\n      return false\n  }\n}\n\nBuffer.isBuffer = function (b) {\n  return !!(b !== null && b !== undefined && b._isBuffer)\n}\n\nBuffer.byteLength = function (str, encoding) {\n  var ret\n  str = str + ''\n  switch (encoding || 'utf8') {\n    case 'hex':\n      ret = str.length / 2\n      break\n    case 'utf8':\n    case 'utf-8':\n      ret = utf8ToBytes(str).length\n      break\n    case 'ascii':\n    case 'binary':\n    case 'raw':\n      ret = str.length\n      break\n    case 'base64':\n      ret = base64ToBytes(str).length\n      break\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      ret = str.length * 2\n      break\n    default:\n      throw new Error('Unknown encoding')\n  }\n  return ret\n}\n\nBuffer.concat = function (list, totalLength) {\n  assert(isArray(list), 'Usage: Buffer.concat(list, [totalLength])\\n' +\n      'list should be an Array.')\n\n  if (list.length === 0) {\n    return new Buffer(0)\n  } else if (list.length === 1) {\n    return list[0]\n  }\n\n  var i\n  if (typeof totalLength !== 'number') {\n    totalLength = 0\n    for (i = 0; i < list.length; i++) {\n      totalLength += list[i].length\n    }\n  }\n\n  var buf = new Buffer(totalLength)\n  var pos = 0\n  for (i = 0; i < list.length; i++) {\n    var item = list[i]\n    item.copy(buf, pos)\n    pos += item.length\n  }\n  return buf\n}\n\n// BUFFER INSTANCE METHODS\n// =======================\n\nfunction _hexWrite (buf, string, offset, length) {\n  offset = Number(offset) || 0\n  var remaining = buf.length - offset\n  if (!length) {\n    length = remaining\n  } else {\n    length = Number(length)\n    if (length > remaining) {\n      length = remaining\n    }\n  }\n\n  // must be an even number of digits\n  var strLen = string.length\n  assert(strLen % 2 === 0, 'Invalid hex string')\n\n  if (length > strLen / 2) {\n    length = strLen / 2\n  }\n  for (var i = 0; i < length; i++) {\n    var byte = parseInt(string.substr(i * 2, 2), 16)\n    assert(!isNaN(byte), 'Invalid hex string')\n    buf[offset + i] = byte\n  }\n  Buffer._charsWritten = i * 2\n  return i\n}\n\nfunction _utf8Write (buf, string, offset, length) {\n  var charsWritten = Buffer._charsWritten =\n    blitBuffer(utf8ToBytes(string), buf, offset, length)\n  return charsWritten\n}\n\nfunction _asciiWrite (buf, string, offset, length) {\n  var charsWritten = Buffer._charsWritten =\n    blitBuffer(asciiToBytes(string), buf, offset, length)\n  return charsWritten\n}\n\nfunction _binaryWrite (buf, string, offset, length) {\n  return _asciiWrite(buf, string, offset, length)\n}\n\nfunction _base64Write (buf, string, offset, length) {\n  var charsWritten = Buffer._charsWritten =\n    blitBuffer(base64ToBytes(string), buf, offset, length)\n  return charsWritten\n}\n\nfunction _utf16leWrite (buf, string, offset, length) {\n  var charsWritten = Buffer._charsWritten =\n    blitBuffer(utf16leToBytes(string), buf, offset, length)\n  return charsWritten\n}\n\nBuffer.prototype.write = function (string, offset, length, encoding) {\n  // Support both (string, offset, length, encoding)\n  // and the legacy (string, encoding, offset, length)\n  if (isFinite(offset)) {\n    if (!isFinite(length)) {\n      encoding = length\n      length = undefined\n    }\n  } else {  // legacy\n    var swap = encoding\n    encoding = offset\n    offset = length\n    length = swap\n  }\n\n  offset = Number(offset) || 0\n  var remaining = this.length - offset\n  if (!length) {\n    length = remaining\n  } else {\n    length = Number(length)\n    if (length > remaining) {\n      length = remaining\n    }\n  }\n  encoding = String(encoding || 'utf8').toLowerCase()\n\n  var ret\n  switch (encoding) {\n    case 'hex':\n      ret = _hexWrite(this, string, offset, length)\n      break\n    case 'utf8':\n    case 'utf-8':\n      ret = _utf8Write(this, string, offset, length)\n      break\n    case 'ascii':\n      ret = _asciiWrite(this, string, offset, length)\n      break\n    case 'binary':\n      ret = _binaryWrite(this, string, offset, length)\n      break\n    case 'base64':\n      ret = _base64Write(this, string, offset, length)\n      break\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      ret = _utf16leWrite(this, string, offset, length)\n      break\n    default:\n      throw new Error('Unknown encoding')\n  }\n  return ret\n}\n\nBuffer.prototype.toString = function (encoding, start, end) {\n  var self = this\n\n  encoding = String(encoding || 'utf8').toLowerCase()\n  start = Number(start) || 0\n  end = (end !== undefined)\n    ? Number(end)\n    : end = self.length\n\n  // Fastpath empty strings\n  if (end === start)\n    return ''\n\n  var ret\n  switch (encoding) {\n    case 'hex':\n      ret = _hexSlice(self, start, end)\n      break\n    case 'utf8':\n    case 'utf-8':\n      ret = _utf8Slice(self, start, end)\n      break\n    case 'ascii':\n      ret = _asciiSlice(self, start, end)\n      break\n    case 'binary':\n      ret = _binarySlice(self, start, end)\n      break\n    case 'base64':\n      ret = _base64Slice(self, start, end)\n      break\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      ret = _utf16leSlice(self, start, end)\n      break\n    default:\n      throw new Error('Unknown encoding')\n  }\n  return ret\n}\n\nBuffer.prototype.toJSON = function () {\n  return {\n    type: 'Buffer',\n    data: Array.prototype.slice.call(this._arr || this, 0)\n  }\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function (target, target_start, start, end) {\n  var source = this\n\n  if (!start) start = 0\n  if (!end && end !== 0) end = this.length\n  if (!target_start) target_start = 0\n\n  // Copy 0 bytes; we're done\n  if (end === start) return\n  if (target.length === 0 || source.length === 0) return\n\n  // Fatal error conditions\n  assert(end >= start, 'sourceEnd < sourceStart')\n  assert(target_start >= 0 && target_start < target.length,\n      'targetStart out of bounds')\n  assert(start >= 0 && start < source.length, 'sourceStart out of bounds')\n  assert(end >= 0 && end <= source.length, 'sourceEnd out of bounds')\n\n  // Are we oob?\n  if (end > this.length)\n    end = this.length\n  if (target.length - target_start < end - start)\n    end = target.length - target_start + start\n\n  var len = end - start\n\n  if (len < 100 || !Buffer._useTypedArrays) {\n    for (var i = 0; i < len; i++)\n      target[i + target_start] = this[i + start]\n  } else {\n    target._set(this.subarray(start, start + len), target_start)\n  }\n}\n\nfunction _base64Slice (buf, start, end) {\n  if (start === 0 && end === buf.length) {\n    return base64.fromByteArray(buf)\n  } else {\n    return base64.fromByteArray(buf.slice(start, end))\n  }\n}\n\nfunction _utf8Slice (buf, start, end) {\n  var res = ''\n  var tmp = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; i++) {\n    if (buf[i] <= 0x7F) {\n      res += decodeUtf8Char(tmp) + String.fromCharCode(buf[i])\n      tmp = ''\n    } else {\n      tmp += '%' + buf[i].toString(16)\n    }\n  }\n\n  return res + decodeUtf8Char(tmp)\n}\n\nfunction _asciiSlice (buf, start, end) {\n  var ret = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; i++)\n    ret += String.fromCharCode(buf[i])\n  return ret\n}\n\nfunction _binarySlice (buf, start, end) {\n  return _asciiSlice(buf, start, end)\n}\n\nfunction _hexSlice (buf, start, end) {\n  var len = buf.length\n\n  if (!start || start < 0) start = 0\n  if (!end || end < 0 || end > len) end = len\n\n  var out = ''\n  for (var i = start; i < end; i++) {\n    out += toHex(buf[i])\n  }\n  return out\n}\n\nfunction _utf16leSlice (buf, start, end) {\n  var bytes = buf.slice(start, end)\n  var res = ''\n  for (var i = 0; i < bytes.length; i += 2) {\n    res += String.fromCharCode(bytes[i] + bytes[i+1] * 256)\n  }\n  return res\n}\n\nBuffer.prototype.slice = function (start, end) {\n  var len = this.length\n  start = clamp(start, len, 0)\n  end = clamp(end, len, len)\n\n  if (Buffer._useTypedArrays) {\n    return Buffer._augment(this.subarray(start, end))\n  } else {\n    var sliceLen = end - start\n    var newBuf = new Buffer(sliceLen, undefined, true)\n    for (var i = 0; i < sliceLen; i++) {\n      newBuf[i] = this[i + start]\n    }\n    return newBuf\n  }\n}\n\n// `get` will be removed in Node 0.13+\nBuffer.prototype.get = function (offset) {\n  console.log('.get() is deprecated. Access using array indexes instead.')\n  return this.readUInt8(offset)\n}\n\n// `set` will be removed in Node 0.13+\nBuffer.prototype.set = function (v, offset) {\n  console.log('.set() is deprecated. Access using array indexes instead.')\n  return this.writeUInt8(v, offset)\n}\n\nBuffer.prototype.readUInt8 = function (offset, noAssert) {\n  if (!noAssert) {\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset < this.length, 'Trying to read beyond buffer length')\n  }\n\n  if (offset >= this.length)\n    return\n\n  return this[offset]\n}\n\nfunction _readUInt16 (buf, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 1 < buf.length, 'Trying to read beyond buffer length')\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  var val\n  if (littleEndian) {\n    val = buf[offset]\n    if (offset + 1 < len)\n      val |= buf[offset + 1] << 8\n  } else {\n    val = buf[offset] << 8\n    if (offset + 1 < len)\n      val |= buf[offset + 1]\n  }\n  return val\n}\n\nBuffer.prototype.readUInt16LE = function (offset, noAssert) {\n  return _readUInt16(this, offset, true, noAssert)\n}\n\nBuffer.prototype.readUInt16BE = function (offset, noAssert) {\n  return _readUInt16(this, offset, false, noAssert)\n}\n\nfunction _readUInt32 (buf, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 3 < buf.length, 'Trying to read beyond buffer length')\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  var val\n  if (littleEndian) {\n    if (offset + 2 < len)\n      val = buf[offset + 2] << 16\n    if (offset + 1 < len)\n      val |= buf[offset + 1] << 8\n    val |= buf[offset]\n    if (offset + 3 < len)\n      val = val + (buf[offset + 3] << 24 >>> 0)\n  } else {\n    if (offset + 1 < len)\n      val = buf[offset + 1] << 16\n    if (offset + 2 < len)\n      val |= buf[offset + 2] << 8\n    if (offset + 3 < len)\n      val |= buf[offset + 3]\n    val = val + (buf[offset] << 24 >>> 0)\n  }\n  return val\n}\n\nBuffer.prototype.readUInt32LE = function (offset, noAssert) {\n  return _readUInt32(this, offset, true, noAssert)\n}\n\nBuffer.prototype.readUInt32BE = function (offset, noAssert) {\n  return _readUInt32(this, offset, false, noAssert)\n}\n\nBuffer.prototype.readInt8 = function (offset, noAssert) {\n  if (!noAssert) {\n    assert(offset !== undefined && offset !== null,\n        'missing offset')\n    assert(offset < this.length, 'Trying to read beyond buffer length')\n  }\n\n  if (offset >= this.length)\n    return\n\n  var neg = this[offset] & 0x80\n  if (neg)\n    return (0xff - this[offset] + 1) * -1\n  else\n    return this[offset]\n}\n\nfunction _readInt16 (buf, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 1 < buf.length, 'Trying to read beyond buffer length')\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  var val = _readUInt16(buf, offset, littleEndian, true)\n  var neg = val & 0x8000\n  if (neg)\n    return (0xffff - val + 1) * -1\n  else\n    return val\n}\n\nBuffer.prototype.readInt16LE = function (offset, noAssert) {\n  return _readInt16(this, offset, true, noAssert)\n}\n\nBuffer.prototype.readInt16BE = function (offset, noAssert) {\n  return _readInt16(this, offset, false, noAssert)\n}\n\nfunction _readInt32 (buf, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 3 < buf.length, 'Trying to read beyond buffer length')\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  var val = _readUInt32(buf, offset, littleEndian, true)\n  var neg = val & 0x80000000\n  if (neg)\n    return (0xffffffff - val + 1) * -1\n  else\n    return val\n}\n\nBuffer.prototype.readInt32LE = function (offset, noAssert) {\n  return _readInt32(this, offset, true, noAssert)\n}\n\nBuffer.prototype.readInt32BE = function (offset, noAssert) {\n  return _readInt32(this, offset, false, noAssert)\n}\n\nfunction _readFloat (buf, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset + 3 < buf.length, 'Trying to read beyond buffer length')\n  }\n\n  return ieee754.read(buf, offset, littleEndian, 23, 4)\n}\n\nBuffer.prototype.readFloatLE = function (offset, noAssert) {\n  return _readFloat(this, offset, true, noAssert)\n}\n\nBuffer.prototype.readFloatBE = function (offset, noAssert) {\n  return _readFloat(this, offset, false, noAssert)\n}\n\nfunction _readDouble (buf, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset + 7 < buf.length, 'Trying to read beyond buffer length')\n  }\n\n  return ieee754.read(buf, offset, littleEndian, 52, 8)\n}\n\nBuffer.prototype.readDoubleLE = function (offset, noAssert) {\n  return _readDouble(this, offset, true, noAssert)\n}\n\nBuffer.prototype.readDoubleBE = function (offset, noAssert) {\n  return _readDouble(this, offset, false, noAssert)\n}\n\nBuffer.prototype.writeUInt8 = function (value, offset, noAssert) {\n  if (!noAssert) {\n    assert(value !== undefined && value !== null, 'missing value')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset < this.length, 'trying to write beyond buffer length')\n    verifuint(value, 0xff)\n  }\n\n  if (offset >= this.length) return\n\n  this[offset] = value\n}\n\nfunction _writeUInt16 (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(value !== undefined && value !== null, 'missing value')\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 1 < buf.length, 'trying to write beyond buffer length')\n    verifuint(value, 0xffff)\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  for (var i = 0, j = Math.min(len - offset, 2); i < j; i++) {\n    buf[offset + i] =\n        (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>\n            (littleEndian ? i : 1 - i) * 8\n  }\n}\n\nBuffer.prototype.writeUInt16LE = function (value, offset, noAssert) {\n  _writeUInt16(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeUInt16BE = function (value, offset, noAssert) {\n  _writeUInt16(this, value, offset, false, noAssert)\n}\n\nfunction _writeUInt32 (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(value !== undefined && value !== null, 'missing value')\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 3 < buf.length, 'trying to write beyond buffer length')\n    verifuint(value, 0xffffffff)\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  for (var i = 0, j = Math.min(len - offset, 4); i < j; i++) {\n    buf[offset + i] =\n        (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff\n  }\n}\n\nBuffer.prototype.writeUInt32LE = function (value, offset, noAssert) {\n  _writeUInt32(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeUInt32BE = function (value, offset, noAssert) {\n  _writeUInt32(this, value, offset, false, noAssert)\n}\n\nBuffer.prototype.writeInt8 = function (value, offset, noAssert) {\n  if (!noAssert) {\n    assert(value !== undefined && value !== null, 'missing value')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset < this.length, 'Trying to write beyond buffer length')\n    verifsint(value, 0x7f, -0x80)\n  }\n\n  if (offset >= this.length)\n    return\n\n  if (value >= 0)\n    this.writeUInt8(value, offset, noAssert)\n  else\n    this.writeUInt8(0xff + value + 1, offset, noAssert)\n}\n\nfunction _writeInt16 (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(value !== undefined && value !== null, 'missing value')\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 1 < buf.length, 'Trying to write beyond buffer length')\n    verifsint(value, 0x7fff, -0x8000)\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  if (value >= 0)\n    _writeUInt16(buf, value, offset, littleEndian, noAssert)\n  else\n    _writeUInt16(buf, 0xffff + value + 1, offset, littleEndian, noAssert)\n}\n\nBuffer.prototype.writeInt16LE = function (value, offset, noAssert) {\n  _writeInt16(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeInt16BE = function (value, offset, noAssert) {\n  _writeInt16(this, value, offset, false, noAssert)\n}\n\nfunction _writeInt32 (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(value !== undefined && value !== null, 'missing value')\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 3 < buf.length, 'Trying to write beyond buffer length')\n    verifsint(value, 0x7fffffff, -0x80000000)\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  if (value >= 0)\n    _writeUInt32(buf, value, offset, littleEndian, noAssert)\n  else\n    _writeUInt32(buf, 0xffffffff + value + 1, offset, littleEndian, noAssert)\n}\n\nBuffer.prototype.writeInt32LE = function (value, offset, noAssert) {\n  _writeInt32(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeInt32BE = function (value, offset, noAssert) {\n  _writeInt32(this, value, offset, false, noAssert)\n}\n\nfunction _writeFloat (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(value !== undefined && value !== null, 'missing value')\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 3 < buf.length, 'Trying to write beyond buffer length')\n    verifIEEE754(value, 3.4028234663852886e+38, -3.4028234663852886e+38)\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  ieee754.write(buf, value, offset, littleEndian, 23, 4)\n}\n\nBuffer.prototype.writeFloatLE = function (value, offset, noAssert) {\n  _writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function (value, offset, noAssert) {\n  _writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction _writeDouble (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(value !== undefined && value !== null, 'missing value')\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 7 < buf.length,\n        'Trying to write beyond buffer length')\n    verifIEEE754(value, 1.7976931348623157E+308, -1.7976931348623157E+308)\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  ieee754.write(buf, value, offset, littleEndian, 52, 8)\n}\n\nBuffer.prototype.writeDoubleLE = function (value, offset, noAssert) {\n  _writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function (value, offset, noAssert) {\n  _writeDouble(this, value, offset, false, noAssert)\n}\n\n// fill(value, start=0, end=buffer.length)\nBuffer.prototype.fill = function (value, start, end) {\n  if (!value) value = 0\n  if (!start) start = 0\n  if (!end) end = this.length\n\n  if (typeof value === 'string') {\n    value = value.charCodeAt(0)\n  }\n\n  assert(typeof value === 'number' && !isNaN(value), 'value is not a number')\n  assert(end >= start, 'end < start')\n\n  // Fill 0 bytes; we're done\n  if (end === start) return\n  if (this.length === 0) return\n\n  assert(start >= 0 && start < this.length, 'start out of bounds')\n  assert(end >= 0 && end <= this.length, 'end out of bounds')\n\n  for (var i = start; i < end; i++) {\n    this[i] = value\n  }\n}\n\nBuffer.prototype.inspect = function () {\n  var out = []\n  var len = this.length\n  for (var i = 0; i < len; i++) {\n    out[i] = toHex(this[i])\n    if (i === exports.INSPECT_MAX_BYTES) {\n      out[i + 1] = '...'\n      break\n    }\n  }\n  return '<Buffer ' + out.join(' ') + '>'\n}\n\n/**\n * Creates a new `ArrayBuffer` with the *copied* memory of the buffer instance.\n * Added in Node 0.12. Only available in browsers that support ArrayBuffer.\n */\nBuffer.prototype.toArrayBuffer = function () {\n  if (typeof Uint8Array !== 'undefined') {\n    if (Buffer._useTypedArrays) {\n      return (new Buffer(this)).buffer\n    } else {\n      var buf = new Uint8Array(this.length)\n      for (var i = 0, len = buf.length; i < len; i += 1)\n        buf[i] = this[i]\n      return buf.buffer\n    }\n  } else {\n    throw new Error('Buffer.toArrayBuffer not supported in this browser')\n  }\n}\n\n// HELPER FUNCTIONS\n// ================\n\nfunction stringtrim (str) {\n  if (str.trim) return str.trim()\n  return str.replace(/^\\s+|\\s+$/g, '')\n}\n\nvar BP = Buffer.prototype\n\n/**\n * Augment a Uint8Array *instance* (not the Uint8Array class!) with Buffer methods\n */\nBuffer._augment = function (arr) {\n  arr._isBuffer = true\n\n  // save reference to original Uint8Array get/set methods before overwriting\n  arr._get = arr.get\n  arr._set = arr.set\n\n  // deprecated, will be removed in node 0.13+\n  arr.get = BP.get\n  arr.set = BP.set\n\n  arr.write = BP.write\n  arr.toString = BP.toString\n  arr.toLocaleString = BP.toString\n  arr.toJSON = BP.toJSON\n  arr.copy = BP.copy\n  arr.slice = BP.slice\n  arr.readUInt8 = BP.readUInt8\n  arr.readUInt16LE = BP.readUInt16LE\n  arr.readUInt16BE = BP.readUInt16BE\n  arr.readUInt32LE = BP.readUInt32LE\n  arr.readUInt32BE = BP.readUInt32BE\n  arr.readInt8 = BP.readInt8\n  arr.readInt16LE = BP.readInt16LE\n  arr.readInt16BE = BP.readInt16BE\n  arr.readInt32LE = BP.readInt32LE\n  arr.readInt32BE = BP.readInt32BE\n  arr.readFloatLE = BP.readFloatLE\n  arr.readFloatBE = BP.readFloatBE\n  arr.readDoubleLE = BP.readDoubleLE\n  arr.readDoubleBE = BP.readDoubleBE\n  arr.writeUInt8 = BP.writeUInt8\n  arr.writeUInt16LE = BP.writeUInt16LE\n  arr.writeUInt16BE = BP.writeUInt16BE\n  arr.writeUInt32LE = BP.writeUInt32LE\n  arr.writeUInt32BE = BP.writeUInt32BE\n  arr.writeInt8 = BP.writeInt8\n  arr.writeInt16LE = BP.writeInt16LE\n  arr.writeInt16BE = BP.writeInt16BE\n  arr.writeInt32LE = BP.writeInt32LE\n  arr.writeInt32BE = BP.writeInt32BE\n  arr.writeFloatLE = BP.writeFloatLE\n  arr.writeFloatBE = BP.writeFloatBE\n  arr.writeDoubleLE = BP.writeDoubleLE\n  arr.writeDoubleBE = BP.writeDoubleBE\n  arr.fill = BP.fill\n  arr.inspect = BP.inspect\n  arr.toArrayBuffer = BP.toArrayBuffer\n\n  return arr\n}\n\n// slice(start, end)\nfunction clamp (index, len, defaultValue) {\n  if (typeof index !== 'number') return defaultValue\n  index = ~~index;  // Coerce to integer.\n  if (index >= len) return len\n  if (index >= 0) return index\n  index += len\n  if (index >= 0) return index\n  return 0\n}\n\nfunction coerce (length) {\n  // Coerce length to a number (possibly NaN), round up\n  // in case it's fractional (e.g. 123.456) then do a\n  // double negate to coerce a NaN to 0. Easy, right?\n  length = ~~Math.ceil(+length)\n  return length < 0 ? 0 : length\n}\n\nfunction isArray (subject) {\n  return (Array.isArray || function (subject) {\n    return Object.prototype.toString.call(subject) === '[object Array]'\n  })(subject)\n}\n\nfunction isArrayish (subject) {\n  return isArray(subject) || Buffer.isBuffer(subject) ||\n      subject && typeof subject === 'object' &&\n      typeof subject.length === 'number'\n}\n\nfunction toHex (n) {\n  if (n < 16) return '0' + n.toString(16)\n  return n.toString(16)\n}\n\nfunction utf8ToBytes (str) {\n  var byteArray = []\n  for (var i = 0; i < str.length; i++) {\n    var b = str.charCodeAt(i)\n    if (b <= 0x7F)\n      byteArray.push(str.charCodeAt(i))\n    else {\n      var start = i\n      if (b >= 0xD800 && b <= 0xDFFF) i++\n      var h = encodeURIComponent(str.slice(start, i+1)).substr(1).split('%')\n      for (var j = 0; j < h.length; j++)\n        byteArray.push(parseInt(h[j], 16))\n    }\n  }\n  return byteArray\n}\n\nfunction asciiToBytes (str) {\n  var byteArray = []\n  for (var i = 0; i < str.length; i++) {\n    // Node's code seems to be doing this and not & 0x7F..\n    byteArray.push(str.charCodeAt(i) & 0xFF)\n  }\n  return byteArray\n}\n\nfunction utf16leToBytes (str) {\n  var c, hi, lo\n  var byteArray = []\n  for (var i = 0; i < str.length; i++) {\n    c = str.charCodeAt(i)\n    hi = c >> 8\n    lo = c % 256\n    byteArray.push(lo)\n    byteArray.push(hi)\n  }\n\n  return byteArray\n}\n\nfunction base64ToBytes (str) {\n  return base64.toByteArray(str)\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n  var pos\n  for (var i = 0; i < length; i++) {\n    if ((i + offset >= dst.length) || (i >= src.length))\n      break\n    dst[i + offset] = src[i]\n  }\n  return i\n}\n\nfunction decodeUtf8Char (str) {\n  try {\n    return decodeURIComponent(str)\n  } catch (err) {\n    return String.fromCharCode(0xFFFD) // UTF 8 invalid char\n  }\n}\n\n/*\n * We have to make sure that the value is a valid integer. This means that it\n * is non-negative. It has no fractional component and that it does not\n * exceed the maximum allowed value.\n */\nfunction verifuint (value, max) {\n  assert(typeof value === 'number', 'cannot write a non-number as a number')\n  assert(value >= 0, 'specified a negative value for writing an unsigned value')\n  assert(value <= max, 'value is larger than maximum value for type')\n  assert(Math.floor(value) === value, 'value has a fractional component')\n}\n\nfunction verifsint (value, max, min) {\n  assert(typeof value === 'number', 'cannot write a non-number as a number')\n  assert(value <= max, 'value larger than maximum allowed value')\n  assert(value >= min, 'value smaller than minimum allowed value')\n  assert(Math.floor(value) === value, 'value has a fractional component')\n}\n\nfunction verifIEEE754 (value, max, min) {\n  assert(typeof value === 'number', 'cannot write a non-number as a number')\n  assert(value <= max, 'value larger than maximum allowed value')\n  assert(value >= min, 'value smaller than minimum allowed value')\n}\n\nfunction assert (test, message) {\n  if (!test) throw new Error(message || 'Failed assertion')\n}\n","var lookup = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\n\n;(function (exports) {\n\t'use strict';\n\n  var Arr = (typeof Uint8Array !== 'undefined')\n    ? Uint8Array\n    : Array\n\n\tvar PLUS   = '+'.charCodeAt(0)\n\tvar SLASH  = '/'.charCodeAt(0)\n\tvar NUMBER = '0'.charCodeAt(0)\n\tvar LOWER  = 'a'.charCodeAt(0)\n\tvar UPPER  = 'A'.charCodeAt(0)\n\tvar PLUS_URL_SAFE = '-'.charCodeAt(0)\n\tvar SLASH_URL_SAFE = '_'.charCodeAt(0)\n\n\tfunction decode (elt) {\n\t\tvar code = elt.charCodeAt(0)\n\t\tif (code === PLUS ||\n\t\t    code === PLUS_URL_SAFE)\n\t\t\treturn 62 // '+'\n\t\tif (code === SLASH ||\n\t\t    code === SLASH_URL_SAFE)\n\t\t\treturn 63 // '/'\n\t\tif (code < NUMBER)\n\t\t\treturn -1 //no match\n\t\tif (code < NUMBER + 10)\n\t\t\treturn code - NUMBER + 26 + 26\n\t\tif (code < UPPER + 26)\n\t\t\treturn code - UPPER\n\t\tif (code < LOWER + 26)\n\t\t\treturn code - LOWER + 26\n\t}\n\n\tfunction b64ToByteArray (b64) {\n\t\tvar i, j, l, tmp, placeHolders, arr\n\n\t\tif (b64.length % 4 > 0) {\n\t\t\tthrow new Error('Invalid string. Length must be a multiple of 4')\n\t\t}\n\n\t\t// the number of equal signs (place holders)\n\t\t// if there are two placeholders, than the two characters before it\n\t\t// represent one byte\n\t\t// if there is only one, then the three characters before it represent 2 bytes\n\t\t// this is just a cheap hack to not do indexOf twice\n\t\tvar len = b64.length\n\t\tplaceHolders = '=' === b64.charAt(len - 2) ? 2 : '=' === b64.charAt(len - 1) ? 1 : 0\n\n\t\t// base64 is 4/3 + up to two characters of the original data\n\t\tarr = new Arr(b64.length * 3 / 4 - placeHolders)\n\n\t\t// if there are placeholders, only get up to the last complete 4 chars\n\t\tl = placeHolders > 0 ? b64.length - 4 : b64.length\n\n\t\tvar L = 0\n\n\t\tfunction push (v) {\n\t\t\tarr[L++] = v\n\t\t}\n\n\t\tfor (i = 0, j = 0; i < l; i += 4, j += 3) {\n\t\t\ttmp = (decode(b64.charAt(i)) << 18) | (decode(b64.charAt(i + 1)) << 12) | (decode(b64.charAt(i + 2)) << 6) | decode(b64.charAt(i + 3))\n\t\t\tpush((tmp & 0xFF0000) >> 16)\n\t\t\tpush((tmp & 0xFF00) >> 8)\n\t\t\tpush(tmp & 0xFF)\n\t\t}\n\n\t\tif (placeHolders === 2) {\n\t\t\ttmp = (decode(b64.charAt(i)) << 2) | (decode(b64.charAt(i + 1)) >> 4)\n\t\t\tpush(tmp & 0xFF)\n\t\t} else if (placeHolders === 1) {\n\t\t\ttmp = (decode(b64.charAt(i)) << 10) | (decode(b64.charAt(i + 1)) << 4) | (decode(b64.charAt(i + 2)) >> 2)\n\t\t\tpush((tmp >> 8) & 0xFF)\n\t\t\tpush(tmp & 0xFF)\n\t\t}\n\n\t\treturn arr\n\t}\n\n\tfunction uint8ToBase64 (uint8) {\n\t\tvar i,\n\t\t\textraBytes = uint8.length % 3, // if we have 1 byte left, pad 2 bytes\n\t\t\toutput = \"\",\n\t\t\ttemp, length\n\n\t\tfunction encode (num) {\n\t\t\treturn lookup.charAt(num)\n\t\t}\n\n\t\tfunction tripletToBase64 (num) {\n\t\t\treturn encode(num >> 18 & 0x3F) + encode(num >> 12 & 0x3F) + encode(num >> 6 & 0x3F) + encode(num & 0x3F)\n\t\t}\n\n\t\t// go through the array every three bytes, we'll deal with trailing stuff later\n\t\tfor (i = 0, length = uint8.length - extraBytes; i < length; i += 3) {\n\t\t\ttemp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2])\n\t\t\toutput += tripletToBase64(temp)\n\t\t}\n\n\t\t// pad the end with zeros, but make sure to not forget the extra bytes\n\t\tswitch (extraBytes) {\n\t\t\tcase 1:\n\t\t\t\ttemp = uint8[uint8.length - 1]\n\t\t\t\toutput += encode(temp >> 2)\n\t\t\t\toutput += encode((temp << 4) & 0x3F)\n\t\t\t\toutput += '=='\n\t\t\t\tbreak\n\t\t\tcase 2:\n\t\t\t\ttemp = (uint8[uint8.length - 2] << 8) + (uint8[uint8.length - 1])\n\t\t\t\toutput += encode(temp >> 10)\n\t\t\t\toutput += encode((temp >> 4) & 0x3F)\n\t\t\t\toutput += encode((temp << 2) & 0x3F)\n\t\t\t\toutput += '='\n\t\t\t\tbreak\n\t\t}\n\n\t\treturn output\n\t}\n\n\texports.toByteArray = b64ToByteArray\n\texports.fromByteArray = uint8ToBase64\n}(typeof exports === 'undefined' ? (this.base64js = {}) : exports))\n","exports.read = function (buffer, offset, isLE, mLen, nBytes) {\n  var e, m,\n      eLen = nBytes * 8 - mLen - 1,\n      eMax = (1 << eLen) - 1,\n      eBias = eMax >> 1,\n      nBits = -7,\n      i = isLE ? (nBytes - 1) : 0,\n      d = isLE ? -1 : 1,\n      s = buffer[offset + i]\n\n  i += d\n\n  e = s & ((1 << (-nBits)) - 1)\n  s >>= (-nBits)\n  nBits += eLen\n  for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  m = e & ((1 << (-nBits)) - 1)\n  e >>= (-nBits)\n  nBits += mLen\n  for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  if (e === 0) {\n    e = 1 - eBias\n  } else if (e === eMax) {\n    return m ? NaN : ((s ? -1 : 1) * Infinity)\n  } else {\n    m = m + Math.pow(2, mLen)\n    e = e - eBias\n  }\n  return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n  var e, m, c,\n      eLen = nBytes * 8 - mLen - 1,\n      eMax = (1 << eLen) - 1,\n      eBias = eMax >> 1,\n      rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0),\n      i = isLE ? 0 : (nBytes - 1),\n      d = isLE ? 1 : -1,\n      s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n  value = Math.abs(value)\n\n  if (isNaN(value) || value === Infinity) {\n    m = isNaN(value) ? 1 : 0\n    e = eMax\n  } else {\n    e = Math.floor(Math.log(value) / Math.LN2)\n    if (value * (c = Math.pow(2, -e)) < 1) {\n      e--\n      c *= 2\n    }\n    if (e + eBias >= 1) {\n      value += rt / c\n    } else {\n      value += rt * Math.pow(2, 1 - eBias)\n    }\n    if (value * c >= 2) {\n      e++\n      c /= 2\n    }\n\n    if (e + eBias >= eMax) {\n      m = 0\n      e = eMax\n    } else if (e + eBias >= 1) {\n      m = (value * c - 1) * Math.pow(2, mLen)\n      e = e + eBias\n    } else {\n      m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n      e = 0\n    }\n  }\n\n  for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n  e = (e << mLen) | m\n  eLen += mLen\n  for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n  buffer[offset + i - d] |= s * 128\n}\n","var Buffer = require('buffer').Buffer;\nvar intSize = 4;\nvar zeroBuffer = new Buffer(intSize); zeroBuffer.fill(0);\nvar chrsz = 8;\n\nfunction toArray(buf, bigEndian) {\n  if ((buf.length % intSize) !== 0) {\n    var len = buf.length + (intSize - (buf.length % intSize));\n    buf = Buffer.concat([buf, zeroBuffer], len);\n  }\n\n  var arr = [];\n  var fn = bigEndian ? buf.readInt32BE : buf.readInt32LE;\n  for (var i = 0; i < buf.length; i += intSize) {\n    arr.push(fn.call(buf, i));\n  }\n  return arr;\n}\n\nfunction toBuffer(arr, size, bigEndian) {\n  var buf = new Buffer(size);\n  var fn = bigEndian ? buf.writeInt32BE : buf.writeInt32LE;\n  for (var i = 0; i < arr.length; i++) {\n    fn.call(buf, arr[i], i * 4, true);\n  }\n  return buf;\n}\n\nfunction hash(buf, fn, hashSize, bigEndian) {\n  if (!Buffer.isBuffer(buf)) buf = new Buffer(buf);\n  var arr = fn(toArray(buf, bigEndian), buf.length * chrsz);\n  return toBuffer(arr, hashSize, bigEndian);\n}\n\nmodule.exports = { hash: hash };\n","var Buffer = require('buffer').Buffer\nvar sha = require('./sha')\nvar sha256 = require('./sha256')\nvar rng = require('./rng')\nvar md5 = require('./md5')\n\nvar algorithms = {\n  sha1: sha,\n  sha256: sha256,\n  md5: md5\n}\n\nvar blocksize = 64\nvar zeroBuffer = new Buffer(blocksize); zeroBuffer.fill(0)\nfunction hmac(fn, key, data) {\n  if(!Buffer.isBuffer(key)) key = new Buffer(key)\n  if(!Buffer.isBuffer(data)) data = new Buffer(data)\n\n  if(key.length > blocksize) {\n    key = fn(key)\n  } else if(key.length < blocksize) {\n    key = Buffer.concat([key, zeroBuffer], blocksize)\n  }\n\n  var ipad = new Buffer(blocksize), opad = new Buffer(blocksize)\n  for(var i = 0; i < blocksize; i++) {\n    ipad[i] = key[i] ^ 0x36\n    opad[i] = key[i] ^ 0x5C\n  }\n\n  var hash = fn(Buffer.concat([ipad, data]))\n  return fn(Buffer.concat([opad, hash]))\n}\n\nfunction hash(alg, key) {\n  alg = alg || 'sha1'\n  var fn = algorithms[alg]\n  var bufs = []\n  var length = 0\n  if(!fn) error('algorithm:', alg, 'is not yet supported')\n  return {\n    update: function (data) {\n      if(!Buffer.isBuffer(data)) data = new Buffer(data)\n        \n      bufs.push(data)\n      length += data.length\n      return this\n    },\n    digest: function (enc) {\n      var buf = Buffer.concat(bufs)\n      var r = key ? hmac(fn, key, buf) : fn(buf)\n      bufs = null\n      return enc ? r.toString(enc) : r\n    }\n  }\n}\n\nfunction error () {\n  var m = [].slice.call(arguments).join(' ')\n  throw new Error([\n    m,\n    'we accept pull requests',\n    'http://github.com/dominictarr/crypto-browserify'\n    ].join('\\n'))\n}\n\nexports.createHash = function (alg) { return hash(alg) }\nexports.createHmac = function (alg, key) { return hash(alg, key) }\nexports.randomBytes = function(size, callback) {\n  if (callback && callback.call) {\n    try {\n      callback.call(this, undefined, new Buffer(rng(size)))\n    } catch (err) { callback(err) }\n  } else {\n    return new Buffer(rng(size))\n  }\n}\n\nfunction each(a, f) {\n  for(var i in a)\n    f(a[i], i)\n}\n\n// the least I can do is make error messages for the rest of the node.js/crypto api.\neach(['createCredentials'\n, 'createCipher'\n, 'createCipheriv'\n, 'createDecipher'\n, 'createDecipheriv'\n, 'createSign'\n, 'createVerify'\n, 'createDiffieHellman'\n, 'pbkdf2'], function (name) {\n  exports[name] = function () {\n    error('sorry,', name, 'is not implemented yet')\n  }\n})\n","/*\r\n * A JavaScript implementation of the RSA Data Security, Inc. MD5 Message\r\n * Digest Algorithm, as defined in RFC 1321.\r\n * Version 2.1 Copyright (C) Paul Johnston 1999 - 2002.\r\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\r\n * Distributed under the BSD License\r\n * See http://pajhome.org.uk/crypt/md5 for more info.\r\n */\r\n\r\nvar helpers = require('./helpers');\r\n\r\n/*\r\n * Perform a simple self-test to see if the VM is working\r\n */\r\nfunction md5_vm_test()\r\n{\r\n  return hex_md5(\"abc\") == \"900150983cd24fb0d6963f7d28e17f72\";\r\n}\r\n\r\n/*\r\n * Calculate the MD5 of an array of little-endian words, and a bit length\r\n */\r\nfunction core_md5(x, len)\r\n{\r\n  /* append padding */\r\n  x[len >> 5] |= 0x80 << ((len) % 32);\r\n  x[(((len + 64) >>> 9) << 4) + 14] = len;\r\n\r\n  var a =  1732584193;\r\n  var b = -271733879;\r\n  var c = -1732584194;\r\n  var d =  271733878;\r\n\r\n  for(var i = 0; i < x.length; i += 16)\r\n  {\r\n    var olda = a;\r\n    var oldb = b;\r\n    var oldc = c;\r\n    var oldd = d;\r\n\r\n    a = md5_ff(a, b, c, d, x[i+ 0], 7 , -680876936);\r\n    d = md5_ff(d, a, b, c, x[i+ 1], 12, -389564586);\r\n    c = md5_ff(c, d, a, b, x[i+ 2], 17,  606105819);\r\n    b = md5_ff(b, c, d, a, x[i+ 3], 22, -1044525330);\r\n    a = md5_ff(a, b, c, d, x[i+ 4], 7 , -176418897);\r\n    d = md5_ff(d, a, b, c, x[i+ 5], 12,  1200080426);\r\n    c = md5_ff(c, d, a, b, x[i+ 6], 17, -1473231341);\r\n    b = md5_ff(b, c, d, a, x[i+ 7], 22, -45705983);\r\n    a = md5_ff(a, b, c, d, x[i+ 8], 7 ,  1770035416);\r\n    d = md5_ff(d, a, b, c, x[i+ 9], 12, -1958414417);\r\n    c = md5_ff(c, d, a, b, x[i+10], 17, -42063);\r\n    b = md5_ff(b, c, d, a, x[i+11], 22, -1990404162);\r\n    a = md5_ff(a, b, c, d, x[i+12], 7 ,  1804603682);\r\n    d = md5_ff(d, a, b, c, x[i+13], 12, -40341101);\r\n    c = md5_ff(c, d, a, b, x[i+14], 17, -1502002290);\r\n    b = md5_ff(b, c, d, a, x[i+15], 22,  1236535329);\r\n\r\n    a = md5_gg(a, b, c, d, x[i+ 1], 5 , -165796510);\r\n    d = md5_gg(d, a, b, c, x[i+ 6], 9 , -1069501632);\r\n    c = md5_gg(c, d, a, b, x[i+11], 14,  643717713);\r\n    b = md5_gg(b, c, d, a, x[i+ 0], 20, -373897302);\r\n    a = md5_gg(a, b, c, d, x[i+ 5], 5 , -701558691);\r\n    d = md5_gg(d, a, b, c, x[i+10], 9 ,  38016083);\r\n    c = md5_gg(c, d, a, b, x[i+15], 14, -660478335);\r\n    b = md5_gg(b, c, d, a, x[i+ 4], 20, -405537848);\r\n    a = md5_gg(a, b, c, d, x[i+ 9], 5 ,  568446438);\r\n    d = md5_gg(d, a, b, c, x[i+14], 9 , -1019803690);\r\n    c = md5_gg(c, d, a, b, x[i+ 3], 14, -187363961);\r\n    b = md5_gg(b, c, d, a, x[i+ 8], 20,  1163531501);\r\n    a = md5_gg(a, b, c, d, x[i+13], 5 , -1444681467);\r\n    d = md5_gg(d, a, b, c, x[i+ 2], 9 , -51403784);\r\n    c = md5_gg(c, d, a, b, x[i+ 7], 14,  1735328473);\r\n    b = md5_gg(b, c, d, a, x[i+12], 20, -1926607734);\r\n\r\n    a = md5_hh(a, b, c, d, x[i+ 5], 4 , -378558);\r\n    d = md5_hh(d, a, b, c, x[i+ 8], 11, -2022574463);\r\n    c = md5_hh(c, d, a, b, x[i+11], 16,  1839030562);\r\n    b = md5_hh(b, c, d, a, x[i+14], 23, -35309556);\r\n    a = md5_hh(a, b, c, d, x[i+ 1], 4 , -1530992060);\r\n    d = md5_hh(d, a, b, c, x[i+ 4], 11,  1272893353);\r\n    c = md5_hh(c, d, a, b, x[i+ 7], 16, -155497632);\r\n    b = md5_hh(b, c, d, a, x[i+10], 23, -1094730640);\r\n    a = md5_hh(a, b, c, d, x[i+13], 4 ,  681279174);\r\n    d = md5_hh(d, a, b, c, x[i+ 0], 11, -358537222);\r\n    c = md5_hh(c, d, a, b, x[i+ 3], 16, -722521979);\r\n    b = md5_hh(b, c, d, a, x[i+ 6], 23,  76029189);\r\n    a = md5_hh(a, b, c, d, x[i+ 9], 4 , -640364487);\r\n    d = md5_hh(d, a, b, c, x[i+12], 11, -421815835);\r\n    c = md5_hh(c, d, a, b, x[i+15], 16,  530742520);\r\n    b = md5_hh(b, c, d, a, x[i+ 2], 23, -995338651);\r\n\r\n    a = md5_ii(a, b, c, d, x[i+ 0], 6 , -198630844);\r\n    d = md5_ii(d, a, b, c, x[i+ 7], 10,  1126891415);\r\n    c = md5_ii(c, d, a, b, x[i+14], 15, -1416354905);\r\n    b = md5_ii(b, c, d, a, x[i+ 5], 21, -57434055);\r\n    a = md5_ii(a, b, c, d, x[i+12], 6 ,  1700485571);\r\n    d = md5_ii(d, a, b, c, x[i+ 3], 10, -1894986606);\r\n    c = md5_ii(c, d, a, b, x[i+10], 15, -1051523);\r\n    b = md5_ii(b, c, d, a, x[i+ 1], 21, -2054922799);\r\n    a = md5_ii(a, b, c, d, x[i+ 8], 6 ,  1873313359);\r\n    d = md5_ii(d, a, b, c, x[i+15], 10, -30611744);\r\n    c = md5_ii(c, d, a, b, x[i+ 6], 15, -1560198380);\r\n    b = md5_ii(b, c, d, a, x[i+13], 21,  1309151649);\r\n    a = md5_ii(a, b, c, d, x[i+ 4], 6 , -145523070);\r\n    d = md5_ii(d, a, b, c, x[i+11], 10, -1120210379);\r\n    c = md5_ii(c, d, a, b, x[i+ 2], 15,  718787259);\r\n    b = md5_ii(b, c, d, a, x[i+ 9], 21, -343485551);\r\n\r\n    a = safe_add(a, olda);\r\n    b = safe_add(b, oldb);\r\n    c = safe_add(c, oldc);\r\n    d = safe_add(d, oldd);\r\n  }\r\n  return Array(a, b, c, d);\r\n\r\n}\r\n\r\n/*\r\n * These functions implement the four basic operations the algorithm uses.\r\n */\r\nfunction md5_cmn(q, a, b, x, s, t)\r\n{\r\n  return safe_add(bit_rol(safe_add(safe_add(a, q), safe_add(x, t)), s),b);\r\n}\r\nfunction md5_ff(a, b, c, d, x, s, t)\r\n{\r\n  return md5_cmn((b & c) | ((~b) & d), a, b, x, s, t);\r\n}\r\nfunction md5_gg(a, b, c, d, x, s, t)\r\n{\r\n  return md5_cmn((b & d) | (c & (~d)), a, b, x, s, t);\r\n}\r\nfunction md5_hh(a, b, c, d, x, s, t)\r\n{\r\n  return md5_cmn(b ^ c ^ d, a, b, x, s, t);\r\n}\r\nfunction md5_ii(a, b, c, d, x, s, t)\r\n{\r\n  return md5_cmn(c ^ (b | (~d)), a, b, x, s, t);\r\n}\r\n\r\n/*\r\n * Add integers, wrapping at 2^32. This uses 16-bit operations internally\r\n * to work around bugs in some JS interpreters.\r\n */\r\nfunction safe_add(x, y)\r\n{\r\n  var lsw = (x & 0xFFFF) + (y & 0xFFFF);\r\n  var msw = (x >> 16) + (y >> 16) + (lsw >> 16);\r\n  return (msw << 16) | (lsw & 0xFFFF);\r\n}\r\n\r\n/*\r\n * Bitwise rotate a 32-bit number to the left.\r\n */\r\nfunction bit_rol(num, cnt)\r\n{\r\n  return (num << cnt) | (num >>> (32 - cnt));\r\n}\r\n\r\nmodule.exports = function md5(buf) {\r\n  return helpers.hash(buf, core_md5, 16);\r\n};\r\n","// Original code adapted from Robert Kieffer.\n// details at https://github.com/broofa/node-uuid\n(function() {\n  var _global = this;\n\n  var mathRNG, whatwgRNG;\n\n  // NOTE: Math.random() does not guarantee \"cryptographic quality\"\n  mathRNG = function(size) {\n    var bytes = new Array(size);\n    var r;\n\n    for (var i = 0, r; i < size; i++) {\n      if ((i & 0x03) == 0) r = Math.random() * 0x100000000;\n      bytes[i] = r >>> ((i & 0x03) << 3) & 0xff;\n    }\n\n    return bytes;\n  }\n\n  if (_global.crypto && crypto.getRandomValues) {\n    whatwgRNG = function(size) {\n      var bytes = new Uint8Array(size);\n      crypto.getRandomValues(bytes);\n      return bytes;\n    }\n  }\n\n  module.exports = whatwgRNG || mathRNG;\n\n}())\n","/*\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-1, as defined\n * in FIPS PUB 180-1\n * Version 2.1a Copyright Paul Johnston 2000 - 2002.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n * Distributed under the BSD License\n * See http://pajhome.org.uk/crypt/md5 for details.\n */\n\nvar helpers = require('./helpers');\n\n/*\n * Calculate the SHA-1 of an array of big-endian words, and a bit length\n */\nfunction core_sha1(x, len)\n{\n  /* append padding */\n  x[len >> 5] |= 0x80 << (24 - len % 32);\n  x[((len + 64 >> 9) << 4) + 15] = len;\n\n  var w = Array(80);\n  var a =  1732584193;\n  var b = -271733879;\n  var c = -1732584194;\n  var d =  271733878;\n  var e = -1009589776;\n\n  for(var i = 0; i < x.length; i += 16)\n  {\n    var olda = a;\n    var oldb = b;\n    var oldc = c;\n    var oldd = d;\n    var olde = e;\n\n    for(var j = 0; j < 80; j++)\n    {\n      if(j < 16) w[j] = x[i + j];\n      else w[j] = rol(w[j-3] ^ w[j-8] ^ w[j-14] ^ w[j-16], 1);\n      var t = safe_add(safe_add(rol(a, 5), sha1_ft(j, b, c, d)),\n                       safe_add(safe_add(e, w[j]), sha1_kt(j)));\n      e = d;\n      d = c;\n      c = rol(b, 30);\n      b = a;\n      a = t;\n    }\n\n    a = safe_add(a, olda);\n    b = safe_add(b, oldb);\n    c = safe_add(c, oldc);\n    d = safe_add(d, oldd);\n    e = safe_add(e, olde);\n  }\n  return Array(a, b, c, d, e);\n\n}\n\n/*\n * Perform the appropriate triplet combination function for the current\n * iteration\n */\nfunction sha1_ft(t, b, c, d)\n{\n  if(t < 20) return (b & c) | ((~b) & d);\n  if(t < 40) return b ^ c ^ d;\n  if(t < 60) return (b & c) | (b & d) | (c & d);\n  return b ^ c ^ d;\n}\n\n/*\n * Determine the appropriate additive constant for the current iteration\n */\nfunction sha1_kt(t)\n{\n  return (t < 20) ?  1518500249 : (t < 40) ?  1859775393 :\n         (t < 60) ? -1894007588 : -899497514;\n}\n\n/*\n * Add integers, wrapping at 2^32. This uses 16-bit operations internally\n * to work around bugs in some JS interpreters.\n */\nfunction safe_add(x, y)\n{\n  var lsw = (x & 0xFFFF) + (y & 0xFFFF);\n  var msw = (x >> 16) + (y >> 16) + (lsw >> 16);\n  return (msw << 16) | (lsw & 0xFFFF);\n}\n\n/*\n * Bitwise rotate a 32-bit number to the left.\n */\nfunction rol(num, cnt)\n{\n  return (num << cnt) | (num >>> (32 - cnt));\n}\n\nmodule.exports = function sha1(buf) {\n  return helpers.hash(buf, core_sha1, 20, true);\n};\n","\n/**\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-256, as defined\n * in FIPS 180-2\n * Version 2.2-beta Copyright Angel Marin, Paul Johnston 2000 - 2009.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n *\n */\n\nvar helpers = require('./helpers');\n\nvar safe_add = function(x, y) {\n  var lsw = (x & 0xFFFF) + (y & 0xFFFF);\n  var msw = (x >> 16) + (y >> 16) + (lsw >> 16);\n  return (msw << 16) | (lsw & 0xFFFF);\n};\n\nvar S = function(X, n) {\n  return (X >>> n) | (X << (32 - n));\n};\n\nvar R = function(X, n) {\n  return (X >>> n);\n};\n\nvar Ch = function(x, y, z) {\n  return ((x & y) ^ ((~x) & z));\n};\n\nvar Maj = function(x, y, z) {\n  return ((x & y) ^ (x & z) ^ (y & z));\n};\n\nvar Sigma0256 = function(x) {\n  return (S(x, 2) ^ S(x, 13) ^ S(x, 22));\n};\n\nvar Sigma1256 = function(x) {\n  return (S(x, 6) ^ S(x, 11) ^ S(x, 25));\n};\n\nvar Gamma0256 = function(x) {\n  return (S(x, 7) ^ S(x, 18) ^ R(x, 3));\n};\n\nvar Gamma1256 = function(x) {\n  return (S(x, 17) ^ S(x, 19) ^ R(x, 10));\n};\n\nvar core_sha256 = function(m, l) {\n  var K = new Array(0x428A2F98,0x71374491,0xB5C0FBCF,0xE9B5DBA5,0x3956C25B,0x59F111F1,0x923F82A4,0xAB1C5ED5,0xD807AA98,0x12835B01,0x243185BE,0x550C7DC3,0x72BE5D74,0x80DEB1FE,0x9BDC06A7,0xC19BF174,0xE49B69C1,0xEFBE4786,0xFC19DC6,0x240CA1CC,0x2DE92C6F,0x4A7484AA,0x5CB0A9DC,0x76F988DA,0x983E5152,0xA831C66D,0xB00327C8,0xBF597FC7,0xC6E00BF3,0xD5A79147,0x6CA6351,0x14292967,0x27B70A85,0x2E1B2138,0x4D2C6DFC,0x53380D13,0x650A7354,0x766A0ABB,0x81C2C92E,0x92722C85,0xA2BFE8A1,0xA81A664B,0xC24B8B70,0xC76C51A3,0xD192E819,0xD6990624,0xF40E3585,0x106AA070,0x19A4C116,0x1E376C08,0x2748774C,0x34B0BCB5,0x391C0CB3,0x4ED8AA4A,0x5B9CCA4F,0x682E6FF3,0x748F82EE,0x78A5636F,0x84C87814,0x8CC70208,0x90BEFFFA,0xA4506CEB,0xBEF9A3F7,0xC67178F2);\n  var HASH = new Array(0x6A09E667, 0xBB67AE85, 0x3C6EF372, 0xA54FF53A, 0x510E527F, 0x9B05688C, 0x1F83D9AB, 0x5BE0CD19);\n    var W = new Array(64);\n    var a, b, c, d, e, f, g, h, i, j;\n    var T1, T2;\n  /* append padding */\n  m[l >> 5] |= 0x80 << (24 - l % 32);\n  m[((l + 64 >> 9) << 4) + 15] = l;\n  for (var i = 0; i < m.length; i += 16) {\n    a = HASH[0]; b = HASH[1]; c = HASH[2]; d = HASH[3]; e = HASH[4]; f = HASH[5]; g = HASH[6]; h = HASH[7];\n    for (var j = 0; j < 64; j++) {\n      if (j < 16) {\n        W[j] = m[j + i];\n      } else {\n        W[j] = safe_add(safe_add(safe_add(Gamma1256(W[j - 2]), W[j - 7]), Gamma0256(W[j - 15])), W[j - 16]);\n      }\n      T1 = safe_add(safe_add(safe_add(safe_add(h, Sigma1256(e)), Ch(e, f, g)), K[j]), W[j]);\n      T2 = safe_add(Sigma0256(a), Maj(a, b, c));\n      h = g; g = f; f = e; e = safe_add(d, T1); d = c; c = b; b = a; a = safe_add(T1, T2);\n    }\n    HASH[0] = safe_add(a, HASH[0]); HASH[1] = safe_add(b, HASH[1]); HASH[2] = safe_add(c, HASH[2]); HASH[3] = safe_add(d, HASH[3]);\n    HASH[4] = safe_add(e, HASH[4]); HASH[5] = safe_add(f, HASH[5]); HASH[6] = safe_add(g, HASH[6]); HASH[7] = safe_add(h, HASH[7]);\n  }\n  return HASH;\n};\n\nmodule.exports = function sha256(buf) {\n  return helpers.hash(buf, core_sha256, 32, true);\n};\n","if (typeof Object.create === 'function') {\n  // implementation from standard node.js 'util' module\n  module.exports = function inherits(ctor, superCtor) {\n    ctor.super_ = superCtor\n    ctor.prototype = Object.create(superCtor.prototype, {\n      constructor: {\n        value: ctor,\n        enumerable: false,\n        writable: true,\n        configurable: true\n      }\n    });\n  };\n} else {\n  // old school shim for old browsers\n  module.exports = function inherits(ctor, superCtor) {\n    ctor.super_ = superCtor\n    var TempCtor = function () {}\n    TempCtor.prototype = superCtor.prototype\n    ctor.prototype = new TempCtor()\n    ctor.prototype.constructor = ctor\n  }\n}\n","/* This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at http://mozilla.org/MPL/2.0/. */\n\nvar crypto = require('crypto');\n\nvar defineProperty = Object.defineProperty;\nfunction next() {\n  return \"@@symbol:\" + crypto.randomBytes(8).toString('hex');\n}\n\n\nfunction Symbol(desc) {\n  if (!(this instanceof Symbol)) {\n    return new Symbol(desc);\n  }\n  var _symbol = this._symbol = next();\n  defineProperty(this, '_desc', {\n    value: desc,\n    enumerable: false,\n    writable: false,\n    configurable: false\n  });\n  defineProperty(Object.prototype, _symbol, {\n    set: function(value) {\n      defineProperty(this, _symbol, {\n        value: value,\n        enumerable: false,\n        writable: true\n      });\n    }\n  });\n}\n\nSymbol.prototype.toString = function toString() {\n  return this._symbol;\n};\n\nvar globalSymbolRegistry = {};\nSymbol.for = function symbolFor(key) {\n  key = String(key);\n  return globalSymbolRegistry[key] || (globalSymbolRegistry[key] = Symbol(key));\n};\n\nSymbol.keyFor = function keyFor(sym) {\n  if (!(sym instanceof Symbol)) {\n    throw new TypeError(\"Symbol.keyFor requires a Symbol argument\");\n  }\n  for (var key in globalSymbolRegistry) {\n    if (globalSymbolRegistry[key] === sym) {\n      return key;\n    }\n  }\n  return undefined;\n};\n\nmodule.exports = this.Symbol || Symbol;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nmodule.exports = extend;\nfunction extend(origin, add) {\n  // Don't do anything if add isn't an object\n  if (!add || typeof add !== 'object') return origin;\n\n  var keys = Object.keys(add);\n  var i = keys.length;\n  while (i--) {\n    origin[keys[i]] = add[keys[i]];\n  }\n  return origin;\n}\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar GrammarDecl = require('./GrammarDecl');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction Builder() {}\n\nBuilder.prototype = {\n  newGrammar: function(name) {\n    return new GrammarDecl(name);\n  },\n\n  anything: function() {\n    return pexprs.anything;\n  },\n\n  end: function() {\n    return pexprs.end;\n  },\n\n  prim: function(x) {\n    return pexprs.makePrim(x);\n  },\n\n  param: function(index) {\n    return new pexprs.Param(index);\n  },\n\n  alt: function(/* term1, term1, ... */) {\n    var terms = [];\n    for (var idx = 0; idx < arguments.length; idx++) {\n      var arg = arguments[idx];\n      if (arg instanceof pexprs.Alt) {\n        terms = terms.concat(arg.terms);\n      } else {\n        terms.push(arg);\n      }\n    }\n    return terms.length === 1 ? terms[0] : new pexprs.Alt(terms);\n  },\n\n  seq: function(/* factor1, factor2, ... */) {\n    var factors = [];\n    for (var idx = 0; idx < arguments.length; idx++) {\n      var arg = arguments[idx];\n      if (arg instanceof pexprs.Seq) {\n        factors = factors.concat(arg.factors);\n      } else {\n        factors.push(arg);\n      }\n    }\n    return factors.length === 1 ? factors[0] : new pexprs.Seq(factors);\n  },\n\n  star: function(expr) {\n    return new pexprs.Star(expr);\n  },\n\n  plus: function(expr) {\n    return new pexprs.Plus(expr);\n  },\n\n  opt: function(expr) {\n    return new pexprs.Opt(expr);\n  },\n\n  not: function(expr) {\n    return new pexprs.Not(expr);\n  },\n\n  la: function(expr) {\n    return new pexprs.Lookahead(expr);\n  },\n\n  arr: function(expr) {\n    return new pexprs.Arr(expr);\n  },\n\n  str: function(expr) {\n    return new pexprs.Str(expr);\n  },\n\n  obj: function(properties, isLenient) {\n    return new pexprs.Obj(properties, !!isLenient);\n  },\n\n  app: function(ruleName, optParams) {\n    return new pexprs.Apply(ruleName, optParams);\n  }\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Builder;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar InputStream = require('./InputStream');\nvar Interval = require('./Interval');\nvar MatchResult = require('./MatchResult');\nvar Semantics = require('./Semantics');\nvar State = require('./State');\nvar common = require('./common');\nvar errors = require('./errors');\nvar nodes = require('./nodes');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction Grammar(name, superGrammar, ruleDict, optDefaultStartRule) {\n  this.name = name;\n  this.superGrammar = superGrammar;\n  this.ruleDict = ruleDict;\n  if (optDefaultStartRule) {\n    if (!(optDefaultStartRule in ruleDict)) {\n      throw new Error(\"Invalid start rule: '\" + optDefaultStartRule +\n                      \"' is not a rule in grammar '\" + name + \"'\");\n    }\n    this.defaultStartRule = optDefaultStartRule;\n  }\n  this.constructors = this.ctors = this.createConstructors();\n}\n\nGrammar.prototype = {\n  construct: function(ruleName, children) {\n    var body = this.ruleDict[ruleName];\n    if (!body || !body.check(this, children) || children.length !== body.getArity()) {\n      throw new errors.InvalidConstructorCall(this, ruleName, children);\n    }\n    var interval = new Interval(InputStream.newFor(children), 0, children.length);\n    return new nodes.Node(this, ruleName, children, interval);\n  },\n\n  createConstructors: function() {\n    var self = this;\n    var constructors = {};\n\n    function makeConstructor(ruleName) {\n      return function(/* val1, val2, ... */) {\n        return self.construct(ruleName, Array.prototype.slice.call(arguments));\n      };\n    }\n\n    for (var ruleName in this.ruleDict) {\n      // We want *all* properties, not just own properties, because of\n      // supergrammars.\n      constructors[ruleName] = makeConstructor(ruleName);\n    }\n    return constructors;\n  },\n\n  // Return true if the grammar is a built-in grammar, otherwise false.\n  // NOTE: This might give an unexpected result if called before BuiltInRules is defined!\n  isBuiltIn: function() {\n    return this === Grammar.ProtoBuiltInRules || this === Grammar.BuiltInRules;\n  },\n\n  match: function(obj, optStartRule) {\n    var startRule = optStartRule || this.defaultStartRule;\n    if (!startRule) {\n      throw new Error('Missing start rule argument -- the grammar has no default start rule.');\n    }\n    var state = this._match(obj, startRule, false);\n    return MatchResult.newFor(state);\n  },\n\n  _match: function(obj, startRule, tracingEnabled) {\n    var inputStream = InputStream.newFor(typeof obj === 'string' ? obj : [obj]);\n    var state = new State(this, inputStream, startRule, tracingEnabled);\n    var succeeded = new pexprs.Apply(startRule).eval(state);\n    if (succeeded) {\n      // Link every CSTNode to its parent.\n      var stack = [undefined];\n      var helpers = this.semantics().addOperation('setParents', {\n        _terminal: function() {\n          this._node.parent = stack[stack.length - 1];\n        },\n        _default: function(children) {\n          stack.push(this._node);\n          children.forEach(function(child) { child.setParents(); });\n          stack.pop();\n          this._node.parent = stack[stack.length - 1];\n        }\n      });\n      helpers(MatchResult.newFor(state)).setParents();\n    }\n    return state;\n  },\n\n  trace: function(obj, optStartRule) {\n    var startRule = optStartRule || this.defaultStartRule;\n    if (!startRule) {\n      throw new Error('Missing start rule argument -- the grammar has no default start rule.');\n    }\n    var state = this._match(obj, startRule, true);\n\n    var rootTrace = state.trace[0];\n    rootTrace.state = state;\n    rootTrace.result = MatchResult.newFor(state);\n    return rootTrace;\n  },\n\n  semantics: function() {\n    return Semantics.createSemantics(this);\n  },\n\n  extendSemantics: function(superSemantics) {\n    return Semantics.createSemantics(this, superSemantics._getSemantics());\n  },\n\n  // Check that every key in `actionDict` corresponds to a semantic action, and that it maps to\n  // a function of the correct arity. If not, throw an exception.\n  _checkTopDownActionDict: function(what, name, actionDict) {\n    function isSpecialAction(name) {\n      return name === '_terminal' || name === '_default';\n    }\n\n    var problems = [];\n    for (var k in actionDict) {\n      var v = actionDict[k];\n      if (!isSpecialAction(k) && !(k in this.ruleDict)) {\n        problems.push(\"'\" + k + \"' is not a valid semantic action for '\" + this.name + \"'\");\n      } else if (typeof v !== 'function') {\n        problems.push(\n            \"'\" + k + \"' must be a function in an action dictionary for '\" + this.name + \"'\");\n      } else {\n        var actual = v.length;\n        var expected = this._topDownActionArity(k);\n        if (actual !== expected) {\n          problems.push(\n              \"Semantic action '\" + k + \"' has the wrong arity: \" +\n              'expected ' + expected + ', got ' + actual);\n        }\n      }\n    }\n    if (problems.length > 0) {\n      var prettyProblems = problems.map(function(problem) { return '- ' + problem; });\n      var error = new Error(\n          \"Found errors in the action dictionary of the '\" + name + \"' \" + what + ':\\n' +\n          prettyProblems.join('\\n'));\n      error.problems = problems;\n      throw error;\n    }\n  },\n\n  // Return the expected arity for a semantic action named `actionName`, which\n  // is either a rule name or a special action name like '_default'.\n  _topDownActionArity: function(actionName) {\n    if (actionName === '_default') {\n      return 1;\n    } else if (actionName === '_terminal') {\n      return 0;\n    }\n    return this.ruleDict[actionName].getArity();\n  },\n\n  _inheritsFrom: function(grammar) {\n    var g = this.superGrammar;\n    while (g) {\n      if (g === grammar) {\n        return true;\n      }\n      g = g.superGrammar;\n    }\n    return false;\n  },\n\n  toRecipe: function(optVarName) {\n    if (this.isBuiltIn()) {\n      throw new Error(\n          'Why would anyone want to generate a recipe for the ' + this.name + ' grammar?!?!');\n    }\n\n    var sb = new common.StringBuffer();\n    if (optVarName) {\n      sb.append('var ' + optVarName + ' = ');\n    }\n    sb.append('(function() {\\n');\n\n    // Include the supergrammar in the recipe if it's not a built-in grammar.\n    var superGrammarDecl = '';\n    if (!this.superGrammar.isBuiltIn()) {\n      sb.append(this.superGrammar.toRecipe('buildSuperGrammar'));\n      superGrammarDecl = '    .withSuperGrammar(buildSuperGrammar.call(this))\\n';\n    }\n    sb.append('  return new this.newGrammar(' + common.toStringLiteral(this.name) + ')\\n');\n    sb.append(superGrammarDecl);\n\n    if (this.defaultStartRule) {\n      sb.append(\"    .withDefaultStartRule('\" + this.defaultStartRule + \"')\\n\");\n    }\n\n    var self = this;\n    Object.keys(this.ruleDict).forEach(function(ruleName) {\n      var body = self.ruleDict[ruleName];\n      sb.append('    .');\n      if (self.superGrammar.ruleDict[ruleName]) {\n        sb.append(body instanceof pexprs.Extend ? 'extend' : 'override');\n      } else {\n        sb.append('define');\n      }\n      var formals = '[' + body.formals.map(common.toStringLiteral).join(', ') + ']';\n      sb.append('(' + common.toStringLiteral(ruleName) + ', ' + formals + ', ');\n      body.outputRecipe(sb, body.formals);\n      if (body.description) {\n        sb.append(', ' + common.toStringLiteral(body.description));\n      }\n      sb.append(')\\n');\n    });\n    sb.append('    .build();\\n});\\n');\n    return sb.contents();\n  },\n\n  // TODO: Come up with better names for these methods.\n  // TODO: Write the analog of these methods for inherited attributes.\n  toOperationActionDictionaryTemplate: function() {\n    return this._toOperationOrAttributeActionDictionaryTemplate();\n  },\n  toAttributeActionDictionaryTemplate: function() {\n    return this._toOperationOrAttributeActionDictionaryTemplate();\n  },\n\n  _toOperationOrAttributeActionDictionaryTemplate: function() {\n    // TODO: add the super-grammar's templates at the right place, e.g., a case for AddExpr_plus\n    // should appear next to other cases of AddExpr.\n\n    var self = this;\n    var sb = new common.StringBuffer();\n    sb.append('{');\n\n    var first = true;\n    for (var ruleName in this.ruleDict) {\n      if (ruleName === 'spaces_') {\n        // This rule is not for the user, it's more of an implementation detail of syntactic rules.\n        continue;\n      }\n      var body = this.ruleDict[ruleName];\n      if (first) {\n        first = false;\n      } else {\n        sb.append(',');\n      }\n      sb.append('\\n');\n      sb.append('  ');\n      this.addSemanticActionTemplate(ruleName, body, sb);\n    }\n\n    sb.append('\\n}');\n    return sb.contents();\n  },\n\n  addSemanticActionTemplate: function(ruleName, body, sb) {\n    sb.append(ruleName);\n    sb.append(': function(');\n    var arity = this._topDownActionArity(ruleName);\n    sb.append(common.repeat('_', arity).join(', '));\n    sb.append(') {\\n');\n    sb.append('  }');\n  }\n};\n\n// The following grammar contains a few rules that couldn't be written  in \"userland\".\n// At the bottom of src/main.js, we create a sub-grammar of this grammar that's called\n// `BuiltInRules`. That grammar contains several convenience rules, e.g., `letter` and\n// `digit`, and is implicitly the super-grammar of any grammar whose super-grammar\n// isn't specified.\nGrammar.ProtoBuiltInRules = new Grammar('ProtoBuiltInRules', undefined, {\n  // The following rules can't be written in userland because they reference\n  // `anything` and `end` directly.\n  _: pexprs.anything.withFormals([]),\n  end: pexprs.end.withFormals([]),\n\n  // The following rule is part of the Ohm implementation. Its name ends with '_' to\n  // discourage programmers from invoking, extending, and overriding it.\n  spaces_: new pexprs.Star(new pexprs.Apply('space')).withFormals([]),\n\n  // The `space` rule must be defined here because it's referenced by `spaces_`.\n  space: pexprs.makePrim(/[\\s]/).withFormals([]).withDescription('a space')\n});\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Grammar;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Grammar = require('./Grammar');\nvar common = require('./common');\nvar errors = require('./errors');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Private Stuff\n// --------------------------------------------------------------------\n\n// Constructors\n\nfunction GrammarDecl(name) {\n  this.name = name;\n}\n\n// Helpers\n\nfunction onOhmError(doFn, onErrorFn) {\n  try {\n    doFn();\n  } catch (e) {\n    if (e instanceof errors.Error) {\n      onErrorFn(e);\n    } else {\n      throw e;\n    }\n  }\n}\n\nGrammarDecl.prototype.ensureSuperGrammar = function() {\n  if (!this.superGrammar) {\n    this.withSuperGrammar(\n        // TODO: The conditional expression below is an ugly hack. It's kind of ok because\n        // I doubt anyone will ever try to declare a grammar called `BuiltInRules`. Still,\n        // we should try to find a better way to do this.\n        this.name === 'BuiltInRules' ?\n            Grammar.ProtoBuiltInRules :\n            Grammar.BuiltInRules);\n  }\n  return this.superGrammar;\n};\n\nGrammarDecl.prototype.installOverriddenOrExtendedRule = function(name, formals, body) {\n  var duplicateParameterNames = common.getDuplicates(formals);\n  if (duplicateParameterNames.length > 0) {\n    throw new errors.DuplicateParameterNames(name, duplicateParameterNames);\n  }\n  var baseRule = this.ensureSuperGrammar().ruleDict[name];\n  if (formals.length !== baseRule.formals.length) {\n    throw new errors.WrongNumberOfParameters(name, baseRule.formals.length, formals.length);\n  }\n  return this.install(name, formals, baseRule.description, body);\n};\n\nGrammarDecl.prototype.install = function(name, formals, description, body) {\n  body = body.introduceParams(formals);\n  body.formals = formals;\n  body.description = description;\n  this.ruleDict[name] = body;\n  return this;\n};\n\n// Stuff that you should only do once\n\nGrammarDecl.prototype.withSuperGrammar = function(superGrammar) {\n  if (this.superGrammar) {\n    throw new Error('the super grammar of a GrammarDecl cannot be set more than once');\n  }\n  this.superGrammar = superGrammar;\n  this.ruleDict = Object.create(superGrammar.ruleDict);\n\n  // Grammars with an explicit supergrammar inherit a default start rule.\n  if (!superGrammar.isBuiltIn()) {\n    this.defaultStartRule = superGrammar.defaultStartRule;\n  }\n  return this;\n};\n\nGrammarDecl.prototype.withDefaultStartRule = function(ruleName) {\n  this.defaultStartRule = ruleName;\n  return this;\n};\n\n// Creates a Grammar instance, and if it passes the sanity checks, returns it.\nGrammarDecl.prototype.build = function() {\n  var grammar =\n      new Grammar(this.name, this.ensureSuperGrammar(), this.ruleDict, this.defaultStartRule);\n  // TODO: change the pexpr.prototype.assert... methods to make them add\n  // exceptions to an array that's provided as an arg. Then we'll be able to\n  // show more than one error of the same type at a time.\n  // TODO: include the offending pexpr in the errors, that way we can show\n  // the part of the source that caused it.\n  var grammarErrors = [];\n  var grammarHasInvalidApplications = false;\n  Object.keys(grammar.ruleDict).forEach(function(ruleName) {\n    var body = grammar.ruleDict[ruleName];\n    onOhmError(\n        function() { body.assertChoicesHaveUniformArity(ruleName); },\n        function(e) { grammarErrors.push(e); });\n    onOhmError(\n        function() { body.assertAllApplicationsAreValid(grammar); },\n        function(e) {\n          grammarErrors.push(e);\n          grammarHasInvalidApplications = true;\n        });\n  });\n  if (!grammarHasInvalidApplications) {\n    // The following check can only be done if the grammar has no invalid applications.\n    Object.keys(grammar.ruleDict).forEach(function(ruleName) {\n      var body = grammar.ruleDict[ruleName];\n      onOhmError(\n          function() { body.assertIteratedExprsAreNotNullable(grammar, ruleName); },\n          function(e) { grammarErrors.push(e); });\n    });\n  }\n  if (grammarErrors.length > 0) {\n    errors.throwErrors(grammarErrors);\n  }\n  return grammar;\n};\n\n// Rule declarations\n\nGrammarDecl.prototype.define = function(name, formals, body, optDescr) {\n  this.ensureSuperGrammar();\n  if (this.superGrammar.ruleDict[name]) {\n    throw new errors.DuplicateRuleDeclaration(name, this.name, this.superGrammar.name);\n  } else if (this.ruleDict[name]) {\n    throw new errors.DuplicateRuleDeclaration(name, this.name, this.name);\n  }\n  var duplicateParameterNames = common.getDuplicates(formals);\n  if (duplicateParameterNames.length > 0) {\n    throw new errors.DuplicateParameterNames(name, duplicateParameterNames);\n  }\n  return this.install(name, formals, optDescr, body);\n};\n\nGrammarDecl.prototype.override = function(name, formals, body) {\n  var baseRule = this.ensureSuperGrammar().ruleDict[name];\n  if (!baseRule) {\n    throw new errors.CannotOverrideUndeclaredRule(name, this.superGrammar.name);\n  }\n  this.installOverriddenOrExtendedRule(name, formals, body);\n  return this;\n};\n\nGrammarDecl.prototype.extend = function(name, formals, body) {\n  var baseRule = this.ensureSuperGrammar().ruleDict[name];\n  if (!baseRule) {\n    throw new errors.CannotExtendUndeclaredRule(name, this.superGrammar.name);\n  }\n  this.installOverriddenOrExtendedRule(\n      name, formals, new pexprs.Extend(this.superGrammar, name, body));\n  return this;\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = GrammarDecl;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar Interval = require('./Interval');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction InputStream() {\n  throw new Error('InputStream cannot be instantiated -- it\\'s abstract');\n}\n\nInputStream.newFor = function(obj) {\n  if (typeof obj === 'string') {\n    return new StringInputStream(obj);\n  } else if (Array.isArray(obj)) {\n    return new ListInputStream(obj);\n  } else if (obj instanceof InputStream) {\n    return obj;\n  } else {\n    throw new Error('cannot make input stream for ' + obj);\n  }\n};\n\nInputStream.prototype = {\n  init: function(source) {\n    this.source = source;\n    this.pos = 0;\n    this.posInfos = [];\n  },\n\n  atEnd: function() {\n    return this.pos === this.source.length;\n  },\n\n  next: function() {\n    if (this.atEnd()) {\n      return common.fail;\n    } else {\n      return this.source[this.pos++];\n    }\n  },\n\n  matchExactly: function(x) {\n    return this.next() === x ? true : common.fail;\n  },\n\n  sourceSlice: function(startIdx, endIdx) {\n    return this.source.slice(startIdx, endIdx);\n  },\n\n  intervalFrom: function(startIdx) {\n    return new Interval(this, startIdx, this.pos);\n  }\n};\n\nfunction StringInputStream(source) {\n  this.init(source);\n}\n\nStringInputStream.prototype = Object.create(InputStream.prototype, {\n  matchString: {\n    value: function(s) {\n      for (var idx = 0; idx < s.length; idx++) {\n        if (this.matchExactly(s[idx]) === common.fail) {\n          return common.fail;\n        }\n      }\n      return true;\n    }\n  },\n\n  matchRegExp: {\n    value: function(e) {\n      // IMPORTANT: e must be a non-global, one-character expression, e.g., /./ and /[0-9]/\n      var c = this.next();\n      return c !== common.fail && e.test(c) ? true : common.fail;\n    }\n  }\n});\n\nfunction ListInputStream(source) {\n  this.init(source);\n}\n\nListInputStream.prototype = Object.create(InputStream.prototype, {\n  matchString: {\n    value: function(s) {\n      return this.matchExactly(s);\n    }\n  },\n\n  matchRegExp: {\n    value: function(e) {\n      return this.matchExactly(e);\n    }\n  }\n});\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = InputStream;\n\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar errors = require('./errors');\nvar util = require('./util');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction Interval(inputStream, startIdx, endIdx) {\n  this.inputStream = inputStream;\n  this.startIdx = startIdx;\n  this.endIdx = endIdx;\n}\n\nInterval.coverage = function(/* interval1, interval2, ... */) {\n  var inputStream = arguments[0].inputStream;\n  var startIdx = arguments[0].startIdx;\n  var endIdx = arguments[0].endIdx;\n  for (var idx = 1; idx < arguments.length; idx++) {\n    var interval = arguments[idx];\n    if (interval.inputStream !== inputStream) {\n      throw new errors.IntervalSourcesDontMatch();\n    } else {\n      startIdx = Math.min(startIdx, arguments[idx].startIdx);\n      endIdx = Math.max(endIdx, arguments[idx].endIdx);\n    }\n  }\n  return new Interval(inputStream, startIdx, endIdx);\n};\n\nInterval.prototype = {\n  coverageWith: function(/* interval1, interval2, ... */) {\n    var intervals = Array.prototype.slice.call(arguments);\n    intervals.push(this);\n    return Interval.coverage.apply(undefined, intervals);\n  },\n\n  collapsedLeft: function() {\n    return new Interval(this.inputStream, this.startIdx, this.startIdx);\n  },\n\n  collapsedRight: function() {\n    return new Interval(this.inputStream, this.endIdx, this.endIdx);\n  },\n\n  getLineAndColumnMessage: function() {\n    return util.getLineAndColumnMessage(this.inputStream.source, this.startIdx);\n  },\n\n  // Returns a new Interval which contains the same contents as this one,\n  // but with whitespace trimmed from both ends. (This only makes sense when\n  // the input stream is a string.)\n  trimmed: function() {\n    var contents = this.contents;\n    var startIdx = this.startIdx + contents.match(/^\\s*/)[0].length;\n    var endIdx = this.endIdx - contents.match(/\\s*$/)[0].length;\n    return new Interval(this.inputStream, startIdx, endIdx);\n  }\n};\n\nObject.defineProperties(Interval.prototype, {\n  contents: {\n    get: function() {\n      if (this._contents === undefined) {\n        this._contents = this.inputStream.sourceSlice(this.startIdx, this.endIdx);\n      }\n      return this._contents;\n    },\n    enumerable: true\n  }\n});\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Interval;\n\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar inherits = require('inherits');\n\nvar common = require('./common');\nvar util = require('./util');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// Create a short error message for an error that occurred during matching.\nfunction getShortMatchErrorMessage(pos, source, detail) {\n  var errorInfo = util.getLineAndColumn(source, pos);\n  return 'Line ' + errorInfo.lineNum + ', col ' + errorInfo.colNum + ': ' + detail;\n}\n\n// ----------------- MatchFailure -----------------\n\nfunction MatchResult(state) {\n  this.state = state;\n  this._cst = state.bindings[0];\n}\n\nMatchResult.newFor = function(state) {\n  var succeeded = state.bindings.length === 1;\n  return succeeded ? new MatchResult(state) : new MatchFailure(state);\n};\n\nMatchResult.prototype.failed = function() {\n  return false;\n};\n\nMatchResult.prototype.succeeded = function() {\n  return !this.failed();\n};\n\n// ----------------- MatchFailure -----------------\n\nfunction MatchFailure(state) {\n  this.state = state;\n  common.defineLazyProperty(this, '_exprsAndStacks', function() {\n    return this.state.getFailures();\n  });\n  common.defineLazyProperty(this, 'message', function() {\n    var source = this.state.inputStream.source;\n    if (typeof source !== 'string') {\n      return 'match failed at position ' + this.getPos();\n    }\n\n    var detail = 'Expected ' + this.getExpectedText();\n    return util.getLineAndColumnMessage(source, this.getPos()) + detail;\n  });\n  common.defineLazyProperty(this, 'shortMessage', function() {\n    if (typeof this.state.inputStream.source !== 'string') {\n      return 'match failed at position ' + this.getPos();\n    }\n    var detail = 'expected ' + this.getExpectedText();\n    return getShortMatchErrorMessage(this.getPos(), this.state.inputStream.source, detail);\n  });\n}\ninherits(MatchFailure, MatchResult);\n\nMatchFailure.prototype.toString = function() {\n  return '[MatchFailure at position ' + this.getPos() + ']';\n};\n\nMatchFailure.prototype.failed = function() {\n  return true;\n};\n\nMatchFailure.prototype.getPos = function() {\n  return this.state.getFailuresPos();\n};\n\n// Return a string summarizing the expected contents of the input stream when\n// the match failure occurred.\nMatchFailure.prototype.getExpectedText = function() {\n  var sb = new common.StringBuffer();\n  var expected = this.getExpected();\n  for (var idx = 0; idx < expected.length; idx++) {\n    if (idx > 0) {\n      if (idx === expected.length - 1) {\n        sb.append((expected.length > 2 ? ', or ' : ' or '));\n      } else {\n        sb.append(', ');\n      }\n    }\n    sb.append(expected[idx]);\n  }\n  return sb.contents();\n};\n\n// Return an Array of unique strings representing the terminals or rules that\n// were expected to be matched.\nMatchFailure.prototype.getExpected = function() {\n  var expected = {};\n  var ruleDict = this.state.grammar.ruleDict;\n  this._exprsAndStacks.forEach(function(obj) {\n    expected[obj.expr.toExpected(ruleDict)] = true;\n  });\n  return Object.keys(expected);\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = MatchResult;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar extend = require('util-extend');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction Namespace() {\n}\nNamespace.prototype = Object.create(null);\n\nNamespace.asNamespace = function(objOrNamespace) {\n  if (objOrNamespace instanceof Namespace) {\n    return objOrNamespace;\n  }\n  return Namespace.createNamespace(objOrNamespace);\n};\n\n// Create a new namespace. If `optProps` is specified, all of its properties\n// will be copied to the new namespace.\nNamespace.createNamespace = function(optProps) {\n  return Namespace.extend(Namespace.prototype, optProps);\n};\n\n// Create a new namespace which extends another namespace. If `optProps` is\n// specified, all of its properties will be copied to the new namespace.\nNamespace.extend = function(namespace, optProps) {\n  if (namespace !== Namespace.prototype && !(namespace instanceof Namespace)) {\n    throw new TypeError('not a Namespace object: ' + namespace);\n  }\n  var ns = Object.create(namespace, {\n    constructor: {\n      value: Namespace,\n      enumerable: false,\n      writable: true,\n      configurable: true\n    }\n  });\n  return extend(ns, optProps);\n};\n\n// TODO: Should this be a regular method?\nNamespace.toString = function(ns) {\n  return Object.prototype.toString.call(ns);\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Namespace;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction PosInfo(globalApplicationStack) {\n  this.globalApplicationStack = globalApplicationStack;\n  this.applicationStack = [];\n  // Redundant (could be generated from applicationStack) but useful for performance reasons.\n  this.activeApplications = {};\n  this.memo = {};\n}\n\nPosInfo.prototype = {\n  isActive: function(application) {\n    return this.activeApplications[application.toMemoKey()];\n  },\n\n  enter: function(application) {\n    this.globalApplicationStack.push(application);\n    this.applicationStack.push(application);\n    this.activeApplications[application.toMemoKey()] = true;\n  },\n\n  exit: function() {\n    var application = this.globalApplicationStack.pop();\n    this.applicationStack.pop();\n    this.activeApplications[application.toMemoKey()] = false;\n  },\n\n  shouldUseMemoizedResult: function(memoRec) {\n    var involvedApplications = memoRec.involvedApplications;\n    for (var memoKey in involvedApplications) {\n      if (involvedApplications[memoKey] && this.activeApplications[memoKey]) {\n        return false;\n      }\n    }\n    return true;\n  },\n\n  getCurrentLeftRecursion: function() {\n    if (this.leftRecursionStack) {\n      return this.leftRecursionStack[this.leftRecursionStack.length - 1];\n    }\n  },\n\n  startLeftRecursion: function(application) {\n    if (!this.leftRecursionStack) {\n      this.leftRecursionStack = [];\n    }\n    this.leftRecursionStack.push({\n        memoKey: application.toMemoKey(),\n        value: false,\n        pos: -1,\n        involvedApplications: {}});\n    this.updateInvolvedApplications();\n  },\n\n  endLeftRecursion: function(application) {\n    this.leftRecursionStack.pop();\n  },\n\n  updateInvolvedApplications: function() {\n    var currentLeftRecursion = this.getCurrentLeftRecursion();\n    var involvedApplications = currentLeftRecursion.involvedApplications;\n    var lrApplicationMemoKey = currentLeftRecursion.memoKey;\n    var idx = this.applicationStack.length - 1;\n    while (true) {\n      var memoKey = this.applicationStack[idx--].toMemoKey();\n      if (memoKey === lrApplicationMemoKey) {\n        break;\n      }\n      involvedApplications[memoKey] = true;\n    }\n  }\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = PosInfo;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Symbol = require('symbol');  // eslint-disable-line no-undef\nvar inherits = require('inherits');\n\nvar MatchResult = require('./MatchResult');\nvar common = require('./common');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// ----------------- Wrappers -----------------\n\n// Wrappers decorate CST nodes with all of the functionality (i.e., operations and attributes)\n// provided by a Semantics (see below). `Wrapper` is the abstract superclass of all wrappers. A\n// `Wrapper` must have `_node` and `_semantics` instance variables, which refer to the CST node and\n// Semantics (resp.) for which it was created, and a `_childWrappers` instance variable which is\n// used to cache the wrapper instances that are created for its child nodes. Setting these instance\n// variables is the responsibility of the constructor of each Semantics-specific subclass of\n// `Wrapper`.\nfunction Wrapper() {}\n\nWrapper.prototype.toString = function() {\n  return '[semantics wrapper for ' + this._node.grammar.name + ']';\n};\n\n// Returns the wrapper of the specified child node. Child wrappers are created lazily and cached in\n// the parent wrapper's `_childWrappers` instance variable.\nWrapper.prototype.child = function(idx) {\n  if (!(0 <= idx && idx < this._node.numChildren())) {\n    // TODO: Consider throwing an exception here.\n    return undefined;\n  }\n  var childWrapper = this._childWrappers[idx];\n  if (!childWrapper) {\n    childWrapper = this._childWrappers[idx] = this._semantics.wrap(this._node.childAt(idx));\n  }\n  return childWrapper;\n};\n\n// Returns an array containing the wrappers of all of the children of the node associated with this\n// wrapper.\nWrapper.prototype._children = function() {\n  // Force the creation of all child wrappers\n  for (var idx = 0; idx < this._node.numChildren(); idx++) {\n    this.child(idx);\n  }\n  return this._childWrappers;\n};\n\n// Returns the wrapper of the first child node. Throws an exception if the node associated with this\n// wrapper doesn't have exactly one child.\nWrapper.prototype._onlyChild = function() {\n  if (this._node.numChildren() !== 1) {\n    throw new Error(\n        'cannot get only child of a node of type ' + this.ctorName() +\n        ' (it has ' + this._node.numChildren() + ' children)');\n  } else {\n    return this.child(0);\n  }\n};\n\n// Returns `true` if the CST node associated with this wrapper corresponds to an iteration\n// expression, i.e., a Kleene-*, Kleene-+, or an optional. Returns `false` otherwise.\nWrapper.prototype.isIteration = function() {\n  return this._node.ctorName === '_iter';\n};\n\n// Returns `true` if the CST node associated with this wrapper is a terminal node, `false`\n// otherwise.\nWrapper.prototype.isTerminal = function() {\n  return this._node.isTerminal();\n};\n\nObject.defineProperties(Wrapper.prototype, {\n  // Returns an array containing the children of this CST node.\n  children: {get: function() { return this._children(); }},\n\n  // Returns the name of grammar rule that created this CST node.\n  ctorName: {get: function() { return this._node.ctorName; }},\n\n  // Returns the interval consumed by the CST node associated with this wrapper.\n  interval: {get: function() { return this._node.interval; }},\n\n  // Returns the number of children of this CST node.\n  numChildren: {get: function() { return this._node.numChildren(); }},\n\n  // Returns the primitive value of this CST node, if it's a terminal node. Otherwise,\n  // throws an exception.\n  primitiveValue: {\n    get: function() {\n      if (this.isTerminal()) {\n        return this._node.primitiveValue;\n      }\n      throw new TypeError(\n          \"tried to access the 'primitiveValue' attribute of a non-terminal CST node\");\n    }\n  }\n});\n\n// ----------------- Semantics -----------------\n\n// A Semantics is a container for a family of Operations and Attributes for a given grammar.\n// Semantics enable modularity (different clients of a grammar can create their set of operations\n// and attributes in isolation) and extensibility even when operations and attributes are mutually-\n// recursive. This constructor should not be called directly except from\n// `Semantics.createSemantics`. The normal ways to create a Semantics, given a grammar 'g', are\n// `g.semantics()` and `g.extendSemantics(parentSemantics)`.\nfunction Semantics(grammar, optSuperSemantics) {\n  var self = this;\n  this.grammar = grammar;\n  this.checkedActionDicts = false;\n\n  // Constructor for wrapper instances, which are passed as the arguments to the semantic actions\n  // of an operation or attribute. Operations and attributes require double dispatch: the semantic\n  // action is chosen based on both the node's type and the semantics. Wrappers ensure that\n  // the `execute` method is called with the correct (most specific) semantics object as an\n  // argument.\n  this.Wrapper = function(node) {\n    self.checkActionDictsIfHaventAlready();\n    this._semantics = self;\n    this._node = node;\n    this._childWrappers = [];\n  };\n\n  if (optSuperSemantics) {\n    this.super = optSuperSemantics;\n    if (grammar !== this.super.grammar && !grammar._inheritsFrom(this.super.grammar)) {\n      throw new Error(\n          \"Cannot extend a semantics for grammar '\" + this.super.grammar.name +\n          \"' for use with grammar '\" + grammar.name + \"' (not a sub-grammar)\");\n    }\n    inherits(this.Wrapper, this.super.Wrapper);\n    this.operations = Object.create(this.super.operations);\n    this.attributes = Object.create(this.super.attributes);\n    this.attributeKeys = Object.create(null);\n\n    // Assign unique symbols for each of the attributes inherited from the super-semantics so that\n    // they are memoized independently.\n    for (var attributeName in this.attributes) {\n      this.attributeKeys[attributeName] = Symbol();\n    }\n  } else {\n    inherits(this.Wrapper, Wrapper);\n    this.operations = Object.create(null);\n    this.attributes = Object.create(null);\n    this.attributeKeys = Object.create(null);\n  }\n}\n\nSemantics.prototype.toString = function() {\n  return '[semantics for ' + this.grammar.name + ']';\n};\n\nSemantics.prototype.checkActionDictsIfHaventAlready = function() {\n  if (!this.checkedActionDicts) {\n    this.checkActionDicts();\n    this.checkedActionDicts = true;\n  }\n};\n\n// Checks that the action dictionaries for all operations and attributes in this semantics,\n// including the ones that were inherited from the super-semantics, agree with the grammar.\n// Throws an exception if one or more of them doesn't.\nSemantics.prototype.checkActionDicts = function() {\n  for (var name in this.operations) {\n    this.operations[name].checkActionDict(this.grammar);\n  }\n  for (name in this.attributes) {\n    this.attributes[name].checkActionDict(this.grammar);\n  }\n};\n\nSemantics.prototype.addOperationOrAttribute = function(type, name, actionDict) {\n  var typePlural = type + 's';\n  var Ctor = type === 'operation' ? Operation : Attribute;\n\n  this.assertNewName(name, type);\n  this[typePlural][name] = new Ctor(name, actionDict);\n\n  // The following check is not strictly necessary (it will happen later anyway) but it's better to\n  // catch errors early.\n  this[typePlural][name].checkActionDict(this.grammar);\n\n  function doIt() {\n    // Dispatch to most specific version of this operation / attribute -- it may have been\n    // overridden by a sub-semantics.\n    var thisThing = this._semantics[typePlural][name];\n    return thisThing.execute(this._semantics, this);\n  }\n\n  if (type === 'operation') {\n    this.Wrapper.prototype[name] = doIt;\n    this.Wrapper.prototype[name].toString = function() {\n      return '[' + name + ' operation]';\n    };\n  } else {\n    Object.defineProperty(this.Wrapper.prototype, name, {get: doIt});\n    this.attributeKeys[name] = Symbol();\n  }\n};\n\nSemantics.prototype.extendOperationOrAttribute = function(type, name, actionDict) {\n  var typePlural = type + 's';\n  var Ctor = type === 'operation' ? Operation : Attribute;\n\n  if (!(this.super && name in this.super[typePlural])) {\n    throw new Error('Cannot extend ' + type + \" '\" + name +\n        \"': did not inherit an \" + type + ' with that name');\n  }\n  if (Object.prototype.hasOwnProperty.call(this[typePlural], name)) {\n    throw new Error('Cannot extend ' + type + \" '\" + name + \"' again\");\n  }\n\n  // Create a new operation / attribute whose actionDict delegates to the super operation /\n  // attribute's actionDict, and which has all the keys from `inheritedActionDict`.\n  var inheritedActionDict = this[typePlural][name].actionDict;\n  var newActionDict = Object.create(inheritedActionDict);\n  Object.keys(actionDict).forEach(function(name) {\n    newActionDict[name] = actionDict[name];\n  });\n\n  this[typePlural][name] = new Ctor(name, newActionDict);\n\n  // The following check is not strictly necessary (it will happen later anyway) but it's better to\n  // catch errors early.\n  this[typePlural][name].checkActionDict(this.grammar);\n};\n\nSemantics.prototype.assertNewName = function(name, type) {\n  if (Wrapper.prototype.hasOwnProperty(name)) {\n    throw new Error(\n        'Cannot add ' + type + \" '\" + name + \"': that's a reserved name\");\n  }\n  if (name in this.operations) {\n    throw new Error(\n        'Cannot add ' + type + \" '\" + name + \"': an operation with that name already exists\");\n  }\n  if (name in this.attributes) {\n    throw new Error(\n        'Cannot add ' + type + \" '\" + name + \"': an attribute with that name already exists\");\n  }\n};\n\n// Returns a wrapper for the given CST `node` in this semantics.\nSemantics.prototype.wrap = function(node) {\n  return new this.Wrapper(node);\n};\n\n// Creates a new Semantics instance for `grammar`, inheriting operations and attributes from\n// `optSuperSemantics`, if it is specified. Returns a function that acts as a proxy for the new\n// Semantics instance. When that function is invoked with a CST node as an argument, it returns\n// a wrapper for that node which gives access to the operations and attributes provided by this\n// semantics.\nSemantics.createSemantics = function(grammar, optSuperSemantics) {\n  var s = new Semantics(grammar, optSuperSemantics);\n\n  // To enable clients to invoke a semantics like a function, return a function that acts as a proxy\n  // for `s`, which is the real `Semantics` instance.\n  var proxy = function ASemantics(matchResult) {\n    if (!(matchResult instanceof MatchResult)) {\n      throw new TypeError(\n          'Semantics expected a MatchResult, but got ' + common.unexpectedObjToString(matchResult));\n    }\n    if (!matchResult.succeeded()) {\n      throw new TypeError(\n          'cannot apply Semantics to ' + matchResult.toString());\n    }\n\n    var cst = matchResult._cst;\n    if (cst.grammar !== grammar) {\n      throw new Error(\n          \"Cannot use a CST node created by grammar '\" + cst.grammar.name +\n          \"' with a semantics for '\" + grammar.name + \"'\");\n    }\n    return s.wrap(cst);\n  };\n\n  // Forward public methods from the proxy to the semantics instance.\n  proxy.addOperation = function(name, actionDict) {\n    s.addOperationOrAttribute.call(s, 'operation', name, actionDict);\n    return proxy;\n  };\n  proxy.extendOperation = function(name, actionDict) {\n    s.extendOperationOrAttribute.call(s, 'operation', name, actionDict);\n    return proxy;\n  };\n  proxy.addAttribute = function(name, actionDict) {\n    s.addOperationOrAttribute.call(s, 'attribute', name, actionDict);\n    return proxy;\n  };\n  proxy.extendAttribute = function(name, actionDict) {\n    s.extendOperationOrAttribute.call(s, 'attribute', name, actionDict);\n    return proxy;\n  };\n\n  // Make the proxy's toString() work.\n  proxy.toString = s.toString.bind(s);\n\n  // Returns the semantics for the proxy.\n  proxy._getSemantics = function() {\n    return s;\n  };\n\n  return proxy;\n};\n\n// ----------------- Default semantic actions -----------------\n\nvar actions = {\n  getPrimitiveValue: function() {\n    return this.primitiveValue;\n  },\n  passThrough: function(childNode) {\n    throw new Error('BUG: ohm.actions.passThrough should never be called');\n  }\n};\n\nSemantics.actions = actions;\n\n// ----------------- Operation -----------------\n\n// An Operation represents a function to be applied to a concrete syntax tree (CST) -- it's very\n// similar to a Visitor (http://en.wikipedia.org/wiki/Visitor_pattern). An operation is executed by\n// recursively walking the CST, and at each node, invoking the matching semantic action from\n// `actionDict`. See `Operation.prototype.execute` for details of how a CST node's matching semantic\n// action is found.\nfunction Operation(name, actionDict) {\n  this.name = name;\n  this.actionDict = actionDict;\n}\n\nOperation.prototype.typeName = 'operation';\n\nOperation.prototype.checkActionDict = function(grammar) {\n  grammar._checkTopDownActionDict(this.typeName, this.name, this.actionDict);\n};\n\n// Execute this operation on the CST node associated with `nodeWrapper` in the context of the given\n// Semantics instance.\nOperation.prototype.execute = function(semantics, nodeWrapper) {\n  if (nodeWrapper.isIteration()) {\n    // This CST node corresponds to an iteration expression in the grammar (*, +, or ?), so we map\n    // this operation over all of its child nodes.\n    var results = [];\n    for (var idx = 0; idx < nodeWrapper._node.numChildren(); idx++) {\n      results.push(this.execute(semantics, nodeWrapper.child(idx)));\n    }\n    return results;\n  }\n\n  // Look for a semantic action whose name matches the node's constructor name, which is either the\n  // name of a rule in the grammar, or the special value '_terminal'.\n  var actionFn = this.actionDict[nodeWrapper._node.ctorName];\n  if (actionFn) {\n    return this.doAction(semantics, nodeWrapper, actionFn);\n  }\n\n  // The action dictionary does not contain a semantic action for this specific type of node, so\n  // invoke the '_default' semantic action if it exists (but only if this node is not a terminal).\n  var defaultActionFn = this.actionDict._default;\n  if (defaultActionFn && !nodeWrapper.isTerminal()) {\n    return this.doAction(semantics, nodeWrapper, defaultActionFn, true);\n  }\n\n  // The programmer hasn't written a semantic action for this type of node yet.\n  throw new Error(\n      'missing semantic action for ' + nodeWrapper._node.ctorName + ' in ' + this.name + ' ' +\n      this.typeName);\n};\n\n// Invoke `actionFn` on the CST node that corresponds to `nodeWrapper`, in the context of\n// `semantics`. If `optPassChildrenAsArray` is true, `actionFn` will be called with a single\n// argument, which is an array of wrappers. Otherwise, the number of arguments to `actionFn` will\n// be equal to the number of children in the CST node.\nOperation.prototype.doAction = function(semantics, nodeWrapper, actionFn, optPassChildrenAsArray) {\n  if (actionFn === actions.passThrough) {\n    return this.execute(semantics, nodeWrapper._onlyChild());\n  }\n  return optPassChildrenAsArray ?\n      actionFn.call(nodeWrapper, nodeWrapper._children()) :\n      actionFn.apply(nodeWrapper, nodeWrapper._children());\n};\n\n// ----------------- Attribute -----------------\n\n// Attributes are Operations whose results are memoized. This means that, for any given semantics,\n// the semantic action for a CST node will be invoked no more than once.\nfunction Attribute(name, actionDict) {\n  this.name = name;\n  this.actionDict = actionDict;\n}\ninherits(Attribute, Operation);\n\nAttribute.prototype.typeName = 'attribute';\n\nAttribute.prototype.execute = function(semantics, nodeWrapper) {\n  var node = nodeWrapper._node;\n  var key = semantics.attributeKeys[this.name];\n  if (!node.hasOwnProperty(key)) {\n    // The following is a super-send -- isn't JS beautiful? :/\n    node[key] = Operation.prototype.execute.call(this, semantics, nodeWrapper);\n  }\n  return node[key];\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Semantics;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar PosInfo = require('./PosInfo');\nvar Trace = require('./Trace');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction State(grammar, inputStream, startRule, tracingEnabled) {\n  this.grammar = grammar;\n  this.origInputStream = inputStream;\n  this.startRule = startRule;\n  this.tracingEnabled = tracingEnabled;\n  this.rightmostFailPos = -1;\n  this.init();\n}\n\nState.prototype = {\n  init: function(optFailuresArray) {\n    this.inputStreamStack = [];\n    this.posInfosStack = [];\n    this.pushInputStream(this.origInputStream);\n    this.applicationStack = [];\n    this.bindings = [];\n    this.failures = optFailuresArray;\n    this.ignoreFailuresCount = 0;\n    if (this.isTracing()) {\n      this.trace = [];\n    }\n  },\n\n  pushInputStream: function(inputStream) {\n    this.inputStreamStack.push(this.inputStream);\n    this.posInfosStack.push(this.posInfos);\n    this.inputStream = inputStream;\n    this.posInfos = [];\n  },\n\n  popInputStream: function() {\n    this.inputStream = this.inputStreamStack.pop();\n    this.posInfos = this.posInfosStack.pop();\n  },\n\n  getCurrentPosInfo: function() {\n    return this.getPosInfo(this.inputStream.pos);\n  },\n\n  getPosInfo: function(pos) {\n    var posInfo = this.posInfos[pos];\n    return posInfo || (this.posInfos[pos] = new PosInfo(this.applicationStack));\n  },\n\n  recordFailure: function(pos, expr) {\n    if (this.ignoreFailuresCount > 0) {\n      return;\n    }\n    if (pos < this.rightmostFailPos) {\n      // it would be useless to record this failure, so don't do it\n      return;\n    } else if (pos > this.rightmostFailPos) {\n      // new rightmost failure!\n      this.rightmostFailPos = pos;\n    }\n    if (!this.failures) {\n      // we're not really recording failures, so we're done\n      return;\n    }\n\n    // TODO: consider making this code more OO, e.g., add an ExprAndStacks class\n    // that supports an addStack(stack) method.\n    function addStack(stack, stacks) {\n      for (var idx = 0; idx < stacks.length; idx++) {\n        var otherStack = stacks[idx];\n        if (stack.length !== otherStack.length) {\n          continue;\n        }\n        for (var idx2 = 0; idx2 < stack.length; idx2++) {\n          if (stack[idx2] !== otherStack[idx2]) {\n            break;\n          }\n        }\n        if (idx2 === stack.length) {\n          // found it, no need to add\n          return;\n        }\n      }\n      stacks.push(stack);\n    }\n\n    // Another failure at right-most position -- record it if it wasn't already.\n    var stack = this.applicationStack.slice();\n    var exprsAndStacks = this.failures;\n    for (var idx = 0; idx < exprsAndStacks.length; idx++) {\n      var exprAndStacks = exprsAndStacks[idx];\n      if (exprAndStacks.expr === expr) {\n        addStack(stack, exprAndStacks.stacks);\n        return;\n      }\n    }\n    exprsAndStacks.push({expr: expr, stacks: [stack]});\n  },\n\n  ignoreFailures: function() {\n    this.ignoreFailuresCount++;\n  },\n\n  recordFailures: function() {\n    this.ignoreFailuresCount--;\n  },\n\n  getFailuresPos: function() {\n    return this.rightmostFailPos;\n  },\n\n  getFailures: function() {\n    if (!this.failures) {\n      // Rewind, then try to match the input again, recording failures.\n      this.init([]);\n      this.tracingEnabled = false;\n      var succeeded = new pexprs.Apply(this.startRule).eval(this);\n      if (succeeded) {\n        this.failures = [];\n      }\n    }\n    return this.failures;\n  },\n\n  // Returns the memoized trace entry for `pos` and `expr`, if one exists.\n  getMemoizedTraceEntry: function(pos, expr) {\n    var posInfo = this.posInfos[pos];\n    if (posInfo && expr.ruleName) {\n      var memoRec = posInfo.memo[expr.ruleName];\n      if (memoRec) {\n        return memoRec.traceEntry;\n      }\n    }\n    return null;\n  },\n\n  // Make a new trace entry, using the currently active trace array as the\n  // new entry's children.\n  getTraceEntry: function(pos, expr, result) {\n    var entry = this.getMemoizedTraceEntry(pos, expr);\n    if (!entry) {\n      entry = new Trace(this.inputStream, pos, expr, result, this.trace);\n    }\n    return entry;\n  },\n\n  isTracing: function() {\n    return this.tracingEnabled;\n  }\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = State;\n\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Interval = require('./Interval');\nvar common = require('./common');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// Unicode characters that are used in the `toString` output.\nvar BALLOT_X = '\\u2717';\nvar CHECK_MARK = '\\u2713';\nvar DOT_OPERATOR = '\\u22C5';\nvar RIGHTWARDS_DOUBLE_ARROW = '\\u21D2';\nvar SYMBOL_FOR_HORIZONTAL_TABULATION = '\\u2409';\nvar SYMBOL_FOR_LINE_FEED = '\\u240A';\nvar SYMBOL_FOR_CARRIAGE_RETURN = '\\u240D';\n\nfunction linkLeftRecursiveChildren(children) {\n  for (var i = 0; i < children.length; ++i) {\n    var child = children[i];\n    var nextChild = children[i + 1];\n\n    if (nextChild && child.expr === nextChild.expr) {\n      child.replacedBy = nextChild;\n    }\n  }\n}\n\nfunction spaces(n) {\n  return common.repeat(' ', n).join('');\n}\n\n// Return a string representation of a portion of `inputStream` at offset `pos`.\n// The result will contain exactly `len` characters.\nfunction getInputExcerpt(inputStream, pos, len) {\n  var excerpt = asEscapedString(inputStream.sourceSlice(pos, pos + len));\n\n  // Pad the output if necessary.\n  if (excerpt.length < len) {\n    return excerpt + common.repeat(' ', len - excerpt.length).join('');\n  }\n  return excerpt;\n}\n\nfunction asEscapedString(obj) {\n  if (typeof obj === 'string') {\n    // Replace non-printable characters with visible symbols.\n    return obj\n        .replace(/ /g, DOT_OPERATOR)\n        .replace(/\\t/g, SYMBOL_FOR_HORIZONTAL_TABULATION)\n        .replace(/\\n/g, SYMBOL_FOR_LINE_FEED)\n        .replace(/\\r/g, SYMBOL_FOR_CARRIAGE_RETURN);\n  }\n  return String(obj);\n}\n\n// ----------------- Trace -----------------\n\nfunction Trace(inputStream, pos, expr, ans, optChildren) {\n  this.children = optChildren || [];\n  this.expr = expr;\n  if (ans) {\n    this.interval = new Interval(inputStream, pos, inputStream.pos);\n  }\n  this.isLeftRecursive = false;\n  this.pos = pos;\n  this.inputStream = inputStream;\n  this.succeeded = !!ans;\n}\n\nObject.defineProperty(Trace.prototype, 'displayString', {\n  get: function() { return this.expr.toDisplayString(); }\n});\n\nTrace.prototype.setLeftRecursive = function(leftRecursive) {\n  this.isLeftRecursive = leftRecursive;\n  if (leftRecursive) {\n    linkLeftRecursiveChildren(this.children);\n  }\n};\n\n// Recursively traverse this trace node and all its descendents, calling a visitor function\n// for each node that is visited. If `vistorObjOrFn` is an object, then its 'enter' property\n// is a function to call before visiting the children of a node, and its 'exit' property is\n// a function to call afterwards. If `visitorObjOrFn` is a function, it represents the 'enter'\n// function.\n//\n// The functions are called with three arguments: the Trace node, its parent Trace, and a number\n// representing the depth of the node in the tree. (The root node has depth 0.) `optThisArg`, if\n// specified, is the value to use for `this` when executing the visitor functions.\nTrace.prototype.walk = function(visitorObjOrFn, optThisArg) {\n  var visitor = visitorObjOrFn;\n  if (typeof visitor === 'function') {\n    visitor = {enter: visitor};\n  }\n  return (function _walk(node, parent, depth) {\n    if (visitor.enter) {\n      visitor.enter.call(optThisArg, node, parent, depth);\n    }\n    node.children.forEach(function(c) {\n      if (c && ('walk' in c)) {\n        _walk(c, node, depth + 1);\n      }\n    });\n    if (visitor.exit) {\n      visitor.exit.call(optThisArg, node, parent, depth);\n    }\n  })(this, null, 0);\n};\n\n// Return a string representation of the trace.\n// Sample:\n//     12⋅+⋅2⋅*⋅3 ✓ exp ⇒  \"12\"\n//     12⋅+⋅2⋅*⋅3   ✓ addExp (LR) ⇒  \"12\"\n//     12⋅+⋅2⋅*⋅3       ✗ addExp_plus\nTrace.prototype.toString = function() {\n  var sb = new common.StringBuffer();\n  this.walk(function(node, parent, depth) {\n    var ctorName = node.expr.constructor.name;\n    if (ctorName === 'Alt') {\n      return;  // Don't print anything for Alt nodes.\n    }\n    sb.append(getInputExcerpt(node.inputStream, node.pos, 10) + spaces(depth * 2 + 1));\n    sb.append((node.succeeded ? CHECK_MARK : BALLOT_X) + ' ' + node.displayString);\n    if (node.isLeftRecursive) {\n      sb.append(' (LR)');\n    }\n    if (node.succeeded) {\n      var contents = asEscapedString(node.interval.contents);\n      sb.append(' ' + RIGHTWARDS_DOUBLE_ARROW + '  ');\n      sb.append(typeof contents === 'string' ? '\"' + contents + '\"' : contents);\n    }\n    sb.append('\\n');\n  });\n  return sb.contents();\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Trace;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar extend = require('util-extend');\n\n// --------------------------------------------------------------------\n// Private Stuff\n// --------------------------------------------------------------------\n\n// Helpers\n\nfunction repeatStr(str, n) {\n  return new Array(n + 1).join(str);\n}\n\nvar escapeStringFor = {};\nfor (var c = 0; c < 128; c++) {\n  escapeStringFor[c] = String.fromCharCode(c);\n}\nescapeStringFor[\"'\".charCodeAt(0)]  = \"\\\\'\";\nescapeStringFor['\"'.charCodeAt(0)]  = '\\\\\"';\nescapeStringFor['\\\\'.charCodeAt(0)] = '\\\\\\\\';\nescapeStringFor['\\b'.charCodeAt(0)] = '\\\\b';\nescapeStringFor['\\f'.charCodeAt(0)] = '\\\\f';\nescapeStringFor['\\n'.charCodeAt(0)] = '\\\\n';\nescapeStringFor['\\r'.charCodeAt(0)] = '\\\\r';\nescapeStringFor['\\t'.charCodeAt(0)] = '\\\\t';\nescapeStringFor['\\u000b'.charCodeAt(0)] = '\\\\v';\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nexports.abstract = function() {\n  throw new Error('this method is abstract!');\n};\n\n// Define a lazily-computed, non-enumerable property named `propName`\n// on the object `obj`. `getterFn` will be called to compute the value the\n// first time the property is accessed.\nexports.defineLazyProperty = function(obj, propName, getterFn) {\n  var memo;\n  Object.defineProperty(obj, propName, {\n    get: function() {\n      if (!memo) {\n        memo = getterFn.call(this);\n      }\n      return memo;\n    }\n  });\n};\n\nexports.clone = function(obj) {\n  if (obj) {\n    return extend({}, obj);\n  }\n  return obj;\n};\n\nexports.extend = extend;\n\nexports.repeatFn = function(fn, n) {\n  var arr = [];\n  while (n-- > 0) {\n    arr.push(fn());\n  }\n  return arr;\n};\n\nexports.repeat = function(x, n) {\n  return exports.repeatFn(function() { return x; }, n);\n};\n\nexports.getDuplicates = function(array) {\n  var duplicates = [];\n  for (var idx = 0; idx < array.length; idx++) {\n    var x = array[idx];\n    if (array.lastIndexOf(x) !== idx && duplicates.indexOf(x) < 0) {\n      duplicates.push(x);\n    }\n  }\n  return duplicates;\n};\n\nexports.fail = {};\n\nexports.isSyntactic = function(ruleName) {\n  var firstChar = ruleName[0];\n  return ('A' <= firstChar && firstChar <= 'Z');\n};\n\nexports.padLeft = function(str, len, optChar) {\n  var ch = optChar || ' ';\n  if (str.length < len) {\n    return repeatStr(ch, len - str.length) + str;\n  }\n  return str;\n};\n\n// StringBuffer\n\nexports.StringBuffer = function() {\n  this.strings = [];\n};\n\nexports.StringBuffer.prototype.append = function(str) {\n  this.strings.push(str);\n};\n\nexports.StringBuffer.prototype.contents = function() {\n  return this.strings.join('');\n};\n\n// Character escaping and unescaping\n\nexports.escapeChar = function(c, optDelim) {\n  var charCode = c.charCodeAt(0);\n  if ((c === '\"' || c === \"'\") && optDelim && c !== optDelim) {\n    return c;\n  } else if (charCode < 128) {\n    return escapeStringFor[charCode];\n  } else if (128 <= charCode && charCode < 256) {\n    return '\\\\x' + exports.padLeft(charCode.toString(16), 2, '0');\n  } else {\n    return '\\\\u' + exports.padLeft(charCode.toString(16), 4, '0');\n  }\n};\n\nexports.unescapeChar = function(s) {\n  if (s.charAt(0) === '\\\\') {\n    switch (s.charAt(1)) {\n      case 'b': return '\\b';\n      case 'f': return '\\f';\n      case 'n': return '\\n';\n      case 'r': return '\\r';\n      case 't': return '\\t';\n      case 'v': return '\\v';\n      case 'x': return String.fromCharCode(parseInt(s.substring(2, 4), 16));\n      case 'u': return String.fromCharCode(parseInt(s.substring(2, 6), 16));\n      default:   return s.charAt(1);\n    }\n  } else {\n    return s;\n  }\n};\n\n// Helper for producing a description of an unknown object in a safe way.\n// Especially useful for error messages where an unexpected type of object was encountered.\nexports.unexpectedObjToString = function(obj) {\n  if (obj == null) {\n    return String(obj);\n  }\n  var baseToString = Object.prototype.toString.call(obj);\n  try {\n    var typeName;\n    if (obj.constructor && obj.constructor.name) {\n      typeName = obj.constructor.name;\n    } else if (baseToString.indexOf('[object ') === 0) {\n      typeName = baseToString.slice(8, -1);  // Extract e.g. \"Array\" from \"[object Array]\".\n    } else {\n      typeName = typeof obj;\n    }\n    return typeName + ': ' + JSON.stringify(String(obj));\n  } catch (e) {\n    return baseToString;\n  }\n};\n\n// Pretty-printing of strings\n\nexports.toStringLiteral = function(str) {\n  if (typeof str !== 'string') {\n    throw new Error('toStringLiteral only works on strings');\n  }\n  var hasSingleQuotes = str.indexOf(\"'\") >= 0;\n  var hasDoubleQuotes = str.indexOf('\"') >= 0;\n  var delim = hasSingleQuotes && !hasDoubleQuotes ? '\"' : \"'\";\n  var sb = new exports.StringBuffer();\n  sb.append(delim);\n  for (var idx = 0; idx < str.length; idx++) {\n    sb.append(exports.escapeChar(str[idx], delim));\n  }\n  sb.append(delim);\n  return sb.contents();\n};\n\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Namespace = require('./Namespace');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction OhmError() {}\nOhmError.prototype = Object.create(Error.prototype);\n\nfunction makeCustomError(name, initFn) {\n  // Make E think it's really called OhmError, so that errors look nicer when they're\n  // console.log'ed in Chrome.\n  var E = function OhmError() {\n    initFn.apply(this, arguments);\n    // `captureStackTrace` is V8-only.\n    if (typeof Error.captureStackTrace === 'function') {\n      Error.captureStackTrace(this, this.constructor);\n    } else {\n      var e = new Error();\n      Object.defineProperty(this, 'stack', {get: function() { return e.stack; }});\n    }\n  };\n  E.prototype = Object.create(OhmError.prototype);\n  E.prototype.constructor = E;\n  E.prototype.name = name;\n  return E;\n}\n\n// ----------------- errors about intervals -----------------\n\nvar IntervalSourcesDontMatch = makeCustomError(\n    'ohm.error.IntervalSourcesDontMatch',\n    function() {\n      this.message = \"Interval sources don't match\";\n    }\n);\n\n// ----------------- errors about grammars -----------------\n\n// Grammar syntax error\n\nvar GrammarSyntaxError = makeCustomError(\n    'ohm.error.GrammarSyntaxError',\n    function(matchFailure) {\n      Object.defineProperty(this, 'message', {\n        get: function() {\n          return 'Failed to parse grammar:\\n' + matchFailure.message;\n        }\n      });\n    }\n);\n\n// Undeclared grammar\n\nvar UndeclaredGrammar = makeCustomError(\n    'ohm.error.UndeclaredGrammar',\n    function(grammarName, namespace) {\n      this.grammarName = grammarName;\n      this.namespace = namespace;\n      if (this.namespace) {\n        this.message = 'Grammar ' + this.grammarName +\n            ' is not declared in namespace ' + Namespace.toString(this.namespace);\n      } else {\n        this.message = 'Undeclared grammar ' + this.grammarName;\n      }\n    }\n);\n\n// Duplicate grammar declaration\n\nvar DuplicateGrammarDeclaration = makeCustomError(\n    'ohm.error.DuplicateGrammarDeclaration',\n    function(grammarName, namespace) {\n      this.grammarName = grammarName;\n      this.namespace = namespace;\n      this.message = 'Grammar ' + this.grammarName +\n          ' is already declared in namespace ' + Namespace.toString(this.namespace);\n    }\n);\n\n// ----------------- rules -----------------\n\n// Undeclared rule\n\nvar UndeclaredRule = makeCustomError(\n    'ohm.error.UndeclaredRule',\n    function(ruleName, grammarName) {\n      this.ruleName = ruleName;\n      this.grammarName = grammarName;\n      this.message = 'Rule ' + this.ruleName + ' is not declared in grammar ' + this.grammarName;\n    }\n);\n\n// Cannot override undeclared rule\n\nvar CannotOverrideUndeclaredRule = makeCustomError(\n    'ohm.error.CannotOverrideUndeclaredRule',\n    function(ruleName, grammarName) {\n      this.ruleName = ruleName;\n      this.grammarName = grammarName;\n      this.message =\n          'Cannot override rule ' + this.ruleName +\n          ' because it is not declared in ' + this.grammarName;\n    }\n);\n\n// Cannot extend undeclared rule\n\nvar CannotExtendUndeclaredRule = makeCustomError(\n    'ohm.error.CannotExtendUndeclaredRule',\n    function(ruleName, grammarName) {\n      this.ruleName = ruleName;\n      this.grammarName = grammarName;\n      this.message =\n          'Cannot extend rule ' + this.ruleName +\n          ' because it is not declared in ' + this.grammarName;\n    }\n);\n\n// Duplicate rule declaration\n\nvar DuplicateRuleDeclaration = makeCustomError(\n    'ohm.error.DuplicateRuleDeclaration',\n    function(ruleName, offendingGrammarName, declGrammarName) {\n      this.ruleName = ruleName;\n      this.offendingGrammarName = offendingGrammarName;\n      this.declGrammarName = declGrammarName;\n      this.message = \"Duplicate declaration for rule '\" + this.ruleName +\n                     \"' in grammar '\" + this.offendingGrammarName + \"'\";\n      if (this.offendingGrammarName !== declGrammarName) {\n        this.message += \" (originally declared in grammar '\" + this.declGrammarName + \"')\";\n      }\n    }\n);\n\n// Wrong number of parameters\n\nvar WrongNumberOfParameters = makeCustomError(\n    'ohm.error.WrongNumberOfParameters',\n    function(ruleName, expected, actual) {\n      this.ruleName = ruleName;\n      this.expected = expected;\n      this.actual = actual;\n      this.message = 'Wrong number of parameters for rule ' + this.ruleName +\n                     ' (expected ' + this.expected + ', got ' + this.actual + ')';\n    }\n);\n\n// Duplicate parameter names\n\nvar DuplicateParameterNames = makeCustomError(\n    'ohm.error.DuplicateParameterNames',\n    function(ruleName, duplicates) {\n      this.ruleName = ruleName;\n      this.duplicates = duplicates;\n      this.message = 'Duplicate parameter names in rule ' + this.ruleName + ': ' +\n                     this.duplicates.join(',');\n    }\n);\n\n// Invalid parameter expression\n\nvar InvalidParameter = makeCustomError(\n    'ohm.error.InvalidParameter',\n    function(ruleName, expr) {\n      this.ruleName = ruleName;\n      this.expr = expr;\n      this.message = 'Invalid parameter to rule ' + this.ruleName + ': ' + this.expr +\n                     ' has arity ' + this.expr.getArity() + ', but parameter expressions ' +\n                     'must have arity 1';\n    }\n);\n\n// ----------------- Kleene operators -----------------\n\nvar KleeneExprHasNullableOperand = makeCustomError(\n    'ohm.error.KleeneExprHasNullableOperand',\n    function(kleeneExpr) {\n      this.expr = kleeneExpr;\n\n      var operator = kleeneExpr.operator;\n      var nullableExpr = kleeneExpr.expr;\n      this.message = nullableExpr.interval.getLineAndColumnMessage() +\n                     'Nullable expression ' + nullableExpr.interval.contents +\n                     \" is not allowed inside '\" + operator + \"' (possible infinite loop)\";\n    }\n);\n\n// ----------------- arity -----------------\n\nvar InconsistentArity = makeCustomError(\n    'ohm.error.InconsistentArity',\n    function(ruleName, expected, actual) {\n      this.ruleName = ruleName;\n      this.expected = expected;\n      this.actual = actual;\n      this.message =\n          'Rule ' + this.ruleName + ' involves an alternation which has inconsistent arity ' +\n          '(expected ' + this.expected + ', got ' + this.actual + ')';\n    }\n);\n\n// ----------------- properties -----------------\n\nvar DuplicatePropertyNames = makeCustomError(\n    'ohm.error.DuplicatePropertyNames',\n    function(duplicates) {\n      this.duplicates = duplicates;\n      this.message = 'Object pattern has duplicate property names: ' + this.duplicates.join(', ');\n    }\n);\n\n// ----------------- constructors -----------------\n\nvar InvalidConstructorCall = makeCustomError(\n    'ohm.error.InvalidConstructorCall',\n    function(grammar, ctorName, children) {\n      this.grammar = grammar;\n      this.ctorName = ctorName;\n      this.children = children;\n      this.message = 'Attempt to invoke constructor ' + this.ctorName +\n                     ' with invalid or unexpected arguments';\n    }\n);\n\n// ----------------- convenience -----------------\n\nvar MultipleErrors = makeCustomError(\n    'ohm.error.MultipleErrors',\n    function(errors) {\n      this.errors = errors;\n      var messages = errors.map(function(e) { return e.message; });\n      this.message = ['Errors:'].concat(messages).join('\\n- ');\n    }\n);\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = {\n  CannotExtendUndeclaredRule: CannotExtendUndeclaredRule,\n  CannotOverrideUndeclaredRule: CannotOverrideUndeclaredRule,\n  DuplicateGrammarDeclaration: DuplicateGrammarDeclaration,\n  DuplicateParameterNames: DuplicateParameterNames,\n  DuplicatePropertyNames: DuplicatePropertyNames,\n  DuplicateRuleDeclaration: DuplicateRuleDeclaration,\n  Error: OhmError,\n  InconsistentArity: InconsistentArity,\n  IntervalSourcesDontMatch: IntervalSourcesDontMatch,\n  InvalidConstructorCall: InvalidConstructorCall,\n  InvalidParameter: InvalidParameter,\n  GrammarSyntaxError: GrammarSyntaxError,\n  KleeneExprHasNullableOperand: KleeneExprHasNullableOperand,\n  MultipleErrors: MultipleErrors,\n  UndeclaredGrammar: UndeclaredGrammar,\n  UndeclaredRule: UndeclaredRule,\n  WrongNumberOfParameters: WrongNumberOfParameters,\n\n  throwErrors: function(errors) {\n    if (errors.length === 1) {\n      throw errors[0];\n    }\n    if (errors.length > 1) {\n      throw new MultipleErrors(errors);\n    }\n  }\n};\n","(function (Buffer){\n/* global document, Buffer, XMLHttpRequest */\n\n'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Builder = require('./Builder');\nvar Grammar = require('./Grammar');\nvar Namespace = require('./Namespace');\nvar Semantics = require('./Semantics');\nvar UnicodeCategories = require('../third_party/unicode').UnicodeCategories;\nvar common = require('./common');\nvar errors = require('./errors');\nvar util = require('./util');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// The metagrammar, i.e. the grammar for Ohm grammars. Initialized at the\n// bottom of this file because loading the grammar requires Ohm itself.\nvar ohmGrammar;\n\n// An object which makes it possible to stub out the document API for testing.\nvar documentInterface = {\n  querySelector: function(sel) { return document.querySelector(sel); },\n  querySelectorAll: function(sel) { return document.querySelectorAll(sel); }\n};\n\n// Check if `obj` is a DOM element.\nfunction isElement(obj) {\n  return !!(obj && obj.nodeType === 1);\n}\n\nfunction isUndefined(obj) {\n  return obj === void 0;\n}\n\nvar MAX_ARRAY_INDEX = Math.pow(2, 53) - 1;\n\nfunction isArrayLike(obj) {\n  if (obj == null) {\n    return false;\n  }\n  var length = obj.length;\n  return typeof length === 'number' && length >= 0 && length <= MAX_ARRAY_INDEX;\n}\n\n// TODO: just use the jQuery thing\nfunction load(url) {\n  var req = new XMLHttpRequest();\n  req.open('GET', url, false);\n  try {\n    req.send();\n    if (req.status === 0 || req.status === 200) {\n      return req.responseText;\n    }\n  } catch (e) {}\n  throw new Error('unable to load url ' + url);\n}\n\n// Returns a Grammar instance (i.e., an object with a `match` method) for\n// `tree`, which is the concrete syntax tree of a user-written grammar.\n// The grammar will be assigned into `namespace` under the name of the grammar\n// as specified in the source.\nfunction buildGrammar(match, namespace, optOhmGrammarForTesting) {\n  var builder;\n  var decl;\n  var currentRuleName;\n  var currentRuleFormals;\n  var overriding = false;\n  var metaGrammar = optOhmGrammarForTesting || ohmGrammar;\n\n  // A visitor that produces a Grammar instance from the CST.\n  var helpers = metaGrammar.semantics().addOperation('visit', {\n    Grammar: function(n, s, open, rs, close) {\n      builder = new Builder();\n      var grammarName = n.visit();\n      decl = builder.newGrammar(grammarName, namespace);\n      s.visit();\n      rs.visit();\n      var g = decl.build();\n      if (grammarName in namespace) {\n        throw new errors.DuplicateGrammarDeclaration(grammarName, namespace);\n      }\n      g.definitionInterval = this.interval.trimmed();\n      namespace[grammarName] = g;\n      return g;\n    },\n\n    SuperGrammar: function(_, n) {\n      var superGrammarName = n.visit();\n      if (superGrammarName === 'null') {\n        decl.withSuperGrammar(null);\n      } else {\n        if (!namespace || !(superGrammarName in namespace)) {\n          throw new errors.UndeclaredGrammar(superGrammarName, namespace);\n        }\n        decl.withSuperGrammar(namespace[superGrammarName]);\n      }\n    },\n\n    Rule_define: function(n, fs, d, _, b) {\n      currentRuleName = n.visit();\n      currentRuleFormals = fs.visit()[0] || [];\n      // If there is no default start rule yet, set it now. This must be done before visiting\n      // the body, because it might contain an inline rule definition.\n      if (!decl.defaultStartRule && decl.ensureSuperGrammar() !== Grammar.ProtoBuiltInRules) {\n        decl.withDefaultStartRule(currentRuleName);\n      }\n      var body = b.visit();\n      body.definitionInterval = this.interval.trimmed();\n      var description = d.visit()[0];\n      return decl.define(currentRuleName, currentRuleFormals, body, description);\n    },\n    Rule_override: function(n, fs, _, b) {\n      currentRuleName = n.visit();\n      currentRuleFormals = fs.visit()[0] || [];\n      overriding = true;\n      var body = b.visit();\n      body.definitionInterval = this.interval.trimmed();\n      var ans = decl.override(currentRuleName, currentRuleFormals, body);\n      overriding = false;\n      return ans;\n    },\n    Rule_extend: function(n, fs, _, b) {\n      currentRuleName = n.visit();\n      currentRuleFormals = fs.visit()[0] || [];\n      var body = b.visit();\n      var ans = decl.extend(currentRuleName, currentRuleFormals, body);\n      decl.ruleDict[currentRuleName].definitionInterval = this.interval.trimmed();\n      return ans;\n    },\n\n    Formals: function(opointy, fs, cpointy) {\n      return fs.visit();\n    },\n\n    Params: function(opointy, ps, cpointy) {\n      return ps.visit();\n    },\n\n    Alt: function(term, _, terms) {\n      var args = [term.visit()].concat(terms.visit());\n      return builder.alt.apply(builder, args).withInterval(this.interval);\n    },\n\n    Term_inline: function(b, n) {\n      var inlineRuleName = currentRuleName + '_' + n.visit();\n      var body = b.visit();\n      body.definitionInterval = this.interval.trimmed();\n      var isNewRuleDeclaration = !(decl.superGrammar && decl.superGrammar.ruleDict[inlineRuleName]);\n      if (overriding && !isNewRuleDeclaration) {\n        decl.override(inlineRuleName, currentRuleFormals, body);\n      } else {\n        decl.define(inlineRuleName, currentRuleFormals, body);\n      }\n      var params = currentRuleFormals.map(function(formal) { return builder.app(formal); });\n      return builder.app(inlineRuleName, params).withInterval(body.interval);\n    },\n\n    Seq: function(expr) {\n      return builder.seq.apply(builder, expr.visit()).withInterval(this.interval);\n    },\n\n    Iter_star: function(x, _) {\n      return builder.star(x.visit()).withInterval(this.interval);\n    },\n    Iter_plus: function(x, _) {\n      return builder.plus(x.visit()).withInterval(this.interval);\n    },\n    Iter_opt: function(x, _) {\n      return builder.opt(x.visit()).withInterval(this.interval);\n    },\n\n    Pred_not: function(_, x) {\n      return builder.not(x.visit()).withInterval(this.interval);\n    },\n    Pred_lookahead: function(_, x) {\n      return builder.la(x.visit()).withInterval(this.interval);\n    },\n\n    Base_application: function(rule, ps) {\n      return builder.app(rule.visit(), ps.visit()[0] || []).withInterval(this.interval);\n    },\n    Base_prim: function(expr) {\n      return builder.prim(expr.visit()).withInterval(this.interval);\n    },\n    Base_paren: function(open, x, close) {\n      return x.visit();\n    },\n    Base_arr: function(open, x, close) {\n      return builder.arr(x.visit()).withInterval(this.interval);\n    },\n    Base_str: function(open, x, close) {\n      return builder.str(x.visit());\n    },\n    Base_obj: function(open, lenient, close) {\n      return builder.obj([], lenient.visit()[0]);\n    },\n\n    Base_objWithProps: function(open, ps, _, lenient, close) {\n      return builder.obj(ps.visit(), lenient.visit()[0]).withInterval(this.interval);\n    },\n\n    Props: function(p, _, ps) {\n      return [p.visit()].concat(ps.visit());\n    },\n    Prop: function(n, _, p) {\n      return {name: n.visit(), pattern: p.visit()};\n    },\n\n    ruleDescr: function(open, t, close) {\n      return t.visit();\n    },\n    ruleDescrText: function(_) {\n      return this.interval.contents.trim();\n    },\n\n    caseName: function(_, space1, n, space2, end) {\n      return n.visit();\n    },\n\n    name: function(first, rest) {\n      return this.interval.contents;\n    },\n    nameFirst: function(expr) {},\n    nameRest: function(expr) {},\n\n    keyword_null: function(_) {\n      return null;\n    },\n    keyword_true: function(_) {\n      return true;\n    },\n    keyword_false: function(_) {\n      return false;\n    },\n\n    string: function(open, cs, close) {\n      return cs.visit().map(function(c) { return common.unescapeChar(c); }).join('');\n    },\n\n    strChar: function(_) {\n      return this.interval.contents;\n    },\n\n    escapeChar: function(_) {\n      return this.interval.contents;\n    },\n\n    regExp: function(open, e, close) {\n      return e.visit();\n    },\n\n    reCharClass_unicode: function(open, unicodeClass, close) {\n      return UnicodeCategories[unicodeClass.visit().join('')];\n    },\n    reCharClass_ordinary: function(open, _, close) {\n      return new RegExp(this.interval.contents);\n    },\n\n    number: function(_, digits) {\n      return parseInt(this.interval.contents);\n    },\n\n    space: function(expr) {},\n    space_multiLine: function(start, _, end) {},\n    space_singleLine: function(start, _, end) {},\n\n    ListOf_some: function(x, _, xs) {\n      return [x.visit()].concat(xs.visit());\n    },\n    ListOf_none: function() {\n      return [];\n    },\n\n    _terminal: Semantics.actions.getPrimitiveValue,\n    _default: Semantics.actions.passThrough\n  });\n  return helpers(match).visit();\n}\n\nfunction compileAndLoad(source, namespace) {\n  var m = ohmGrammar.match(source, 'Grammars');\n  if (m.failed()) {\n    throw new errors.GrammarSyntaxError(m);\n  }\n  return buildGrammar(m, namespace);\n}\n\n// Return the contents of a script element, fetching it via XHR if necessary.\nfunction getScriptElementContents(el) {\n  if (!isElement(el)) {\n    throw new TypeError('Expected a DOM Node, got ' + common.unexpectedObjToString(el));\n  }\n  if (el.type !== 'text/ohm-js') {\n    throw new Error('Expected a script tag with type=\"text/ohm-js\", got ' + el);\n  }\n  return el.getAttribute('src') ? load(el.getAttribute('src')) : el.innerHTML;\n}\n\nfunction grammar(source, optNamespace) {\n  var ns = grammars(source, optNamespace);\n\n  // Ensure that the source contained no more than one grammar definition.\n  var grammarNames = Object.keys(ns);\n  if (grammarNames.length === 0) {\n    throw new Error('Missing grammar definition');\n  } else if (grammarNames.length > 1) {\n    var secondGrammar = ns[grammarNames[1]];\n    var interval = secondGrammar.definitionInterval;\n    throw new Error(\n        util.getLineAndColumnMessage(interval.inputStream.source, interval.startIdx) +\n        'Found more than one grammar definition -- use ohm.grammars() instead.');\n  }\n  return ns[grammarNames[0]];  // Return the one and only grammar.\n}\n\nfunction grammars(source, optNamespace) {\n  var ns = Namespace.extend(Namespace.asNamespace(optNamespace));\n  if (typeof source !== 'string') {\n    // For convenience, detect Node.js Buffer objects and automatically call toString().\n    if (Buffer && Buffer.isBuffer(source)) {\n      source = source.toString();\n    } else {\n      throw new TypeError(\n          'Expected string as first argument, got ' + common.unexpectedObjToString(source));\n    }\n  }\n  compileAndLoad(source, ns);\n  return ns;\n}\n\nfunction grammarFromScriptElement(optNode) {\n  var node = optNode;\n  if (isUndefined(node)) {\n    var nodeList = documentInterface.querySelectorAll('script[type=\"text/ohm-js\"]');\n    if (nodeList.length !== 1) {\n      throw new Error(\n          'Expected exactly one script tag with type=\"text/ohm-js\", found ' + nodeList.length);\n    }\n    node = nodeList[0];\n  }\n  return grammar(getScriptElementContents(node));\n}\n\nfunction grammarsFromScriptElements(optNodeOrNodeList) {\n  // Simple case: the argument is a DOM node.\n  if (isElement(optNodeOrNodeList)) {\n    return grammars(optNodeOrNodeList);\n  }\n  // Otherwise, it must be either undefined or a NodeList.\n  var nodeList = optNodeOrNodeList;\n  if (isUndefined(nodeList)) {\n    // Find all script elements with type=\"text/ohm-js\".\n    nodeList = documentInterface.querySelectorAll('script[type=\"text/ohm-js\"]');\n  } else if (typeof nodeList === 'string' || (!isElement(nodeList) && !isArrayLike(nodeList))) {\n    throw new TypeError('Expected a Node, NodeList, or Array, but got ' + nodeList);\n  }\n  var ns = Namespace.createNamespace();\n  for (var i = 0; i < nodeList.length; ++i) {\n    // Copy the new grammars into `ns` to keep the namespace flat.\n    common.extend(ns, grammars(getScriptElementContents(nodeList[i]), ns));\n  }\n  return ns;\n}\n\nfunction makeRecipe(recipeFn) {\n  return recipeFn.call(new Builder());\n}\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\n// Stuff that users should know about\n\nmodule.exports = {\n  actions: Semantics.actions,\n  createNamespace: Namespace.createNamespace,\n  error: errors,\n  grammar: grammar,\n  grammars: grammars,\n  grammarFromScriptElement: grammarFromScriptElement,\n  grammarsFromScriptElements: grammarsFromScriptElements,\n  makeRecipe: makeRecipe,\n  util: util\n};\n\n// Stuff that's only here for bootstrapping, testing, etc.\nGrammar.BuiltInRules = require('../dist/built-in-rules');\nohmGrammar = require('../dist/ohm-grammar');\nmodule.exports._buildGrammar = buildGrammar;\nmodule.exports._setDocumentInterfaceForTesting = function(doc) { documentInterface = doc; };\nmodule.exports.ohmGrammar = ohmGrammar;\n\n}).call(this,require(\"buffer\").Buffer)","'use strict';\n\nvar inherits = require('inherits');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction Node(grammar, ctorName, children, interval) {\n  this.grammar = grammar;\n  this.ctorName = ctorName;\n  this.children = children;\n  this.interval = interval;\n}\n\nNode.prototype.numChildren = function() {\n  return this.children.length;\n};\n\nNode.prototype.childAt = function(idx) {\n  return this.children[idx];\n};\n\nNode.prototype.indexOfChild = function(arg) {\n  return this.children.indexOf(arg);\n};\n\nNode.prototype.hasChildren = function() {\n  return this.children.length > 0;\n};\n\nNode.prototype.hasNoChildren = function() {\n  return !this.hasChildren();\n};\n\nNode.prototype.onlyChild = function() {\n  if (this.children.length !== 1) {\n    throw new Error(\n        'cannot get only child of a node of type ' + this.ctorName +\n        ' (it has ' + this.numChildren() + ' children)');\n  } else {\n    return this.firstChild();\n  }\n};\n\nNode.prototype.firstChild = function() {\n  if (this.hasNoChildren()) {\n    throw new Error(\n        'cannot get first child of a ' + this.ctorName + ' node, which has no children');\n  } else {\n    return this.childAt(0);\n  }\n};\n\nNode.prototype.lastChild = function() {\n  if (this.hasNoChildren()) {\n    throw new Error(\n        'cannot get last child of a ' + this.ctorName + ' node, which has no children');\n  } else {\n    return this.childAt(this.numChildren() - 1);\n  }\n};\n\nNode.prototype.childBefore = function(child) {\n  var childIdx = this.indexOfChild(child);\n  if (childIdx < 0) {\n    throw new Error('Node.childBefore() called w/ an argument that is not a child');\n  } else if (childIdx === 0) {\n    throw new Error('cannot get child before first child');\n  } else {\n    return this.childAt(childIdx - 1);\n  }\n};\n\nNode.prototype.childAfter = function(child) {\n  var childIdx = this.indexOfChild(child);\n  if (childIdx < 0) {\n    throw new Error('Node.childAfter() called w/ an argument that is not a child');\n  } else if (childIdx === this.numChildren() - 1) {\n    throw new Error('cannot get child after last child');\n  } else {\n    return this.childAt(childIdx + 1);\n  }\n};\n\nNode.prototype.isTerminal = function() {\n  return false;\n};\n\nNode.prototype.toJSON = function() {\n  var r = {};\n  r[this.ctorName] = this.children;\n  return r;\n};\n\nfunction TerminalNode(grammar, value, interval) {\n  Node.call(this, grammar, '_terminal', [], interval);\n  this.primitiveValue = value;\n}\ninherits(TerminalNode, Node);\n\nTerminalNode.prototype.isTerminal = function() {\n  return true;\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = {Node: Node, TerminalNode: TerminalNode};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\nvar errors = require('./errors');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.assertAllApplicationsAreValid = common.abstract;\n\npexprs.anything.assertAllApplicationsAreValid = function(grammar) {\n  // no-op\n};\n\npexprs.end.assertAllApplicationsAreValid = function(grammar) {\n  // no-op\n};\n\npexprs.Prim.prototype.assertAllApplicationsAreValid = function(grammar) {\n  // no-op\n};\n\npexprs.Param.prototype.assertAllApplicationsAreValid = function(grammar) {\n  // no-op\n};\n\npexprs.Alt.prototype.assertAllApplicationsAreValid = function(grammar) {\n  for (var idx = 0; idx < this.terms.length; idx++) {\n    this.terms[idx].assertAllApplicationsAreValid(grammar);\n  }\n};\n\npexprs.Seq.prototype.assertAllApplicationsAreValid = function(grammar) {\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    this.factors[idx].assertAllApplicationsAreValid(grammar);\n  }\n};\n\npexprs.Iter.prototype.assertAllApplicationsAreValid =\npexprs.Not.prototype.assertAllApplicationsAreValid =\npexprs.Lookahead.prototype.assertAllApplicationsAreValid =\npexprs.Arr.prototype.assertAllApplicationsAreValid =\npexprs.Str.prototype.assertAllApplicationsAreValid = function(grammar) {\n  this.expr.assertAllApplicationsAreValid(grammar);\n};\n\npexprs.Obj.prototype.assertAllApplicationsAreValid = function(grammar) {\n  for (var idx = 0; idx < this.properties.length; idx++) {\n    this.properties[idx].pattern.assertAllApplicationsAreValid(grammar);\n  }\n};\n\npexprs.Apply.prototype.assertAllApplicationsAreValid = function(grammar) {\n  var body = grammar.ruleDict[this.ruleName];\n\n  // Make sure that the rule exists\n  if (!body) {\n    throw new errors.UndeclaredRule(this.ruleName, grammar.name);\n  }\n\n  // ... and that this application has the correct number of parameters\n  var actual = this.params.length;\n  var expected = body.formals.length;\n  if (actual !== expected) {\n    throw new errors.WrongNumberOfParameters(this.ruleName, expected, actual);\n  }\n\n  // ... and that all of the parameter expressions only have valid applications and have arity 1\n  var self = this;\n  this.params.forEach(function(param) {\n    param.assertAllApplicationsAreValid(grammar);\n    if (param.getArity() !== 1) {\n      throw new errors.InvalidParameter(self.ruleName, param);\n    }\n  });\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\nvar errors = require('./errors');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.assertChoicesHaveUniformArity = common.abstract;\n\npexprs.anything.assertChoicesHaveUniformArity =\npexprs.end.assertChoicesHaveUniformArity =\npexprs.Prim.prototype.assertChoicesHaveUniformArity =\npexprs.Param.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  // no-op\n};\n\npexprs.Alt.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  if (this.terms.length === 0) {\n    return;\n  }\n  var arity = this.terms[0].getArity();\n  for (var idx = 0; idx < this.terms.length; idx++) {\n    var term = this.terms[idx];\n    term.assertChoicesHaveUniformArity();\n    var otherArity = term.getArity();\n    if (arity !== otherArity) {\n      throw new errors.InconsistentArity(ruleName, arity, otherArity);\n    }\n  }\n};\n\npexprs.Extend.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  // Extend is a special case of Alt that's guaranteed to have exactly two\n  // cases: [extensions, origBody].\n  var actualArity = this.terms[0].getArity();\n  var expectedArity = this.terms[1].getArity();\n  if (actualArity !== expectedArity) {\n    throw new errors.InconsistentArity(ruleName, expectedArity, actualArity);\n  }\n};\n\npexprs.Seq.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    this.factors[idx].assertChoicesHaveUniformArity(ruleName);\n  }\n};\n\npexprs.Iter.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  this.expr.assertChoicesHaveUniformArity(ruleName);\n};\n\npexprs.Not.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  // no-op (not required b/c the nested expr doesn't show up in the CST)\n};\n\npexprs.Lookahead.prototype.assertChoicesHaveUniformArity =\npexprs.Arr.prototype.assertChoicesHaveUniformArity =\npexprs.Str.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  this.expr.assertChoicesHaveUniformArity(ruleName);\n};\n\npexprs.Obj.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  for (var idx = 0; idx < this.properties.length; idx++) {\n    this.properties[idx].pattern.assertChoicesHaveUniformArity(ruleName);\n  }\n};\n\npexprs.Apply.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  // The arities of the parameter expressions is required to be 1 by\n  // `assertAllApplicationsAreValid()`.\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar pexprs = require('./pexprs');\nvar errors = require('./errors');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.assertIteratedExprsAreNotNullable = function(grammar, ruleName) {\n  // no-op\n};\n\npexprs.Alt.prototype.assertIteratedExprsAreNotNullable = function(grammar, ruleName) {\n  for (var idx = 0; idx < this.terms.length; idx++) {\n    this.terms[idx].assertIteratedExprsAreNotNullable(grammar, ruleName);\n  }\n};\n\npexprs.Seq.prototype.assertIteratedExprsAreNotNullable = function(grammar, ruleName) {\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    this.factors[idx].assertIteratedExprsAreNotNullable(grammar, ruleName);\n  }\n};\n\npexprs.Iter.prototype.assertIteratedExprsAreNotNullable = function(grammar, ruleName) {\n  // Note: this is the implementation of this method for `Star` and `Plus` expressions.\n  // It is overridden for `Opt` below.\n  this.expr.assertIteratedExprsAreNotNullable(grammar, ruleName);\n  if (this.expr.isNullable(grammar)) {\n    throw new errors.KleeneExprHasNullableOperand(this, ruleName);\n  }\n};\n\npexprs.Opt.prototype.assertIteratedExprsAreNotNullable =\npexprs.Not.prototype.assertIteratedExprsAreNotNullable =\npexprs.Lookahead.prototype.assertIteratedExprsAreNotNullable =\npexprs.Arr.prototype.assertIteratedExprsAreNotNullable =\npexprs.Str.prototype.assertIteratedExprsAreNotNullable = function(grammar, ruleName) {\n  this.expr.assertIteratedExprsAreNotNullable(grammar, ruleName);\n};\n\npexprs.Obj.prototype.assertIteratedExprsAreNotNullable = function(grammar, ruleName) {\n  for (var idx = 0; idx < this.properties.length; idx++) {\n    this.properties[idx].pattern.assertIteratedExprsAreNotNullable(grammar, ruleName);\n  }\n};\n\npexprs.Apply.prototype.assertIteratedExprsAreNotNullable = function(grammar, ruleName) {\n  this.params.forEach(function(param) {\n    param.assertIteratedExprsAreNotNullable(grammar, ruleName);\n  });\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar nodes = require('./nodes');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.check = common.abstract;\n\npexprs.anything.check = function(grammar, vals) {\n  return vals.length >= 1;\n};\n\npexprs.end.check = function(grammar, vals) {\n  return vals[0] instanceof nodes.Node &&\n         vals[0].isTerminal() &&\n         vals[0].primitiveValue === undefined;\n};\n\npexprs.Prim.prototype.check = function(grammar, vals) {\n  return vals[0] instanceof nodes.Node &&\n         vals[0].isTerminal() &&\n         vals[0].primitiveValue === this.obj;\n};\n\npexprs.Param.prototype.check = function(grammar, vals) {\n  return vals.length >= 1;\n};\n\npexprs.RegExpPrim.prototype.check = function(grammar, vals) {\n  // TODO: more efficient \"total match checker\" than the use of .replace here\n  return vals[0] instanceof nodes.Node &&\n         vals[0].isTerminal() &&\n         typeof vals[0].primitiveValue === 'string' &&\n         vals[0].primitiveValue.replace(this.obj, '') === '';\n};\n\npexprs.Alt.prototype.check = function(grammar, vals) {\n  for (var i = 0; i < this.terms.length; i++) {\n    var term = this.terms[i];\n    if (term.check(grammar, vals)) {\n      return true;\n    }\n  }\n  return false;\n};\n\npexprs.Seq.prototype.check = function(grammar, vals) {\n  var pos = 0;\n  for (var i = 0; i < this.factors.length; i++) {\n    var factor = this.factors[i];\n    if (factor.check(grammar, vals.slice(pos))) {\n      pos += factor.getArity();\n    } else {\n      return false;\n    }\n  }\n  return true;\n};\n\npexprs.Iter.prototype.check = function(grammar, vals) {\n  var arity = this.getArity();\n  var columns = vals.slice(0, arity);\n  if (columns.length !== arity) {\n    return false;\n  }\n  var rowCount = columns[0].length;\n  var i;\n  for (i = 1; i < arity; i++) {\n    if (columns[i].length !== rowCount) {\n      return false;\n    }\n  }\n\n  for (i = 0; i < rowCount; i++) {\n    var row = [];\n    for (var j = 0; j < arity; j++) {\n      row.push(columns[j][i]);\n    }\n    if (!this.expr.check(grammar, row)) {\n      return false;\n    }\n  }\n\n  return true;\n};\n\npexprs.Not.prototype.check = function(grammar, vals) {\n  return true;\n};\n\npexprs.Lookahead.prototype.check = function(grammar, vals) {\n  return this.expr.check(grammar, vals);\n};\n\npexprs.Arr.prototype.check = function(grammar, vals) {\n  return this.expr.check(grammar, vals);\n};\n\npexprs.Str.prototype.check = function(grammar, vals) {\n  return this.expr.check(grammar, vals);\n};\n\npexprs.Obj.prototype.check = function(grammar, vals) {\n  var fixedArity = this.getArity();\n  if (this.isLenient) {\n    fixedArity--;\n  }\n\n  var pos = 0;\n  for (var i = 0; i < fixedArity; i++) {\n    var pattern = this.properties[i].pattern;\n    if (pattern.check(grammar, vals.slice(pos))) {\n      pos += pattern.getArity();\n    } else {\n      return false;\n    }\n  }\n\n  return this.isLenient ? typeof vals[pos] === 'object' && vals[pos] : true;\n};\n\npexprs.Apply.prototype.check = function(grammar, vals) {\n  if (!(vals[0] instanceof nodes.Node &&\n        vals[0].grammar === grammar &&\n        vals[0].ctorName === this.ruleName)) {\n    return false;\n  }\n\n  // TODO: think about *not* doing the following checks, i.e., trusting that the rule\n  // was correctly constructed.\n  var ruleNode = vals[0];\n  var body = grammar.ruleDict[this.ruleName];\n  return body.check(grammar, ruleNode.children) && ruleNode.numChildren() === body.getArity();\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar InputStream = require('./InputStream');\nvar common = require('./common');\nvar nodes = require('./nodes');\nvar pexprs = require('./pexprs');\n\nvar Node = nodes.Node;\nvar TerminalNode = nodes.TerminalNode;\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\nvar applySpaces_ = new pexprs.Apply('spaces_');\n\nfunction skipSpacesIfAppropriate(state) {\n  var currentApplication = state.applicationStack[state.applicationStack.length - 1];\n  var ruleName = currentApplication.ruleName || '';\n  if (typeof state.inputStream.source === 'string' && common.isSyntactic(ruleName)) {\n    skipSpaces(state);\n  }\n}\n\nfunction skipSpaces(state) {\n  state.ignoreFailures();\n  applySpaces_.eval(state);\n  state.bindings.pop();\n  state.recordFailures();\n}\n\n// Evaluate the expression and return true if it succeeded, otherwise false.\n// On success, the bindings will have `this.arity` more elements than before,\n// and the position could be anywhere. On failure, the bindings and position\n// will be unchanged.\npexprs.PExpr.prototype.eval = function(state) {\n  var origPos = state.inputStream.pos;\n  var origNumBindings = state.bindings.length;\n  var origTrace = state.trace;\n  if (state.isTracing()) {\n    state.trace = [];\n  }\n\n  // Do the actual evaluation.\n  var ans = this._eval(state, state.inputStream, origPos);\n\n  if (state.isTracing()) {\n    var traceEntry = state.getTraceEntry(origPos, this, ans);\n    origTrace.push(traceEntry);\n    state.trace = origTrace;\n  }\n\n  if (!ans) {\n    this.maybeRecordFailure(state, origPos);\n\n    // Reset the position and the bindings.\n    state.inputStream.pos = origPos;\n    state.bindings.length = origNumBindings;\n  }\n  return ans;\n};\n\n// Evaluate the expression and return true if it succeeded, otherwise false.\n// This should not be called directly except by `eval`.\n//\n// The contract of this method is as follows:\n// * When the return value is true:\n//   -- bindings will have expr.arity more elements than before\n// * When the return value is false:\n//   -- bindings will have exactly the same number of elements as before\n//   -- position could be anywhere\n\npexprs.PExpr.prototype._eval = common.abstract;\n\npexprs.anything._eval = function(state, inputStream, origPos) {\n  var value = inputStream.next();\n  if (value === common.fail) {\n    return false;\n  } else {\n    var interval = inputStream.intervalFrom(origPos);\n    state.bindings.push(new TerminalNode(state.grammar, value, interval));\n    return true;\n  }\n};\n\npexprs.end._eval = function(state, inputStream, origPos) {\n  if (state.inputStream.atEnd()) {\n    var interval = inputStream.intervalFrom(inputStream.pos);\n    state.bindings.push(new TerminalNode(state.grammar, undefined, interval));\n    return true;\n  } else {\n    return false;\n  }\n};\n\npexprs.Prim.prototype._eval = function(state, inputStream, origPos) {\n  if (this.match(inputStream) === common.fail) {\n    return false;\n  } else {\n    var interval = inputStream.intervalFrom(origPos);\n    state.bindings.push(new TerminalNode(state.grammar, this.obj, interval));\n    return true;\n  }\n};\n\npexprs.Prim.prototype.match = function(inputStream) {\n  return inputStream.matchExactly(this.obj);\n};\n\npexprs.StringPrim.prototype.match = function(inputStream) {\n  return inputStream.matchString(this.obj);\n};\n\npexprs.RegExpPrim.prototype._eval = function(state, inputStream, origPos) {\n  if (inputStream.matchRegExp(this.obj) === common.fail) {\n    return false;\n  } else {\n    var interval = inputStream.intervalFrom(origPos);\n    state.bindings.push(\n        new TerminalNode(state.grammar, inputStream.source[origPos], interval));\n    return true;\n  }\n};\n\npexprs.Param.prototype._eval = function(state, inputStream, origPos) {\n  var currentApplication = state.applicationStack[state.applicationStack.length - 1];\n  return currentApplication.params[this.index].eval(state);\n};\n\npexprs.Alt.prototype._eval = function(state, inputStream, origPos) {\n  var bindings = state.bindings;\n  var origNumBindings = bindings.length;\n  for (var idx = 0; idx < this.terms.length; idx++) {\n    if (this.terms[idx].eval(state)) {\n      return true;\n    } else {\n      inputStream.pos = origPos;\n      bindings.length = origNumBindings;\n    }\n  }\n  return false;\n};\n\npexprs.Seq.prototype._eval = function(state, inputStream, origPos) {\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    skipSpacesIfAppropriate(state);\n    var factor = this.factors[idx];\n    if (!factor.eval(state)) {\n      return false;\n    }\n  }\n  return true;\n};\n\npexprs.Iter.prototype._eval = function(state, inputStream, origPos) {\n  var arity = this.getArity();\n  var columns = common.repeatFn(function() { return []; }, arity);\n  var numMatches = 0;\n  var idx;\n  while (numMatches < this.maxNumMatches) {\n    var backtrackPos = inputStream.pos;\n    skipSpacesIfAppropriate(state);\n    if (this.expr.eval(state)) {\n      numMatches++;\n      var row = state.bindings.splice(state.bindings.length - arity, arity);\n      for (idx = 0; idx < row.length; idx++) {\n        columns[idx].push(row[idx]);\n      }\n    } else {\n      inputStream.pos = backtrackPos;\n      break;\n    }\n  }\n  if (numMatches < this.minNumMatches) {\n    return false;\n  }\n  for (idx = 0; idx < columns.length; idx++) {\n    var interval = inputStream.intervalFrom(origPos);\n    state.bindings.push(new Node(state.grammar, '_iter', columns[idx], interval));\n  }\n  return true;\n};\n\npexprs.Not.prototype._eval = function(state, inputStream, origPos) {\n  // TODO:\n  // * Right now we're just throwing away all of the failures that happen inside a `not`,\n  //   and recording `this` as a failed expression.\n  // * Double negation should be equivalent to lookahead, but that's not the case right now wrt\n  //   failures. E.g., ~~'foo' produces a failure for ~~'foo', but maybe it should produce\n  //   a failure for 'foo' instead.\n\n  state.ignoreFailures();\n  var ans = this.expr.eval(state);\n  state.recordFailures();\n  if (ans) {\n    state.bindings.length -= this.getArity();\n    return false;\n  } else {\n    inputStream.pos = origPos;\n    return true;\n  }\n};\n\npexprs.Lookahead.prototype._eval = function(state, inputStream, origPos) {\n  if (this.expr.eval(state)) {\n    inputStream.pos = origPos;\n    return true;\n  } else {\n    return false;\n  }\n};\n\npexprs.Arr.prototype._eval = function(state, inputStream, origPos) {\n  var obj = inputStream.next();\n  if (Array.isArray(obj)) {\n    var objInputStream = InputStream.newFor(obj);\n    state.pushInputStream(objInputStream);\n    var ans = this.expr.eval(state) && state.inputStream.atEnd();\n    state.popInputStream();\n    return ans;\n  } else {\n    return false;\n  }\n};\n\npexprs.Str.prototype._eval = function(state, inputStream, origPos) {\n  var obj = inputStream.next();\n  if (typeof obj === 'string') {\n    var strInputStream = InputStream.newFor(obj);\n    state.pushInputStream(strInputStream);\n    var ans = this.expr.eval(state) && (skipSpacesIfAppropriate(state), state.inputStream.atEnd());\n    state.popInputStream();\n    return ans;\n  } else {\n    return false;\n  }\n};\n\npexprs.Obj.prototype._eval = function(state, inputStream, origPos) {\n  var obj = inputStream.next();\n  if (obj !== common.fail && obj && (typeof obj === 'object' || typeof obj === 'function')) {\n    var numOwnPropertiesMatched = 0;\n    for (var idx = 0; idx < this.properties.length; idx++) {\n      var property = this.properties[idx];\n      if (!obj.hasOwnProperty(property.name)) {\n        return false;\n      }\n      var value = obj[property.name];\n      var valueInputStream = InputStream.newFor([value]);\n      state.pushInputStream(valueInputStream);\n      var matched = property.pattern.eval(state) && state.inputStream.atEnd();\n      state.popInputStream();\n      if (!matched) {\n        return false;\n      }\n      numOwnPropertiesMatched++;\n    }\n    if (this.isLenient) {\n      var remainder = {};\n      for (var p in obj) {\n        if (obj.hasOwnProperty(p) && this.properties.indexOf(p) < 0) {\n          remainder[p] = obj[p];\n        }\n      }\n      var interval = inputStream.intervalFrom(origPos);\n      state.bindings.push(new TerminalNode(state.grammar, remainder, interval));\n      return true;\n    } else {\n      return numOwnPropertiesMatched === Object.keys(obj).length;\n    }\n  } else {\n    return false;\n  }\n};\n\npexprs.Apply.prototype._eval = function(state, inputStream) {\n  var self = this;\n  var grammar = state.grammar;\n  var bindings = state.bindings;\n\n  function useMemoizedResult(memoRecOrLR) {\n    inputStream.pos = memoRecOrLR.pos;\n    if (memoRecOrLR.failureDescriptor) {\n      state.recordFailures(memoRecOrLR.failureDescriptor, self);\n    }\n    if (state.isTracing()) {\n      state.trace.push(memoRecOrLR.traceEntry);\n    }\n    if (memoRecOrLR.value) {\n      bindings.push(memoRecOrLR.value);\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n  var actuals = state.applicationStack.length > 1 ?\n      state.applicationStack[state.applicationStack.length - 1].params :\n      [];\n  var app = this.substituteParams(actuals);\n  var ruleName = app.ruleName;\n  var memoKey = app.toMemoKey();\n\n  if (common.isSyntactic(ruleName)) {\n    skipSpaces(state);\n  }\n\n  var origPosInfo = state.getCurrentPosInfo();\n\n  var memoRec = origPosInfo.memo[memoKey];\n  var currentLR;\n  if (memoRec && origPosInfo.shouldUseMemoizedResult(memoRec)) {\n    return useMemoizedResult(memoRec);\n  } else if (origPosInfo.isActive(app)) {\n    currentLR = origPosInfo.getCurrentLeftRecursion();\n    if (currentLR && currentLR.memoKey === memoKey) {\n      origPosInfo.updateInvolvedApplications();\n      return useMemoizedResult(currentLR);\n    } else {\n      origPosInfo.startLeftRecursion(app);\n      return false;\n    }\n  } else {\n    var body = grammar.ruleDict[ruleName];\n    var origPos = inputStream.pos;\n    origPosInfo.enter(app);\n    if (body.description) {\n      state.ignoreFailures();\n    }\n    var value = app.evalOnce(body, state, inputStream, origPos);\n    currentLR = origPosInfo.getCurrentLeftRecursion();\n    if (currentLR) {\n      if (currentLR.memoKey === memoKey) {\n        value = app.handleLeftRecursion(body, state, origPos, currentLR, value);\n        origPosInfo.memo[memoKey] = {\n          pos: inputStream.pos,\n          value: value,\n          involvedApplications: currentLR.involvedApplications\n        };\n        origPosInfo.endLeftRecursion(app);\n      } else if (!currentLR.involvedApplications[memoKey]) {\n        // Only memoize if this application is not involved in the current left recursion\n        origPosInfo.memo[memoKey] = {pos: inputStream.pos, value: value};\n      }\n    } else {\n      origPosInfo.memo[memoKey] = {pos: inputStream.pos, value: value};\n    }\n    if (body.description) {\n      state.recordFailures();\n      if (!value) {\n        state.recordFailure(origPos, app);\n      }\n    }\n    // Record trace information in the memo table, so that it is\n    // available if the memoized result is used later.\n    if (state.isTracing() && origPosInfo.memo[memoKey]) {\n      var entry = state.getTraceEntry(origPos, app, value);\n      entry.setLeftRecursive(currentLR && (currentLR.memoKey === memoKey));\n      origPosInfo.memo[memoKey].traceEntry = entry;\n    }\n    var ans;\n    if (value) {\n      bindings.push(value);\n      if (state.applicationStack.length === 1) {\n        if (common.isSyntactic(ruleName)) {\n          skipSpaces(state);\n        }\n        ans = pexprs.end.eval(state);\n        bindings.pop();\n      } else {\n        ans = true;\n      }\n    } else {\n      ans = false;\n    }\n\n    origPosInfo.exit();\n    return ans;\n  }\n};\n\npexprs.Apply.prototype.evalOnce = function(expr, state, inputStream, origPos) {\n  if (expr.eval(state)) {\n    var arity = expr.getArity();\n    var bindings = state.bindings.splice(state.bindings.length - arity, arity);\n    var ans = new Node(state.grammar, this.ruleName, bindings, inputStream.intervalFrom(origPos));\n    return ans;\n  } else {\n    return false;\n  }\n};\n\npexprs.Apply.prototype.handleLeftRecursion = function(body, state, origPos, currentLR, seedValue) {\n  if (!seedValue) {\n    return seedValue;\n  }\n\n  var inputStream = state.inputStream;\n  var value = seedValue;\n  currentLR.value = seedValue;\n  currentLR.pos = inputStream.pos;\n\n  while (true) {\n    if (state.isTracing()) {\n      currentLR.traceEntry = common.clone(state.trace[state.trace.length - 1]);\n    }\n\n    inputStream.pos = origPos;\n    value = this.evalOnce(body, state, inputStream, origPos);\n    if (value && inputStream.pos > currentLR.pos) {\n      // The left-recursive result was expanded -- keep looping.\n      currentLR.value = value;\n      currentLR.pos = inputStream.pos;\n    } else {\n      // Failed to expand the result.\n      inputStream.pos = currentLR.pos;\n      if (state.isTracing()) {\n        state.trace.pop();  // Drop last trace entry since `value` was unused.\n      }\n      break;\n    }\n  }\n  return currentLR.value;\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.getArity = function() {\n  return 1;\n};\n\npexprs.Alt.prototype.getArity = function() {\n  // This is ok b/c all terms must have the same arity -- this property is\n  // checked by the Grammar constructor.\n  return this.terms.length === 0 ? 0 : this.terms[0].getArity();\n};\n\npexprs.Seq.prototype.getArity = function() {\n  var arity = 0;\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    arity += this.factors[idx].getArity();\n  }\n  return arity;\n};\n\npexprs.Iter.prototype.getArity = function() {\n  return this.expr.getArity();\n};\n\npexprs.Not.prototype.getArity = function() {\n  return 0;\n};\n\npexprs.Lookahead.prototype.getArity =\npexprs.Arr.prototype.getArity =\npexprs.Str.prototype.getArity = function() {\n  return this.expr.getArity();\n};\n\npexprs.Obj.prototype.getArity = function() {\n  var arity = this.isLenient ? 1 : 0;\n  for (var idx = 0; idx < this.properties.length; idx++) {\n    arity += this.properties[idx].pattern.getArity();\n  }\n  return arity;\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n// NOTE: the `introduceParams` method modifies the receiver in place.\n\npexprs.PExpr.prototype.introduceParams = function(formals) {\n  return this;\n};\n\npexprs.Alt.prototype.introduceParams = function(formals) {\n  this.terms.forEach(function(term, idx, terms) {\n    terms[idx] = term.introduceParams(formals);\n  });\n  return this;\n};\n\npexprs.Seq.prototype.introduceParams = function(formals) {\n  this.factors.forEach(function(factor, idx, factors) {\n    factors[idx] = factor.introduceParams(formals);\n  });\n  return this;\n};\n\npexprs.Iter.prototype.introduceParams =\npexprs.Not.prototype.introduceParams =\npexprs.Lookahead.prototype.introduceParams =\npexprs.Arr.prototype.introduceParams =\npexprs.Str.prototype.introduceParams = function(formals) {\n  this.expr = this.expr.introduceParams(formals);\n  return this;\n};\n\npexprs.Obj.prototype.introduceParams = function(formals) {\n  this.properties.forEach(function(property, idx) {\n    property.pattern = property.pattern.introduceParams(formals);\n  });\n  return this;\n};\n\npexprs.Apply.prototype.introduceParams = function(formals) {\n  var index = formals.indexOf(this.ruleName);\n  if (index >= 0) {\n    if (this.params.length > 0) {\n      throw new Error('FIXME: should catch this earlier');\n    }\n    return new pexprs.Param(index);\n  } else {\n    this.params.forEach(function(param, idx, params) {\n      params[idx] = param.introduceParams(formals);\n    });\n    return this;\n  }\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n// Returns `true` if this parsing expression may accept without consuming any input.\npexprs.PExpr.prototype.isNullable = function(grammar) {\n  return this._isNullable(grammar, Object.create(null));\n};\n\npexprs.PExpr.prototype._isNullable = function(grammar, memo) {\n  return false;\n};\n\npexprs.end._isNullable = function(grammar, memo) {\n  return true;\n};\n\npexprs.StringPrim.prototype._isNullable = function(grammar, memo) {\n  // This is an over-simplification: it's only correct if the input is a string. If it's an array\n  // or an object, then the empty string parsing expression is not nullable.\n  return this.obj === '';\n};\n\npexprs.Alt.prototype._isNullable = function(grammar, memo) {\n  return this.terms.length === 0 ||\n      this.terms.some(function(term) { return term._isNullable(grammar, memo); });\n};\n\npexprs.Seq.prototype._isNullable = function(grammar, memo) {\n  return this.factors.every(function(factor) { return factor._isNullable(grammar, memo); });\n};\n\npexprs.Star.prototype._isNullable =\npexprs.Opt.prototype._isNullable =\npexprs.Not.prototype._isNullable =\npexprs.Lookahead.prototype._isNullable = function(grammar, memo) {\n  return true;\n};\n\npexprs.Str.prototype._isNullable = function(grammar, memo) {\n  // This is also an over-simplification that is only correct when the input is a string.\n  return this.expr._isNullable(grammar, memo);\n};\n\npexprs.Apply.prototype._isNullable = function(grammar, memo) {\n  var key = this.toMemoKey();\n  if (!Object.prototype.hasOwnProperty.call(memo, key)) {\n    var body = grammar.ruleDict[this.ruleName];\n    var inlined = body.substituteParams(this.params);\n    memo[key] = false;\n    memo[key] = inlined._isNullable(grammar, memo);\n  }\n  return memo[key];\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n// Do nothing by default.\npexprs.PExpr.prototype.maybeRecordFailure = function(state, startPos) {\n};\n\n// For PExprs that directly consume input, record the failure in the state object.\npexprs.anything.maybeRecordFailure =\npexprs.end.maybeRecordFailure =\npexprs.Prim.prototype.maybeRecordFailure =\npexprs.Not.prototype.maybeRecordFailure = function(state, startPos) {\n  state.recordFailure(startPos, this);\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.outputRecipe = common.abstract;\n\npexprs.anything.outputRecipe = function(sb, formals) {\n  sb.append('this.anything()');\n};\n\npexprs.end.outputRecipe = function(sb, formals) {\n  sb.append('this.end()');\n};\n\npexprs.Prim.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.prim(');\n  sb.append(typeof this.obj === 'string' ? common.toStringLiteral(this.obj) : '' + this.obj);\n  sb.append(')');\n};\n\npexprs.Param.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.param(' + this.index + ')');\n};\n\npexprs.Alt.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.alt(');\n  for (var idx = 0; idx < this.terms.length; idx++) {\n    if (idx > 0) {\n      sb.append(', ');\n    }\n    this.terms[idx].outputRecipe(sb, formals);\n  }\n  sb.append(')');\n};\n\npexprs.Seq.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.seq(');\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    if (idx > 0) {\n      sb.append(', ');\n    }\n    this.factors[idx].outputRecipe(sb, formals);\n  }\n  sb.append(')');\n};\n\npexprs.Star.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.star(');\n  this.expr.outputRecipe(sb, formals);\n  sb.append(')');\n};\n\npexprs.Plus.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.plus(');\n  this.expr.outputRecipe(sb, formals);\n  sb.append(')');\n};\n\npexprs.Opt.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.opt(');\n  this.expr.outputRecipe(sb, formals);\n  sb.append(')');\n};\n\npexprs.Not.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.not(');\n  this.expr.outputRecipe(sb, formals);\n  sb.append(')');\n};\n\npexprs.Lookahead.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.la(');\n  this.expr.outputRecipe(sb, formals);\n  sb.append(')');\n};\n\npexprs.Arr.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.arr(');\n  this.expr.outputRecipe(sb, formals);\n  sb.append(')');\n};\n\npexprs.Str.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.str(');\n  this.expr.outputRecipe(sb, formals);\n  sb.append(')');\n};\n\npexprs.Obj.prototype.outputRecipe = function(sb, formals) {\n  function outputPropertyRecipe(prop) {\n    sb.append('{name: ');\n    sb.append(common.toStringLiteral(prop.name));\n    sb.append(', pattern: ');\n    prop.pattern.outputRecipe(sb, formals);\n    sb.append('}');\n  }\n\n  sb.append('this.obj([');\n  for (var idx = 0; idx < this.properties.length; idx++) {\n    if (idx > 0) {\n      sb.append(', ');\n    }\n    outputPropertyRecipe(this.properties[idx]);\n  }\n  sb.append('], ');\n  sb.append(!!this.isLenient);\n  sb.append(')');\n};\n\npexprs.Apply.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.app(');\n  sb.append(common.toStringLiteral(this.ruleName));\n  if (this.ruleName.indexOf('_') >= 0 && formals.length > 0) {\n    var apps = formals.\n        map(function(formal) { return 'this.app(' + common.toStringLiteral(formal) + ')'; });\n    sb.append(', [' + apps.join(', ') + ']');\n  } else if (this.params.length > 0) {\n    sb.append(', [');\n    this.params.forEach(function(param, idx) {\n      if (idx > 0) {\n        sb.append(', ');\n      }\n      param.outputRecipe(sb, formals);\n    });\n    sb.append(']');\n  }\n  sb.append(')');\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.substituteParams = function(actuals) {\n  return this;\n};\n\npexprs.Param.prototype.substituteParams = function(actuals) {\n  return actuals[this.index];\n};\n\npexprs.Alt.prototype.substituteParams = function(actuals) {\n  return new pexprs.Alt(\n      this.terms.map(function(term) { return term.substituteParams(actuals); }));\n};\n\npexprs.Seq.prototype.substituteParams = function(actuals) {\n  return new pexprs.Seq(\n      this.factors.map(function(factor) { return factor.substituteParams(actuals); }));\n};\n\npexprs.Iter.prototype.substituteParams =\npexprs.Not.prototype.substituteParams =\npexprs.Lookahead.prototype.substituteParams =\npexprs.Arr.prototype.substituteParams =\npexprs.Str.prototype.substituteParams = function(actuals) {\n  return new this.constructor(this.expr.substituteParams(actuals));\n};\n\npexprs.Obj.prototype.substituteParams = function(actuals) {\n  var properties = this.properties.map(function(property) {\n    return {\n      name: property.name,\n      pattern: property.pattern.substituteParams(actuals)\n    };\n  });\n  return new pexprs.Obj(properties, this.isLenient);\n};\n\npexprs.Apply.prototype.substituteParams = function(actuals) {\n  if (this.params.length === 0) {\n    // Avoid making a copy of this application, as an optimization\n    return this;\n  } else {\n    var params = this.params.map(function(param) { return param.substituteParams(actuals); });\n    return new pexprs.Apply(this.ruleName, params);\n  }\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n// Returns a string representing the PExpr, for use as a UI label, etc.\npexprs.PExpr.prototype.toDisplayString = function() {\n  if (this.interval) {\n    return this.interval.trimmed().contents;\n  }\n  return '[' + this.constructor.name + ']';\n};\n\npexprs.anything.toDisplayString = function() {\n  return '_';\n};\n\npexprs.end.toDisplayString = function() {\n  return 'end';\n};\n\npexprs.Prim.prototype.toDisplayString = function() {\n  return String(this.obj);\n};\n\npexprs.Param.prototype.toDisplayString = function() {\n  return '#' + this.index;\n};\n\npexprs.StringPrim.prototype.toDisplayString = function() {\n  return '\"' + this.obj + '\"';\n};\n\npexprs.Apply.prototype.toDisplayString = function() {\n  return this.ruleName;\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.toExpected = function(ruleDict) {\n  return undefined;\n};\n\npexprs.anything.toExpected = function(ruleDict) {\n  return 'any object';\n};\n\npexprs.end.toExpected = function(ruleDict) {\n  return 'end of input';\n};\n\npexprs.Prim.prototype.toExpected = function(ruleDict) {\n  return common.toStringLiteral(this.obj);\n};\n\npexprs.Not.prototype.toExpected = function(ruleDict) {\n  if (this.expr === pexprs.anything) {\n    return 'nothing';\n  } else {\n    return 'not ' + this.expr.toExpected(ruleDict);\n  }\n};\n\n// TODO: think about Arr, Str, and Obj\n\npexprs.Apply.prototype.toExpected = function(ruleDict) {\n  var description = ruleDict[this.ruleName].description;\n  if (description) {\n    return description;\n  } else {\n    var article = (/^[aeiouAEIOU]/.test(this.ruleName) ? 'an' : 'a');\n    return article + ' ' + this.ruleName;\n  }\n};\n\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n/*\n  e1.toString() === e2.toString() ==> e1 and e2 are semantically equivalent.\n  Note that this is not an iff (<==>): e.g.,\n  (~\"b\" \"a\").toString() !== (\"a\").toString(), even though\n  ~\"b\" \"a\" and \"a\" are interchangeable in any grammar,\n  both in terms of the languages they accept and their arities.\n*/\npexprs.PExpr.prototype.toString = common.abstract;\n\npexprs.anything.toString = function() {\n  return '_';\n};\n\npexprs.end.toString = function() {\n  return 'end';\n};\n\npexprs.Prim.prototype.toString = function() {\n  return JSON.stringify(this.obj);\n};\n\npexprs.Param.prototype.toString = function() {\n  return '#' + this.index;\n};\n\npexprs.RegExpPrim.prototype.toString = function() {\n  return this.obj.toString();\n};\n\npexprs.Alt.prototype.toString = function() {\n  return this.terms.length === 1 ?\n    this.terms[0].toString() :\n    '(' + this.terms.map(function(term) { return term.toString(); }).join(' | ') + ')';\n};\n\npexprs.Seq.prototype.toString = function() {\n  return this.factors.length === 1 ?\n    this.factors[0].toString() :\n    '(' + this.factors.map(function(factor) { return factor.toString(); }).join(' ') + ')';\n};\n\npexprs.Iter.prototype.toString = function() {\n  return this.expr + this.operator;\n};\n\npexprs.Not.prototype.toString = function() {\n  return '~' + this.expr;\n};\n\npexprs.Lookahead.prototype.toString = function() {\n  return '&' + this.expr;\n};\n\npexprs.Arr.prototype.toString = function() {\n  return '[' + this.expr.toString() + ']';\n};\n\npexprs.Str.prototype.toString = function() {\n  return '``' + this.expr.toString() + \"''\";\n};\n\npexprs.Obj.prototype.toString = function() {\n  var parts = ['{'];\n\n  var first = true;\n  function emit(part) {\n    if (first) {\n      first = false;\n    } else {\n      parts.push(', ');\n    }\n    parts.push(part);\n  }\n\n  this.properties.forEach(function(property) {\n    emit(JSON.stringify(property.name) + ': ' + property.pattern.toString());\n  });\n  if (this.isLenient) {\n    emit('...');\n  }\n\n  parts.push('}');\n  return parts.join('');\n};\n\npexprs.Apply.prototype.toString = function() {\n  if (this.params.length > 0) {\n    var ps = this.params.map(function(param) { return param.toString(); });\n    return this.ruleName + '<' + ps.join(',') + '>';\n  } else {\n    return this.ruleName;\n  }\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar errors = require('./errors');\nvar inherits = require('inherits');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// General stuff\n\nfunction PExpr() {\n  throw new Error(\"PExpr cannot be instantiated -- it's abstract\");\n}\n\nPExpr.prototype.withDescription = function(description) {\n  this.description = description;\n  return this;\n};\n\nPExpr.prototype.withInterval = function(interval) {\n  this.interval = interval.trimmed();\n  return this;\n};\n\nPExpr.prototype.withFormals = function(formals) {\n  this.formals = formals;\n  return this;\n};\n\n// Anything\n\nvar anything = Object.create(PExpr.prototype);\n\n// End\n\nvar end = Object.create(PExpr.prototype);\n\n// Primitives\n\nfunction Prim(obj) {\n  this.obj = obj;\n}\ninherits(Prim, PExpr);\n\nfunction StringPrim(obj) {\n  this.obj = obj;\n}\ninherits(StringPrim, Prim);\n\nfunction RegExpPrim(obj) {\n  this.obj = obj;\n}\ninherits(RegExpPrim, Prim);\n\n// Parameters\n\nfunction Param(index) {\n  this.index = index;\n}\ninherits(Param, PExpr);\n\n// Alternation\n\nfunction Alt(terms) {\n  this.terms = terms;\n}\ninherits(Alt, PExpr);\n\n// Extend is an implementation detail of rule extension\n\nfunction Extend(superGrammar, name, body) {\n  var origBody = superGrammar.ruleDict[name];\n  this.terms = [body, origBody];\n}\ninherits(Extend, Alt);\n\n// Sequences\n\nfunction Seq(factors) {\n  this.factors = factors;\n}\ninherits(Seq, PExpr);\n\n// Iterators and optionals\n\nfunction Iter(expr) {\n  this.expr = expr;\n}\ninherits(Iter, PExpr);\n\nfunction Star(expr) {\n  this.expr = expr;\n}\ninherits(Star, Iter);\n\nfunction Plus(expr) {\n  this.expr = expr;\n}\ninherits(Plus, Iter);\n\nfunction Opt(expr) {\n  this.expr = expr;\n}\ninherits(Opt, Iter);\n\nStar.prototype.operator = '*';\nPlus.prototype.operator = '+';\nOpt.prototype.operator = '?';\n\nStar.prototype.minNumMatches = 0;\nPlus.prototype.minNumMatches = 1;\nOpt.prototype.minNumMatches = 0;\n\nStar.prototype.maxNumMatches = Number.POSITIVE_INFINITY;\nPlus.prototype.maxNumMatches = Number.POSITIVE_INFINITY;\nOpt.prototype.maxNumMatches = 1;\n\n// Predicates\n\nfunction Not(expr) {\n  this.expr = expr;\n}\ninherits(Not, PExpr);\n\nfunction Lookahead(expr) {\n  this.expr = expr;\n}\ninherits(Lookahead, PExpr);\n\n// Array decomposition\n\nfunction Arr(expr) {\n  this.expr = expr;\n}\ninherits(Arr, PExpr);\n\n// String decomposition\n\nfunction Str(expr) {\n  this.expr = expr;\n}\ninherits(Str, PExpr);\n\n// Object decomposition\n\nfunction Obj(properties, isLenient) {\n  var names = properties.map(function(property) { return property.name; });\n  var duplicates = common.getDuplicates(names);\n  if (duplicates.length > 0) {\n    throw new errors.DuplicatePropertyNames(duplicates);\n  } else {\n    this.properties = properties;\n    this.isLenient = isLenient;\n  }\n}\ninherits(Obj, PExpr);\n\n// Rule application\n\nfunction Apply(ruleName, optParams) {\n  this.ruleName = ruleName;\n  this.params = optParams || [];\n}\ninherits(Apply, PExpr);\n\n// This method just caches the result of `this.toString()` in a non-enumerable property.\nApply.prototype.toMemoKey = function() {\n  if (!this._memoKey) {\n    Object.defineProperty(this, '_memoKey', {value: this.toString()});\n  }\n  return this._memoKey;\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nexports.makePrim = function(obj) {\n  if (typeof obj === 'string' && obj.length !== 1) {\n    return new StringPrim(obj);\n  } else if (obj instanceof RegExp) {\n    return new RegExpPrim(obj);\n  } else {\n    return new Prim(obj);\n  }\n};\n\nexports.PExpr = PExpr;\nexports.anything = anything;\nexports.end = end;\nexports.Prim = Prim;\nexports.StringPrim = StringPrim;\nexports.RegExpPrim = RegExpPrim;\nexports.Param = Param;\nexports.Alt = Alt;\nexports.Extend = Extend;\nexports.Seq = Seq;\nexports.Iter = Iter;\nexports.Star = Star;\nexports.Plus = Plus;\nexports.Opt = Opt;\nexports.Not = Not;\nexports.Lookahead = Lookahead;\nexports.Arr = Arr;\nexports.Str = Str;\nexports.Obj = Obj;\nexports.Apply = Apply;\n\n// --------------------------------------------------------------------\n// Extensions\n// --------------------------------------------------------------------\n\nrequire('./pexprs-assertAllApplicationsAreValid');\nrequire('./pexprs-assertChoicesHaveUniformArity');\nrequire('./pexprs-assertIteratedExprsAreNotNullable');\nrequire('./pexprs-check');\nrequire('./pexprs-eval');\nrequire('./pexprs-maybeRecordFailure');\nrequire('./pexprs-getArity');\nrequire('./pexprs-outputRecipe');\nrequire('./pexprs-introduceParams');\nrequire('./pexprs-isNullable');\nrequire('./pexprs-substituteParams');\nrequire('./pexprs-toDisplayString');\nrequire('./pexprs-toExpected');\nrequire('./pexprs-toString');\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// Given an array of numbers `arr`, return an array of the numbers as strings,\n// right-justified and padded to the same length.\nfunction padNumbersToEqualLength(arr) {\n  var maxLen = 0;\n  var strings = arr.map(function(n) {\n    var str = n.toString();\n    maxLen = Math.max(maxLen, str.length);\n    return str;\n  });\n  return strings.map(function(s) { return common.padLeft(s, maxLen); });\n}\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\n// Return an object with the line and column information for the given\n// offset in `str`.\nexports.getLineAndColumn = function(str, offset) {\n  var lineNum = 1;\n  var colNum = 1;\n\n  var currOffset = 0;\n  var lineStartOffset = 0;\n\n  var nextLine = null;\n  var prevLine = null;\n  var prevLineStartOffset = -1;\n\n  while (currOffset < offset) {\n    var c = str.charAt(currOffset++);\n    if (c === '\\n') {\n      lineNum++;\n      colNum = 1;\n      prevLineStartOffset = lineStartOffset;\n      lineStartOffset = currOffset;\n    } else if (c !== '\\r') {\n      colNum++;\n    }\n  }\n\n  // Find the end of the target line.\n  var lineEndOffset = str.indexOf('\\n', lineStartOffset);\n  if (lineEndOffset === -1) {\n    lineEndOffset = str.length;\n  } else {\n    // Get the next line.\n    var nextLineEndOffset = str.indexOf('\\n', lineEndOffset + 1);\n    nextLine = nextLineEndOffset === -1 ? str.slice(lineEndOffset)\n                                        : str.slice(lineEndOffset, nextLineEndOffset);\n    // Strip leading and trailing EOL char(s).\n    nextLine = nextLine.replace(/^\\r?\\n/, '').replace(/\\r$/, '');\n  }\n\n  // Get the previous line.\n  if (prevLineStartOffset >= 0) {\n    prevLine = str.slice(prevLineStartOffset, lineStartOffset)\n                  .replace(/\\r?\\n$/, '');  // Strip trailing EOL char(s).\n  }\n\n  // Get the target line, stripping a trailing carriage return if necessary.\n  var line = str.slice(lineStartOffset, lineEndOffset).replace(/\\r$/, '');\n\n  return {\n    lineNum: lineNum,\n    colNum: colNum,\n    line: line,\n    prevLine: prevLine,\n    nextLine: nextLine\n  };\n};\n\n// Return a nicely-formatted string describing the line and column for the\n// given offset in `str`.\nexports.getLineAndColumnMessage = function(str, offset) {\n  var lineAndCol = exports.getLineAndColumn(str, offset);\n  var sb = new common.StringBuffer();\n  sb.append('Line ' + lineAndCol.lineNum + ', col ' + lineAndCol.colNum + ':\\n');\n\n  // An array of the previous, current, and next line numbers as strings of equal length.\n  var lineNumbers = padNumbersToEqualLength([\n      lineAndCol.prevLine == null ? 0 : lineAndCol.lineNum - 1,\n      lineAndCol.lineNum,\n      lineAndCol.nextLine == null ? 0 : lineAndCol.lineNum + 1\n  ]);\n\n  // Helper for appending formatting input lines to the buffer.\n  function appendLine(num, content, prefix) {\n    sb.append(prefix + lineNumbers[num] + ' | ' + content + '\\n');\n  }\n\n  // Include the previous line for context if possible.\n  if (lineAndCol.prevLine != null) {\n    appendLine(0, lineAndCol.prevLine, '  ');\n  }\n  // Line that the error occurred on.\n  appendLine(1, lineAndCol.line, '> ');\n\n  // Line indicating the column on which the error occurred.\n  var gutterWidth = 2 + lineNumbers[1].length + 3;\n  sb.append(common.padLeft('^', gutterWidth + lineAndCol.colNum) + '\\n');\n\n  // Include the next line for context if possible.\n  if (lineAndCol.nextLine != null) {\n    appendLine(2, lineAndCol.nextLine, '  ');\n  }\n  return sb.contents();\n};\n","// From https://code.google.com/p/es-lab/source/browse/trunk/src/parser/unicode.js\nexports.UnicodeCategories = {\n  ZWNJ : /\\u200C/,\n  ZWJ  : /\\u200D/,\n  TAB  : /\\u0009/,\n  VT   : /\\u000B/,\n  FF   : /\\u000C/,\n  SP   : /\\u0020/,\n  NBSP : /\\u00A0/,\n  BOM  : /\\uFEFF/,\n  LF   : /\\u000A/,\n  CR   : /\\u000D/,\n  LS   : /\\u2028/,\n  PS   : /\\u2029/,\n  L    : /[\\u0041-\\u005A]|[\\u00C0-\\u00D6]|[\\u00D8-\\u00DE]|[\\u0100-\\u0100]|[\\u0102-\\u0102]|[\\u0104-\\u0104]|[\\u0106-\\u0106]|[\\u0108-\\u0108]|[\\u010A-\\u010A]|[\\u010C-\\u010C]|[\\u010E-\\u010E]|[\\u0110-\\u0110]|[\\u0112-\\u0112]|[\\u0114-\\u0114]|[\\u0116-\\u0116]|[\\u0118-\\u0118]|[\\u011A-\\u011A]|[\\u011C-\\u011C]|[\\u011E-\\u011E]|[\\u0120-\\u0120]|[\\u0122-\\u0122]|[\\u0124-\\u0124]|[\\u0126-\\u0126]|[\\u0128-\\u0128]|[\\u012A-\\u012A]|[\\u012C-\\u012C]|[\\u012E-\\u012E]|[\\u0130-\\u0130]|[\\u0132-\\u0132]|[\\u0134-\\u0134]|[\\u0136-\\u0136]|[\\u0139-\\u0139]|[\\u013B-\\u013B]|[\\u013D-\\u013D]|[\\u013F-\\u013F]|[\\u0141-\\u0141]|[\\u0143-\\u0143]|[\\u0145-\\u0145]|[\\u0147-\\u0147]|[\\u014A-\\u014A]|[\\u014C-\\u014C]|[\\u014E-\\u014E]|[\\u0150-\\u0150]|[\\u0152-\\u0152]|[\\u0154-\\u0154]|[\\u0156-\\u0156]|[\\u0158-\\u0158]|[\\u015A-\\u015A]|[\\u015C-\\u015C]|[\\u015E-\\u015E]|[\\u0160-\\u0160]|[\\u0162-\\u0162]|[\\u0164-\\u0164]|[\\u0166-\\u0166]|[\\u0168-\\u0168]|[\\u016A-\\u016A]|[\\u016C-\\u016C]|[\\u016E-\\u016E]|[\\u0170-\\u0170]|[\\u0172-\\u0172]|[\\u0174-\\u0174]|[\\u0176-\\u0176]|[\\u0178-\\u0179]|[\\u017B-\\u017B]|[\\u017D-\\u017D]|[\\u0181-\\u0182]|[\\u0184-\\u0184]|[\\u0186-\\u0187]|[\\u0189-\\u018B]|[\\u018E-\\u0191]|[\\u0193-\\u0194]|[\\u0196-\\u0198]|[\\u019C-\\u019D]|[\\u019F-\\u01A0]|[\\u01A2-\\u01A2]|[\\u01A4-\\u01A4]|[\\u01A6-\\u01A7]|[\\u01A9-\\u01A9]|[\\u01AC-\\u01AC]|[\\u01AE-\\u01AF]|[\\u01B1-\\u01B3]|[\\u01B5-\\u01B5]|[\\u01B7-\\u01B8]|[\\u01BC-\\u01BC]|[\\u01C4-\\u01C4]|[\\u01C7-\\u01C7]|[\\u01CA-\\u01CA]|[\\u01CD-\\u01CD]|[\\u01CF-\\u01CF]|[\\u01D1-\\u01D1]|[\\u01D3-\\u01D3]|[\\u01D5-\\u01D5]|[\\u01D7-\\u01D7]|[\\u01D9-\\u01D9]|[\\u01DB-\\u01DB]|[\\u01DE-\\u01DE]|[\\u01E0-\\u01E0]|[\\u01E2-\\u01E2]|[\\u01E4-\\u01E4]|[\\u01E6-\\u01E6]|[\\u01E8-\\u01E8]|[\\u01EA-\\u01EA]|[\\u01EC-\\u01EC]|[\\u01EE-\\u01EE]|[\\u01F1-\\u01F1]|[\\u01F4-\\u01F4]|[\\u01FA-\\u01FA]|[\\u01FC-\\u01FC]|[\\u01FE-\\u01FE]|[\\u0200-\\u0200]|[\\u0202-\\u0202]|[\\u0204-\\u0204]|[\\u0206-\\u0206]|[\\u0208-\\u0208]|[\\u020A-\\u020A]|[\\u020C-\\u020C]|[\\u020E-\\u020E]|[\\u0210-\\u0210]|[\\u0212-\\u0212]|[\\u0214-\\u0214]|[\\u0216-\\u0216]|[\\u0386-\\u0386]|[\\u0388-\\u038A]|[\\u038C-\\u038C]|[\\u038E-\\u038F]|[\\u0391-\\u03A1]|[\\u03A3-\\u03AB]|[\\u03D2-\\u03D4]|[\\u03DA-\\u03DA]|[\\u03DC-\\u03DC]|[\\u03DE-\\u03DE]|[\\u03E0-\\u03E0]|[\\u03E2-\\u03E2]|[\\u03E4-\\u03E4]|[\\u03E6-\\u03E6]|[\\u03E8-\\u03E8]|[\\u03EA-\\u03EA]|[\\u03EC-\\u03EC]|[\\u03EE-\\u03EE]|[\\u0401-\\u040C]|[\\u040E-\\u042F]|[\\u0460-\\u0460]|[\\u0462-\\u0462]|[\\u0464-\\u0464]|[\\u0466-\\u0466]|[\\u0468-\\u0468]|[\\u046A-\\u046A]|[\\u046C-\\u046C]|[\\u046E-\\u046E]|[\\u0470-\\u0470]|[\\u0472-\\u0472]|[\\u0474-\\u0474]|[\\u0476-\\u0476]|[\\u0478-\\u0478]|[\\u047A-\\u047A]|[\\u047C-\\u047C]|[\\u047E-\\u047E]|[\\u0480-\\u0480]|[\\u0490-\\u0490]|[\\u0492-\\u0492]|[\\u0494-\\u0494]|[\\u0496-\\u0496]|[\\u0498-\\u0498]|[\\u049A-\\u049A]|[\\u049C-\\u049C]|[\\u049E-\\u049E]|[\\u04A0-\\u04A0]|[\\u04A2-\\u04A2]|[\\u04A4-\\u04A4]|[\\u04A6-\\u04A6]|[\\u04A8-\\u04A8]|[\\u04AA-\\u04AA]|[\\u04AC-\\u04AC]|[\\u04AE-\\u04AE]|[\\u04B0-\\u04B0]|[\\u04B2-\\u04B2]|[\\u04B4-\\u04B4]|[\\u04B6-\\u04B6]|[\\u04B8-\\u04B8]|[\\u04BA-\\u04BA]|[\\u04BC-\\u04BC]|[\\u04BE-\\u04BE]|[\\u04C1-\\u04C1]|[\\u04C3-\\u04C3]|[\\u04C7-\\u04C7]|[\\u04CB-\\u04CB]|[\\u04D0-\\u04D0]|[\\u04D2-\\u04D2]|[\\u04D4-\\u04D4]|[\\u04D6-\\u04D6]|[\\u04D8-\\u04D8]|[\\u04DA-\\u04DA]|[\\u04DC-\\u04DC]|[\\u04DE-\\u04DE]|[\\u04E0-\\u04E0]|[\\u04E2-\\u04E2]|[\\u04E4-\\u04E4]|[\\u04E6-\\u04E6]|[\\u04E8-\\u04E8]|[\\u04EA-\\u04EA]|[\\u04EE-\\u04EE]|[\\u04F0-\\u04F0]|[\\u04F2-\\u04F2]|[\\u04F4-\\u04F4]|[\\u04F8-\\u04F8]|[\\u0531-\\u0556]|[\\u10A0-\\u10C5]|[\\u1E00-\\u1E00]|[\\u1E02-\\u1E02]|[\\u1E04-\\u1E04]|[\\u1E06-\\u1E06]|[\\u1E08-\\u1E08]|[\\u1E0A-\\u1E0A]|[\\u1E0C-\\u1E0C]|[\\u1E0E-\\u1E0E]|[\\u1E10-\\u1E10]|[\\u1E12-\\u1E12]|[\\u1E14-\\u1E14]|[\\u1E16-\\u1E16]|[\\u1E18-\\u1E18]|[\\u1E1A-\\u1E1A]|[\\u1E1C-\\u1E1C]|[\\u1E1E-\\u1E1E]|[\\u1E20-\\u1E20]|[\\u1E22-\\u1E22]|[\\u1E24-\\u1E24]|[\\u1E26-\\u1E26]|[\\u1E28-\\u1E28]|[\\u1E2A-\\u1E2A]|[\\u1E2C-\\u1E2C]|[\\u1E2E-\\u1E2E]|[\\u1E30-\\u1E30]|[\\u1E32-\\u1E32]|[\\u1E34-\\u1E34]|[\\u1E36-\\u1E36]|[\\u1E38-\\u1E38]|[\\u1E3A-\\u1E3A]|[\\u1E3C-\\u1E3C]|[\\u1E3E-\\u1E3E]|[\\u1E40-\\u1E40]|[\\u1E42-\\u1E42]|[\\u1E44-\\u1E44]|[\\u1E46-\\u1E46]|[\\u1E48-\\u1E48]|[\\u1E4A-\\u1E4A]|[\\u1E4C-\\u1E4C]|[\\u1E4E-\\u1E4E]|[\\u1E50-\\u1E50]|[\\u1E52-\\u1E52]|[\\u1E54-\\u1E54]|[\\u1E56-\\u1E56]|[\\u1E58-\\u1E58]|[\\u1E5A-\\u1E5A]|[\\u1E5C-\\u1E5C]|[\\u1E5E-\\u1E5E]|[\\u1E60-\\u1E60]|[\\u1E62-\\u1E62]|[\\u1E64-\\u1E64]|[\\u1E66-\\u1E66]|[\\u1E68-\\u1E68]|[\\u1E6A-\\u1E6A]|[\\u1E6C-\\u1E6C]|[\\u1E6E-\\u1E6E]|[\\u1E70-\\u1E70]|[\\u1E72-\\u1E72]|[\\u1E74-\\u1E74]|[\\u1E76-\\u1E76]|[\\u1E78-\\u1E78]|[\\u1E7A-\\u1E7A]|[\\u1E7C-\\u1E7C]|[\\u1E7E-\\u1E7E]|[\\u1E80-\\u1E80]|[\\u1E82-\\u1E82]|[\\u1E84-\\u1E84]|[\\u1E86-\\u1E86]|[\\u1E88-\\u1E88]|[\\u1E8A-\\u1E8A]|[\\u1E8C-\\u1E8C]|[\\u1E8E-\\u1E8E]|[\\u1E90-\\u1E90]|[\\u1E92-\\u1E92]|[\\u1E94-\\u1E94]|[\\u1EA0-\\u1EA0]|[\\u1EA2-\\u1EA2]|[\\u1EA4-\\u1EA4]|[\\u1EA6-\\u1EA6]|[\\u1EA8-\\u1EA8]|[\\u1EAA-\\u1EAA]|[\\u1EAC-\\u1EAC]|[\\u1EAE-\\u1EAE]|[\\u1EB0-\\u1EB0]|[\\u1EB2-\\u1EB2]|[\\u1EB4-\\u1EB4]|[\\u1EB6-\\u1EB6]|[\\u1EB8-\\u1EB8]|[\\u1EBA-\\u1EBA]|[\\u1EBC-\\u1EBC]|[\\u1EBE-\\u1EBE]|[\\u1EC0-\\u1EC0]|[\\u1EC2-\\u1EC2]|[\\u1EC4-\\u1EC4]|[\\u1EC6-\\u1EC6]|[\\u1EC8-\\u1EC8]|[\\u1ECA-\\u1ECA]|[\\u1ECC-\\u1ECC]|[\\u1ECE-\\u1ECE]|[\\u1ED0-\\u1ED0]|[\\u1ED2-\\u1ED2]|[\\u1ED4-\\u1ED4]|[\\u1ED6-\\u1ED6]|[\\u1ED8-\\u1ED8]|[\\u1EDA-\\u1EDA]|[\\u1EDC-\\u1EDC]|[\\u1EDE-\\u1EDE]|[\\u1EE0-\\u1EE0]|[\\u1EE2-\\u1EE2]|[\\u1EE4-\\u1EE4]|[\\u1EE6-\\u1EE6]|[\\u1EE8-\\u1EE8]|[\\u1EEA-\\u1EEA]|[\\u1EEC-\\u1EEC]|[\\u1EEE-\\u1EEE]|[\\u1EF0-\\u1EF0]|[\\u1EF2-\\u1EF2]|[\\u1EF4-\\u1EF4]|[\\u1EF6-\\u1EF6]|[\\u1EF8-\\u1EF8]|[\\u1F08-\\u1F0F]|[\\u1F18-\\u1F1D]|[\\u1F28-\\u1F2F]|[\\u1F38-\\u1F3F]|[\\u1F48-\\u1F4D]|[\\u1F59-\\u1F59]|[\\u1F5B-\\u1F5B]|[\\u1F5D-\\u1F5D]|[\\u1F5F-\\u1F5F]|[\\u1F68-\\u1F6F]|[\\u1F88-\\u1F8F]|[\\u1F98-\\u1F9F]|[\\u1FA8-\\u1FAF]|[\\u1FB8-\\u1FBC]|[\\u1FC8-\\u1FCC]|[\\u1FD8-\\u1FDB]|[\\u1FE8-\\u1FEC]|[\\u1FF8-\\u1FFC]|[\\u2102-\\u2102]|[\\u2107-\\u2107]|[\\u210B-\\u210D]|[\\u2110-\\u2112]|[\\u2115-\\u2115]|[\\u2119-\\u211D]|[\\u2124-\\u2124]|[\\u2126-\\u2126]|[\\u2128-\\u2128]|[\\u212A-\\u212D]|[\\u2130-\\u2131]|[\\u2133-\\u2133]|[\\uFF21-\\uFF3A]|[\\u0061-\\u007A]|[\\u00AA-\\u00AA]|[\\u00B5-\\u00B5]|[\\u00BA-\\u00BA]|[\\u00DF-\\u00F6]|[\\u00F8-\\u00FF]|[\\u0101-\\u0101]|[\\u0103-\\u0103]|[\\u0105-\\u0105]|[\\u0107-\\u0107]|[\\u0109-\\u0109]|[\\u010B-\\u010B]|[\\u010D-\\u010D]|[\\u010F-\\u010F]|[\\u0111-\\u0111]|[\\u0113-\\u0113]|[\\u0115-\\u0115]|[\\u0117-\\u0117]|[\\u0119-\\u0119]|[\\u011B-\\u011B]|[\\u011D-\\u011D]|[\\u011F-\\u011F]|[\\u0121-\\u0121]|[\\u0123-\\u0123]|[\\u0125-\\u0125]|[\\u0127-\\u0127]|[\\u0129-\\u0129]|[\\u012B-\\u012B]|[\\u012D-\\u012D]|[\\u012F-\\u012F]|[\\u0131-\\u0131]|[\\u0133-\\u0133]|[\\u0135-\\u0135]|[\\u0137-\\u0138]|[\\u013A-\\u013A]|[\\u013C-\\u013C]|[\\u013E-\\u013E]|[\\u0140-\\u0140]|[\\u0142-\\u0142]|[\\u0144-\\u0144]|[\\u0146-\\u0146]|[\\u0148-\\u0149]|[\\u014B-\\u014B]|[\\u014D-\\u014D]|[\\u014F-\\u014F]|[\\u0151-\\u0151]|[\\u0153-\\u0153]|[\\u0155-\\u0155]|[\\u0157-\\u0157]|[\\u0159-\\u0159]|[\\u015B-\\u015B]|[\\u015D-\\u015D]|[\\u015F-\\u015F]|[\\u0161-\\u0161]|[\\u0163-\\u0163]|[\\u0165-\\u0165]|[\\u0167-\\u0167]|[\\u0169-\\u0169]|[\\u016B-\\u016B]|[\\u016D-\\u016D]|[\\u016F-\\u016F]|[\\u0171-\\u0171]|[\\u0173-\\u0173]|[\\u0175-\\u0175]|[\\u0177-\\u0177]|[\\u017A-\\u017A]|[\\u017C-\\u017C]|[\\u017E-\\u0180]|[\\u0183-\\u0183]|[\\u0185-\\u0185]|[\\u0188-\\u0188]|[\\u018C-\\u018D]|[\\u0192-\\u0192]|[\\u0195-\\u0195]|[\\u0199-\\u019B]|[\\u019E-\\u019E]|[\\u01A1-\\u01A1]|[\\u01A3-\\u01A3]|[\\u01A5-\\u01A5]|[\\u01A8-\\u01A8]|[\\u01AB-\\u01AB]|[\\u01AD-\\u01AD]|[\\u01B0-\\u01B0]|[\\u01B4-\\u01B4]|[\\u01B6-\\u01B6]|[\\u01B9-\\u01BA]|[\\u01BD-\\u01BD]|[\\u01C6-\\u01C6]|[\\u01C9-\\u01C9]|[\\u01CC-\\u01CC]|[\\u01CE-\\u01CE]|[\\u01D0-\\u01D0]|[\\u01D2-\\u01D2]|[\\u01D4-\\u01D4]|[\\u01D6-\\u01D6]|[\\u01D8-\\u01D8]|[\\u01DA-\\u01DA]|[\\u01DC-\\u01DD]|[\\u01DF-\\u01DF]|[\\u01E1-\\u01E1]|[\\u01E3-\\u01E3]|[\\u01E5-\\u01E5]|[\\u01E7-\\u01E7]|[\\u01E9-\\u01E9]|[\\u01EB-\\u01EB]|[\\u01ED-\\u01ED]|[\\u01EF-\\u01F0]|[\\u01F3-\\u01F3]|[\\u01F5-\\u01F5]|[\\u01FB-\\u01FB]|[\\u01FD-\\u01FD]|[\\u01FF-\\u01FF]|[\\u0201-\\u0201]|[\\u0203-\\u0203]|[\\u0205-\\u0205]|[\\u0207-\\u0207]|[\\u0209-\\u0209]|[\\u020B-\\u020B]|[\\u020D-\\u020D]|[\\u020F-\\u020F]|[\\u0211-\\u0211]|[\\u0213-\\u0213]|[\\u0215-\\u0215]|[\\u0217-\\u0217]|[\\u0250-\\u02A8]|[\\u0390-\\u0390]|[\\u03AC-\\u03CE]|[\\u03D0-\\u03D1]|[\\u03D5-\\u03D6]|[\\u03E3-\\u03E3]|[\\u03E5-\\u03E5]|[\\u03E7-\\u03E7]|[\\u03E9-\\u03E9]|[\\u03EB-\\u03EB]|[\\u03ED-\\u03ED]|[\\u03EF-\\u03F2]|[\\u0430-\\u044F]|[\\u0451-\\u045C]|[\\u045E-\\u045F]|[\\u0461-\\u0461]|[\\u0463-\\u0463]|[\\u0465-\\u0465]|[\\u0467-\\u0467]|[\\u0469-\\u0469]|[\\u046B-\\u046B]|[\\u046D-\\u046D]|[\\u046F-\\u046F]|[\\u0471-\\u0471]|[\\u0473-\\u0473]|[\\u0475-\\u0475]|[\\u0477-\\u0477]|[\\u0479-\\u0479]|[\\u047B-\\u047B]|[\\u047D-\\u047D]|[\\u047F-\\u047F]|[\\u0481-\\u0481]|[\\u0491-\\u0491]|[\\u0493-\\u0493]|[\\u0495-\\u0495]|[\\u0497-\\u0497]|[\\u0499-\\u0499]|[\\u049B-\\u049B]|[\\u049D-\\u049D]|[\\u049F-\\u049F]|[\\u04A1-\\u04A1]|[\\u04A3-\\u04A3]|[\\u04A5-\\u04A5]|[\\u04A7-\\u04A7]|[\\u04A9-\\u04A9]|[\\u04AB-\\u04AB]|[\\u04AD-\\u04AD]|[\\u04AF-\\u04AF]|[\\u04B1-\\u04B1]|[\\u04B3-\\u04B3]|[\\u04B5-\\u04B5]|[\\u04B7-\\u04B7]|[\\u04B9-\\u04B9]|[\\u04BB-\\u04BB]|[\\u04BD-\\u04BD]|[\\u04BF-\\u04BF]|[\\u04C2-\\u04C2]|[\\u04C4-\\u04C4]|[\\u04C8-\\u04C8]|[\\u04CC-\\u04CC]|[\\u04D1-\\u04D1]|[\\u04D3-\\u04D3]|[\\u04D5-\\u04D5]|[\\u04D7-\\u04D7]|[\\u04D9-\\u04D9]|[\\u04DB-\\u04DB]|[\\u04DD-\\u04DD]|[\\u04DF-\\u04DF]|[\\u04E1-\\u04E1]|[\\u04E3-\\u04E3]|[\\u04E5-\\u04E5]|[\\u04E7-\\u04E7]|[\\u04E9-\\u04E9]|[\\u04EB-\\u04EB]|[\\u04EF-\\u04EF]|[\\u04F1-\\u04F1]|[\\u04F3-\\u04F3]|[\\u04F5-\\u04F5]|[\\u04F9-\\u04F9]|[\\u0561-\\u0587]|[\\u10D0-\\u10F6]|[\\u1E01-\\u1E01]|[\\u1E03-\\u1E03]|[\\u1E05-\\u1E05]|[\\u1E07-\\u1E07]|[\\u1E09-\\u1E09]|[\\u1E0B-\\u1E0B]|[\\u1E0D-\\u1E0D]|[\\u1E0F-\\u1E0F]|[\\u1E11-\\u1E11]|[\\u1E13-\\u1E13]|[\\u1E15-\\u1E15]|[\\u1E17-\\u1E17]|[\\u1E19-\\u1E19]|[\\u1E1B-\\u1E1B]|[\\u1E1D-\\u1E1D]|[\\u1E1F-\\u1E1F]|[\\u1E21-\\u1E21]|[\\u1E23-\\u1E23]|[\\u1E25-\\u1E25]|[\\u1E27-\\u1E27]|[\\u1E29-\\u1E29]|[\\u1E2B-\\u1E2B]|[\\u1E2D-\\u1E2D]|[\\u1E2F-\\u1E2F]|[\\u1E31-\\u1E31]|[\\u1E33-\\u1E33]|[\\u1E35-\\u1E35]|[\\u1E37-\\u1E37]|[\\u1E39-\\u1E39]|[\\u1E3B-\\u1E3B]|[\\u1E3D-\\u1E3D]|[\\u1E3F-\\u1E3F]|[\\u1E41-\\u1E41]|[\\u1E43-\\u1E43]|[\\u1E45-\\u1E45]|[\\u1E47-\\u1E47]|[\\u1E49-\\u1E49]|[\\u1E4B-\\u1E4B]|[\\u1E4D-\\u1E4D]|[\\u1E4F-\\u1E4F]|[\\u1E51-\\u1E51]|[\\u1E53-\\u1E53]|[\\u1E55-\\u1E55]|[\\u1E57-\\u1E57]|[\\u1E59-\\u1E59]|[\\u1E5B-\\u1E5B]|[\\u1E5D-\\u1E5D]|[\\u1E5F-\\u1E5F]|[\\u1E61-\\u1E61]|[\\u1E63-\\u1E63]|[\\u1E65-\\u1E65]|[\\u1E67-\\u1E67]|[\\u1E69-\\u1E69]|[\\u1E6B-\\u1E6B]|[\\u1E6D-\\u1E6D]|[\\u1E6F-\\u1E6F]|[\\u1E71-\\u1E71]|[\\u1E73-\\u1E73]|[\\u1E75-\\u1E75]|[\\u1E77-\\u1E77]|[\\u1E79-\\u1E79]|[\\u1E7B-\\u1E7B]|[\\u1E7D-\\u1E7D]|[\\u1E7F-\\u1E7F]|[\\u1E81-\\u1E81]|[\\u1E83-\\u1E83]|[\\u1E85-\\u1E85]|[\\u1E87-\\u1E87]|[\\u1E89-\\u1E89]|[\\u1E8B-\\u1E8B]|[\\u1E8D-\\u1E8D]|[\\u1E8F-\\u1E8F]|[\\u1E91-\\u1E91]|[\\u1E93-\\u1E93]|[\\u1E95-\\u1E9B]|[\\u1EA1-\\u1EA1]|[\\u1EA3-\\u1EA3]|[\\u1EA5-\\u1EA5]|[\\u1EA7-\\u1EA7]|[\\u1EA9-\\u1EA9]|[\\u1EAB-\\u1EAB]|[\\u1EAD-\\u1EAD]|[\\u1EAF-\\u1EAF]|[\\u1EB1-\\u1EB1]|[\\u1EB3-\\u1EB3]|[\\u1EB5-\\u1EB5]|[\\u1EB7-\\u1EB7]|[\\u1EB9-\\u1EB9]|[\\u1EBB-\\u1EBB]|[\\u1EBD-\\u1EBD]|[\\u1EBF-\\u1EBF]|[\\u1EC1-\\u1EC1]|[\\u1EC3-\\u1EC3]|[\\u1EC5-\\u1EC5]|[\\u1EC7-\\u1EC7]|[\\u1EC9-\\u1EC9]|[\\u1ECB-\\u1ECB]|[\\u1ECD-\\u1ECD]|[\\u1ECF-\\u1ECF]|[\\u1ED1-\\u1ED1]|[\\u1ED3-\\u1ED3]|[\\u1ED5-\\u1ED5]|[\\u1ED7-\\u1ED7]|[\\u1ED9-\\u1ED9]|[\\u1EDB-\\u1EDB]|[\\u1EDD-\\u1EDD]|[\\u1EDF-\\u1EDF]|[\\u1EE1-\\u1EE1]|[\\u1EE3-\\u1EE3]|[\\u1EE5-\\u1EE5]|[\\u1EE7-\\u1EE7]|[\\u1EE9-\\u1EE9]|[\\u1EEB-\\u1EEB]|[\\u1EED-\\u1EED]|[\\u1EEF-\\u1EEF]|[\\u1EF1-\\u1EF1]|[\\u1EF3-\\u1EF3]|[\\u1EF5-\\u1EF5]|[\\u1EF7-\\u1EF7]|[\\u1EF9-\\u1EF9]|[\\u1F00-\\u1F07]|[\\u1F10-\\u1F15]|[\\u1F20-\\u1F27]|[\\u1F30-\\u1F37]|[\\u1F40-\\u1F45]|[\\u1F50-\\u1F57]|[\\u1F60-\\u1F67]|[\\u1F70-\\u1F7D]|[\\u1F80-\\u1F87]|[\\u1F90-\\u1F97]|[\\u1FA0-\\u1FA7]|[\\u1FB0-\\u1FB4]|[\\u1FB6-\\u1FB7]|[\\u1FBE-\\u1FBE]|[\\u1FC2-\\u1FC4]|[\\u1FC6-\\u1FC7]|[\\u1FD0-\\u1FD3]|[\\u1FD6-\\u1FD7]|[\\u1FE0-\\u1FE7]|[\\u1FF2-\\u1FF4]|[\\u1FF6-\\u1FF7]|[\\u207F-\\u207F]|[\\u210A-\\u210A]|[\\u210E-\\u210F]|[\\u2113-\\u2113]|[\\u2118-\\u2118]|[\\u212E-\\u212F]|[\\u2134-\\u2134]|[\\uFB00-\\uFB06]|[\\uFB13-\\uFB17]|[\\uFF41-\\uFF5A]|[\\u01C5-\\u01C5]|[\\u01C8-\\u01C8]|[\\u01CB-\\u01CB]|[\\u01F2-\\u01F2]|[\\u02B0-\\u02B8]|[\\u02BB-\\u02C1]|[\\u02D0-\\u02D1]|[\\u02E0-\\u02E4]|[\\u037A-\\u037A]|[\\u0559-\\u0559]|[\\u0640-\\u0640]|[\\u06E5-\\u06E6]|[\\u0E46-\\u0E46]|[\\u0EC6-\\u0EC6]|[\\u3005-\\u3005]|[\\u3031-\\u3035]|[\\u309D-\\u309E]|[\\u30FC-\\u30FE]|[\\uFF70-\\uFF70]|[\\uFF9E-\\uFF9F]|[\\u01AA-\\u01AA]|[\\u01BB-\\u01BB]|[\\u01BE-\\u01C3]|[\\u03F3-\\u03F3]|[\\u04C0-\\u04C0]|[\\u05D0-\\u05EA]|[\\u05F0-\\u05F2]|[\\u0621-\\u063A]|[\\u0641-\\u064A]|[\\u0671-\\u06B7]|[\\u06BA-\\u06BE]|[\\u06C0-\\u06CE]|[\\u06D0-\\u06D3]|[\\u06D5-\\u06D5]|[\\u0905-\\u0939]|[\\u093D-\\u093D]|[\\u0950-\\u0950]|[\\u0958-\\u0961]|[\\u0985-\\u098C]|[\\u098F-\\u0990]|[\\u0993-\\u09A8]|[\\u09AA-\\u09B0]|[\\u09B2-\\u09B2]|[\\u09B6-\\u09B9]|[\\u09DC-\\u09DD]|[\\u09DF-\\u09E1]|[\\u09F0-\\u09F1]|[\\u0A05-\\u0A0A]|[\\u0A0F-\\u0A10]|[\\u0A13-\\u0A28]|[\\u0A2A-\\u0A30]|[\\u0A32-\\u0A33]|[\\u0A35-\\u0A36]|[\\u0A38-\\u0A39]|[\\u0A59-\\u0A5C]|[\\u0A5E-\\u0A5E]|[\\u0A72-\\u0A74]|[\\u0A85-\\u0A8B]|[\\u0A8D-\\u0A8D]|[\\u0A8F-\\u0A91]|[\\u0A93-\\u0AA8]|[\\u0AAA-\\u0AB0]|[\\u0AB2-\\u0AB3]|[\\u0AB5-\\u0AB9]|[\\u0ABD-\\u0ABD]|[\\u0AD0-\\u0AD0]|[\\u0AE0-\\u0AE0]|[\\u0B05-\\u0B0C]|[\\u0B0F-\\u0B10]|[\\u0B13-\\u0B28]|[\\u0B2A-\\u0B30]|[\\u0B32-\\u0B33]|[\\u0B36-\\u0B39]|[\\u0B3D-\\u0B3D]|[\\u0B5C-\\u0B5D]|[\\u0B5F-\\u0B61]|[\\u0B85-\\u0B8A]|[\\u0B8E-\\u0B90]|[\\u0B92-\\u0B95]|[\\u0B99-\\u0B9A]|[\\u0B9C-\\u0B9C]|[\\u0B9E-\\u0B9F]|[\\u0BA3-\\u0BA4]|[\\u0BA8-\\u0BAA]|[\\u0BAE-\\u0BB5]|[\\u0BB7-\\u0BB9]|[\\u0C05-\\u0C0C]|[\\u0C0E-\\u0C10]|[\\u0C12-\\u0C28]|[\\u0C2A-\\u0C33]|[\\u0C35-\\u0C39]|[\\u0C60-\\u0C61]|[\\u0C85-\\u0C8C]|[\\u0C8E-\\u0C90]|[\\u0C92-\\u0CA8]|[\\u0CAA-\\u0CB3]|[\\u0CB5-\\u0CB9]|[\\u0CDE-\\u0CDE]|[\\u0CE0-\\u0CE1]|[\\u0D05-\\u0D0C]|[\\u0D0E-\\u0D10]|[\\u0D12-\\u0D28]|[\\u0D2A-\\u0D39]|[\\u0D60-\\u0D61]|[\\u0E01-\\u0E30]|[\\u0E32-\\u0E33]|[\\u0E40-\\u0E45]|[\\u0E81-\\u0E82]|[\\u0E84-\\u0E84]|[\\u0E87-\\u0E88]|[\\u0E8A-\\u0E8A]|[\\u0E8D-\\u0E8D]|[\\u0E94-\\u0E97]|[\\u0E99-\\u0E9F]|[\\u0EA1-\\u0EA3]|[\\u0EA5-\\u0EA5]|[\\u0EA7-\\u0EA7]|[\\u0EAA-\\u0EAB]|[\\u0EAD-\\u0EB0]|[\\u0EB2-\\u0EB3]|[\\u0EBD-\\u0EBD]|[\\u0EC0-\\u0EC4]|[\\u0EDC-\\u0EDD]|[\\u0F00-\\u0F00]|[\\u0F40-\\u0F47]|[\\u0F49-\\u0F69]|[\\u0F88-\\u0F8B]|[\\u1100-\\u1159]|[\\u115F-\\u11A2]|[\\u11A8-\\u11F9]|[\\u2135-\\u2138]|[\\u3006-\\u3006]|[\\u3041-\\u3094]|[\\u30A1-\\u30FA]|[\\u3105-\\u312C]|[\\u3131-\\u318E]|[\\u4E00-\\u9FA5]|[\\uAC00-\\uD7A3]|[\\uF900-\\uFA2D]|[\\uFB1F-\\uFB28]|[\\uFB2A-\\uFB36]|[\\uFB38-\\uFB3C]|[\\uFB3E-\\uFB3E]|[\\uFB40-\\uFB41]|[\\uFB43-\\uFB44]|[\\uFB46-\\uFBB1]|[\\uFBD3-\\uFD3D]|[\\uFD50-\\uFD8F]|[\\uFD92-\\uFDC7]|[\\uFDF0-\\uFDFB]|[\\uFE70-\\uFE72]|[\\uFE74-\\uFE74]|[\\uFE76-\\uFEFC]|[\\uFF66-\\uFF6F]|[\\uFF71-\\uFF9D]|[\\uFFA0-\\uFFBE]|[\\uFFC2-\\uFFC7]|[\\uFFCA-\\uFFCF]|[\\uFFD2-\\uFFD7]|[\\uFFDA-\\uFFDC]/,\n\n/* L = union of the below Unicode categories */\n  Lu   : /[\\u0041-\\u005A]|[\\u00C0-\\u00D6]|[\\u00D8-\\u00DE]|[\\u0100-\\u0100]|[\\u0102-\\u0102]|[\\u0104-\\u0104]|[\\u0106-\\u0106]|[\\u0108-\\u0108]|[\\u010A-\\u010A]|[\\u010C-\\u010C]|[\\u010E-\\u010E]|[\\u0110-\\u0110]|[\\u0112-\\u0112]|[\\u0114-\\u0114]|[\\u0116-\\u0116]|[\\u0118-\\u0118]|[\\u011A-\\u011A]|[\\u011C-\\u011C]|[\\u011E-\\u011E]|[\\u0120-\\u0120]|[\\u0122-\\u0122]|[\\u0124-\\u0124]|[\\u0126-\\u0126]|[\\u0128-\\u0128]|[\\u012A-\\u012A]|[\\u012C-\\u012C]|[\\u012E-\\u012E]|[\\u0130-\\u0130]|[\\u0132-\\u0132]|[\\u0134-\\u0134]|[\\u0136-\\u0136]|[\\u0139-\\u0139]|[\\u013B-\\u013B]|[\\u013D-\\u013D]|[\\u013F-\\u013F]|[\\u0141-\\u0141]|[\\u0143-\\u0143]|[\\u0145-\\u0145]|[\\u0147-\\u0147]|[\\u014A-\\u014A]|[\\u014C-\\u014C]|[\\u014E-\\u014E]|[\\u0150-\\u0150]|[\\u0152-\\u0152]|[\\u0154-\\u0154]|[\\u0156-\\u0156]|[\\u0158-\\u0158]|[\\u015A-\\u015A]|[\\u015C-\\u015C]|[\\u015E-\\u015E]|[\\u0160-\\u0160]|[\\u0162-\\u0162]|[\\u0164-\\u0164]|[\\u0166-\\u0166]|[\\u0168-\\u0168]|[\\u016A-\\u016A]|[\\u016C-\\u016C]|[\\u016E-\\u016E]|[\\u0170-\\u0170]|[\\u0172-\\u0172]|[\\u0174-\\u0174]|[\\u0176-\\u0176]|[\\u0178-\\u0179]|[\\u017B-\\u017B]|[\\u017D-\\u017D]|[\\u0181-\\u0182]|[\\u0184-\\u0184]|[\\u0186-\\u0187]|[\\u0189-\\u018B]|[\\u018E-\\u0191]|[\\u0193-\\u0194]|[\\u0196-\\u0198]|[\\u019C-\\u019D]|[\\u019F-\\u01A0]|[\\u01A2-\\u01A2]|[\\u01A4-\\u01A4]|[\\u01A6-\\u01A7]|[\\u01A9-\\u01A9]|[\\u01AC-\\u01AC]|[\\u01AE-\\u01AF]|[\\u01B1-\\u01B3]|[\\u01B5-\\u01B5]|[\\u01B7-\\u01B8]|[\\u01BC-\\u01BC]|[\\u01C4-\\u01C4]|[\\u01C7-\\u01C7]|[\\u01CA-\\u01CA]|[\\u01CD-\\u01CD]|[\\u01CF-\\u01CF]|[\\u01D1-\\u01D1]|[\\u01D3-\\u01D3]|[\\u01D5-\\u01D5]|[\\u01D7-\\u01D7]|[\\u01D9-\\u01D9]|[\\u01DB-\\u01DB]|[\\u01DE-\\u01DE]|[\\u01E0-\\u01E0]|[\\u01E2-\\u01E2]|[\\u01E4-\\u01E4]|[\\u01E6-\\u01E6]|[\\u01E8-\\u01E8]|[\\u01EA-\\u01EA]|[\\u01EC-\\u01EC]|[\\u01EE-\\u01EE]|[\\u01F1-\\u01F1]|[\\u01F4-\\u01F4]|[\\u01FA-\\u01FA]|[\\u01FC-\\u01FC]|[\\u01FE-\\u01FE]|[\\u0200-\\u0200]|[\\u0202-\\u0202]|[\\u0204-\\u0204]|[\\u0206-\\u0206]|[\\u0208-\\u0208]|[\\u020A-\\u020A]|[\\u020C-\\u020C]|[\\u020E-\\u020E]|[\\u0210-\\u0210]|[\\u0212-\\u0212]|[\\u0214-\\u0214]|[\\u0216-\\u0216]|[\\u0386-\\u0386]|[\\u0388-\\u038A]|[\\u038C-\\u038C]|[\\u038E-\\u038F]|[\\u0391-\\u03A1]|[\\u03A3-\\u03AB]|[\\u03D2-\\u03D4]|[\\u03DA-\\u03DA]|[\\u03DC-\\u03DC]|[\\u03DE-\\u03DE]|[\\u03E0-\\u03E0]|[\\u03E2-\\u03E2]|[\\u03E4-\\u03E4]|[\\u03E6-\\u03E6]|[\\u03E8-\\u03E8]|[\\u03EA-\\u03EA]|[\\u03EC-\\u03EC]|[\\u03EE-\\u03EE]|[\\u0401-\\u040C]|[\\u040E-\\u042F]|[\\u0460-\\u0460]|[\\u0462-\\u0462]|[\\u0464-\\u0464]|[\\u0466-\\u0466]|[\\u0468-\\u0468]|[\\u046A-\\u046A]|[\\u046C-\\u046C]|[\\u046E-\\u046E]|[\\u0470-\\u0470]|[\\u0472-\\u0472]|[\\u0474-\\u0474]|[\\u0476-\\u0476]|[\\u0478-\\u0478]|[\\u047A-\\u047A]|[\\u047C-\\u047C]|[\\u047E-\\u047E]|[\\u0480-\\u0480]|[\\u0490-\\u0490]|[\\u0492-\\u0492]|[\\u0494-\\u0494]|[\\u0496-\\u0496]|[\\u0498-\\u0498]|[\\u049A-\\u049A]|[\\u049C-\\u049C]|[\\u049E-\\u049E]|[\\u04A0-\\u04A0]|[\\u04A2-\\u04A2]|[\\u04A4-\\u04A4]|[\\u04A6-\\u04A6]|[\\u04A8-\\u04A8]|[\\u04AA-\\u04AA]|[\\u04AC-\\u04AC]|[\\u04AE-\\u04AE]|[\\u04B0-\\u04B0]|[\\u04B2-\\u04B2]|[\\u04B4-\\u04B4]|[\\u04B6-\\u04B6]|[\\u04B8-\\u04B8]|[\\u04BA-\\u04BA]|[\\u04BC-\\u04BC]|[\\u04BE-\\u04BE]|[\\u04C1-\\u04C1]|[\\u04C3-\\u04C3]|[\\u04C7-\\u04C7]|[\\u04CB-\\u04CB]|[\\u04D0-\\u04D0]|[\\u04D2-\\u04D2]|[\\u04D4-\\u04D4]|[\\u04D6-\\u04D6]|[\\u04D8-\\u04D8]|[\\u04DA-\\u04DA]|[\\u04DC-\\u04DC]|[\\u04DE-\\u04DE]|[\\u04E0-\\u04E0]|[\\u04E2-\\u04E2]|[\\u04E4-\\u04E4]|[\\u04E6-\\u04E6]|[\\u04E8-\\u04E8]|[\\u04EA-\\u04EA]|[\\u04EE-\\u04EE]|[\\u04F0-\\u04F0]|[\\u04F2-\\u04F2]|[\\u04F4-\\u04F4]|[\\u04F8-\\u04F8]|[\\u0531-\\u0556]|[\\u10A0-\\u10C5]|[\\u1E00-\\u1E00]|[\\u1E02-\\u1E02]|[\\u1E04-\\u1E04]|[\\u1E06-\\u1E06]|[\\u1E08-\\u1E08]|[\\u1E0A-\\u1E0A]|[\\u1E0C-\\u1E0C]|[\\u1E0E-\\u1E0E]|[\\u1E10-\\u1E10]|[\\u1E12-\\u1E12]|[\\u1E14-\\u1E14]|[\\u1E16-\\u1E16]|[\\u1E18-\\u1E18]|[\\u1E1A-\\u1E1A]|[\\u1E1C-\\u1E1C]|[\\u1E1E-\\u1E1E]|[\\u1E20-\\u1E20]|[\\u1E22-\\u1E22]|[\\u1E24-\\u1E24]|[\\u1E26-\\u1E26]|[\\u1E28-\\u1E28]|[\\u1E2A-\\u1E2A]|[\\u1E2C-\\u1E2C]|[\\u1E2E-\\u1E2E]|[\\u1E30-\\u1E30]|[\\u1E32-\\u1E32]|[\\u1E34-\\u1E34]|[\\u1E36-\\u1E36]|[\\u1E38-\\u1E38]|[\\u1E3A-\\u1E3A]|[\\u1E3C-\\u1E3C]|[\\u1E3E-\\u1E3E]|[\\u1E40-\\u1E40]|[\\u1E42-\\u1E42]|[\\u1E44-\\u1E44]|[\\u1E46-\\u1E46]|[\\u1E48-\\u1E48]|[\\u1E4A-\\u1E4A]|[\\u1E4C-\\u1E4C]|[\\u1E4E-\\u1E4E]|[\\u1E50-\\u1E50]|[\\u1E52-\\u1E52]|[\\u1E54-\\u1E54]|[\\u1E56-\\u1E56]|[\\u1E58-\\u1E58]|[\\u1E5A-\\u1E5A]|[\\u1E5C-\\u1E5C]|[\\u1E5E-\\u1E5E]|[\\u1E60-\\u1E60]|[\\u1E62-\\u1E62]|[\\u1E64-\\u1E64]|[\\u1E66-\\u1E66]|[\\u1E68-\\u1E68]|[\\u1E6A-\\u1E6A]|[\\u1E6C-\\u1E6C]|[\\u1E6E-\\u1E6E]|[\\u1E70-\\u1E70]|[\\u1E72-\\u1E72]|[\\u1E74-\\u1E74]|[\\u1E76-\\u1E76]|[\\u1E78-\\u1E78]|[\\u1E7A-\\u1E7A]|[\\u1E7C-\\u1E7C]|[\\u1E7E-\\u1E7E]|[\\u1E80-\\u1E80]|[\\u1E82-\\u1E82]|[\\u1E84-\\u1E84]|[\\u1E86-\\u1E86]|[\\u1E88-\\u1E88]|[\\u1E8A-\\u1E8A]|[\\u1E8C-\\u1E8C]|[\\u1E8E-\\u1E8E]|[\\u1E90-\\u1E90]|[\\u1E92-\\u1E92]|[\\u1E94-\\u1E94]|[\\u1EA0-\\u1EA0]|[\\u1EA2-\\u1EA2]|[\\u1EA4-\\u1EA4]|[\\u1EA6-\\u1EA6]|[\\u1EA8-\\u1EA8]|[\\u1EAA-\\u1EAA]|[\\u1EAC-\\u1EAC]|[\\u1EAE-\\u1EAE]|[\\u1EB0-\\u1EB0]|[\\u1EB2-\\u1EB2]|[\\u1EB4-\\u1EB4]|[\\u1EB6-\\u1EB6]|[\\u1EB8-\\u1EB8]|[\\u1EBA-\\u1EBA]|[\\u1EBC-\\u1EBC]|[\\u1EBE-\\u1EBE]|[\\u1EC0-\\u1EC0]|[\\u1EC2-\\u1EC2]|[\\u1EC4-\\u1EC4]|[\\u1EC6-\\u1EC6]|[\\u1EC8-\\u1EC8]|[\\u1ECA-\\u1ECA]|[\\u1ECC-\\u1ECC]|[\\u1ECE-\\u1ECE]|[\\u1ED0-\\u1ED0]|[\\u1ED2-\\u1ED2]|[\\u1ED4-\\u1ED4]|[\\u1ED6-\\u1ED6]|[\\u1ED8-\\u1ED8]|[\\u1EDA-\\u1EDA]|[\\u1EDC-\\u1EDC]|[\\u1EDE-\\u1EDE]|[\\u1EE0-\\u1EE0]|[\\u1EE2-\\u1EE2]|[\\u1EE4-\\u1EE4]|[\\u1EE6-\\u1EE6]|[\\u1EE8-\\u1EE8]|[\\u1EEA-\\u1EEA]|[\\u1EEC-\\u1EEC]|[\\u1EEE-\\u1EEE]|[\\u1EF0-\\u1EF0]|[\\u1EF2-\\u1EF2]|[\\u1EF4-\\u1EF4]|[\\u1EF6-\\u1EF6]|[\\u1EF8-\\u1EF8]|[\\u1F08-\\u1F0F]|[\\u1F18-\\u1F1D]|[\\u1F28-\\u1F2F]|[\\u1F38-\\u1F3F]|[\\u1F48-\\u1F4D]|[\\u1F59-\\u1F59]|[\\u1F5B-\\u1F5B]|[\\u1F5D-\\u1F5D]|[\\u1F5F-\\u1F5F]|[\\u1F68-\\u1F6F]|[\\u1F88-\\u1F8F]|[\\u1F98-\\u1F9F]|[\\u1FA8-\\u1FAF]|[\\u1FB8-\\u1FBC]|[\\u1FC8-\\u1FCC]|[\\u1FD8-\\u1FDB]|[\\u1FE8-\\u1FEC]|[\\u1FF8-\\u1FFC]|[\\u2102-\\u2102]|[\\u2107-\\u2107]|[\\u210B-\\u210D]|[\\u2110-\\u2112]|[\\u2115-\\u2115]|[\\u2119-\\u211D]|[\\u2124-\\u2124]|[\\u2126-\\u2126]|[\\u2128-\\u2128]|[\\u212A-\\u212D]|[\\u2130-\\u2131]|[\\u2133-\\u2133]|[\\uFF21-\\uFF3A]/,\n  Ll   : /[\\u0061-\\u007A]|[\\u00AA-\\u00AA]|[\\u00B5-\\u00B5]|[\\u00BA-\\u00BA]|[\\u00DF-\\u00F6]|[\\u00F8-\\u00FF]|[\\u0101-\\u0101]|[\\u0103-\\u0103]|[\\u0105-\\u0105]|[\\u0107-\\u0107]|[\\u0109-\\u0109]|[\\u010B-\\u010B]|[\\u010D-\\u010D]|[\\u010F-\\u010F]|[\\u0111-\\u0111]|[\\u0113-\\u0113]|[\\u0115-\\u0115]|[\\u0117-\\u0117]|[\\u0119-\\u0119]|[\\u011B-\\u011B]|[\\u011D-\\u011D]|[\\u011F-\\u011F]|[\\u0121-\\u0121]|[\\u0123-\\u0123]|[\\u0125-\\u0125]|[\\u0127-\\u0127]|[\\u0129-\\u0129]|[\\u012B-\\u012B]|[\\u012D-\\u012D]|[\\u012F-\\u012F]|[\\u0131-\\u0131]|[\\u0133-\\u0133]|[\\u0135-\\u0135]|[\\u0137-\\u0138]|[\\u013A-\\u013A]|[\\u013C-\\u013C]|[\\u013E-\\u013E]|[\\u0140-\\u0140]|[\\u0142-\\u0142]|[\\u0144-\\u0144]|[\\u0146-\\u0146]|[\\u0148-\\u0149]|[\\u014B-\\u014B]|[\\u014D-\\u014D]|[\\u014F-\\u014F]|[\\u0151-\\u0151]|[\\u0153-\\u0153]|[\\u0155-\\u0155]|[\\u0157-\\u0157]|[\\u0159-\\u0159]|[\\u015B-\\u015B]|[\\u015D-\\u015D]|[\\u015F-\\u015F]|[\\u0161-\\u0161]|[\\u0163-\\u0163]|[\\u0165-\\u0165]|[\\u0167-\\u0167]|[\\u0169-\\u0169]|[\\u016B-\\u016B]|[\\u016D-\\u016D]|[\\u016F-\\u016F]|[\\u0171-\\u0171]|[\\u0173-\\u0173]|[\\u0175-\\u0175]|[\\u0177-\\u0177]|[\\u017A-\\u017A]|[\\u017C-\\u017C]|[\\u017E-\\u0180]|[\\u0183-\\u0183]|[\\u0185-\\u0185]|[\\u0188-\\u0188]|[\\u018C-\\u018D]|[\\u0192-\\u0192]|[\\u0195-\\u0195]|[\\u0199-\\u019B]|[\\u019E-\\u019E]|[\\u01A1-\\u01A1]|[\\u01A3-\\u01A3]|[\\u01A5-\\u01A5]|[\\u01A8-\\u01A8]|[\\u01AB-\\u01AB]|[\\u01AD-\\u01AD]|[\\u01B0-\\u01B0]|[\\u01B4-\\u01B4]|[\\u01B6-\\u01B6]|[\\u01B9-\\u01BA]|[\\u01BD-\\u01BD]|[\\u01C6-\\u01C6]|[\\u01C9-\\u01C9]|[\\u01CC-\\u01CC]|[\\u01CE-\\u01CE]|[\\u01D0-\\u01D0]|[\\u01D2-\\u01D2]|[\\u01D4-\\u01D4]|[\\u01D6-\\u01D6]|[\\u01D8-\\u01D8]|[\\u01DA-\\u01DA]|[\\u01DC-\\u01DD]|[\\u01DF-\\u01DF]|[\\u01E1-\\u01E1]|[\\u01E3-\\u01E3]|[\\u01E5-\\u01E5]|[\\u01E7-\\u01E7]|[\\u01E9-\\u01E9]|[\\u01EB-\\u01EB]|[\\u01ED-\\u01ED]|[\\u01EF-\\u01F0]|[\\u01F3-\\u01F3]|[\\u01F5-\\u01F5]|[\\u01FB-\\u01FB]|[\\u01FD-\\u01FD]|[\\u01FF-\\u01FF]|[\\u0201-\\u0201]|[\\u0203-\\u0203]|[\\u0205-\\u0205]|[\\u0207-\\u0207]|[\\u0209-\\u0209]|[\\u020B-\\u020B]|[\\u020D-\\u020D]|[\\u020F-\\u020F]|[\\u0211-\\u0211]|[\\u0213-\\u0213]|[\\u0215-\\u0215]|[\\u0217-\\u0217]|[\\u0250-\\u02A8]|[\\u0390-\\u0390]|[\\u03AC-\\u03CE]|[\\u03D0-\\u03D1]|[\\u03D5-\\u03D6]|[\\u03E3-\\u03E3]|[\\u03E5-\\u03E5]|[\\u03E7-\\u03E7]|[\\u03E9-\\u03E9]|[\\u03EB-\\u03EB]|[\\u03ED-\\u03ED]|[\\u03EF-\\u03F2]|[\\u0430-\\u044F]|[\\u0451-\\u045C]|[\\u045E-\\u045F]|[\\u0461-\\u0461]|[\\u0463-\\u0463]|[\\u0465-\\u0465]|[\\u0467-\\u0467]|[\\u0469-\\u0469]|[\\u046B-\\u046B]|[\\u046D-\\u046D]|[\\u046F-\\u046F]|[\\u0471-\\u0471]|[\\u0473-\\u0473]|[\\u0475-\\u0475]|[\\u0477-\\u0477]|[\\u0479-\\u0479]|[\\u047B-\\u047B]|[\\u047D-\\u047D]|[\\u047F-\\u047F]|[\\u0481-\\u0481]|[\\u0491-\\u0491]|[\\u0493-\\u0493]|[\\u0495-\\u0495]|[\\u0497-\\u0497]|[\\u0499-\\u0499]|[\\u049B-\\u049B]|[\\u049D-\\u049D]|[\\u049F-\\u049F]|[\\u04A1-\\u04A1]|[\\u04A3-\\u04A3]|[\\u04A5-\\u04A5]|[\\u04A7-\\u04A7]|[\\u04A9-\\u04A9]|[\\u04AB-\\u04AB]|[\\u04AD-\\u04AD]|[\\u04AF-\\u04AF]|[\\u04B1-\\u04B1]|[\\u04B3-\\u04B3]|[\\u04B5-\\u04B5]|[\\u04B7-\\u04B7]|[\\u04B9-\\u04B9]|[\\u04BB-\\u04BB]|[\\u04BD-\\u04BD]|[\\u04BF-\\u04BF]|[\\u04C2-\\u04C2]|[\\u04C4-\\u04C4]|[\\u04C8-\\u04C8]|[\\u04CC-\\u04CC]|[\\u04D1-\\u04D1]|[\\u04D3-\\u04D3]|[\\u04D5-\\u04D5]|[\\u04D7-\\u04D7]|[\\u04D9-\\u04D9]|[\\u04DB-\\u04DB]|[\\u04DD-\\u04DD]|[\\u04DF-\\u04DF]|[\\u04E1-\\u04E1]|[\\u04E3-\\u04E3]|[\\u04E5-\\u04E5]|[\\u04E7-\\u04E7]|[\\u04E9-\\u04E9]|[\\u04EB-\\u04EB]|[\\u04EF-\\u04EF]|[\\u04F1-\\u04F1]|[\\u04F3-\\u04F3]|[\\u04F5-\\u04F5]|[\\u04F9-\\u04F9]|[\\u0561-\\u0587]|[\\u10D0-\\u10F6]|[\\u1E01-\\u1E01]|[\\u1E03-\\u1E03]|[\\u1E05-\\u1E05]|[\\u1E07-\\u1E07]|[\\u1E09-\\u1E09]|[\\u1E0B-\\u1E0B]|[\\u1E0D-\\u1E0D]|[\\u1E0F-\\u1E0F]|[\\u1E11-\\u1E11]|[\\u1E13-\\u1E13]|[\\u1E15-\\u1E15]|[\\u1E17-\\u1E17]|[\\u1E19-\\u1E19]|[\\u1E1B-\\u1E1B]|[\\u1E1D-\\u1E1D]|[\\u1E1F-\\u1E1F]|[\\u1E21-\\u1E21]|[\\u1E23-\\u1E23]|[\\u1E25-\\u1E25]|[\\u1E27-\\u1E27]|[\\u1E29-\\u1E29]|[\\u1E2B-\\u1E2B]|[\\u1E2D-\\u1E2D]|[\\u1E2F-\\u1E2F]|[\\u1E31-\\u1E31]|[\\u1E33-\\u1E33]|[\\u1E35-\\u1E35]|[\\u1E37-\\u1E37]|[\\u1E39-\\u1E39]|[\\u1E3B-\\u1E3B]|[\\u1E3D-\\u1E3D]|[\\u1E3F-\\u1E3F]|[\\u1E41-\\u1E41]|[\\u1E43-\\u1E43]|[\\u1E45-\\u1E45]|[\\u1E47-\\u1E47]|[\\u1E49-\\u1E49]|[\\u1E4B-\\u1E4B]|[\\u1E4D-\\u1E4D]|[\\u1E4F-\\u1E4F]|[\\u1E51-\\u1E51]|[\\u1E53-\\u1E53]|[\\u1E55-\\u1E55]|[\\u1E57-\\u1E57]|[\\u1E59-\\u1E59]|[\\u1E5B-\\u1E5B]|[\\u1E5D-\\u1E5D]|[\\u1E5F-\\u1E5F]|[\\u1E61-\\u1E61]|[\\u1E63-\\u1E63]|[\\u1E65-\\u1E65]|[\\u1E67-\\u1E67]|[\\u1E69-\\u1E69]|[\\u1E6B-\\u1E6B]|[\\u1E6D-\\u1E6D]|[\\u1E6F-\\u1E6F]|[\\u1E71-\\u1E71]|[\\u1E73-\\u1E73]|[\\u1E75-\\u1E75]|[\\u1E77-\\u1E77]|[\\u1E79-\\u1E79]|[\\u1E7B-\\u1E7B]|[\\u1E7D-\\u1E7D]|[\\u1E7F-\\u1E7F]|[\\u1E81-\\u1E81]|[\\u1E83-\\u1E83]|[\\u1E85-\\u1E85]|[\\u1E87-\\u1E87]|[\\u1E89-\\u1E89]|[\\u1E8B-\\u1E8B]|[\\u1E8D-\\u1E8D]|[\\u1E8F-\\u1E8F]|[\\u1E91-\\u1E91]|[\\u1E93-\\u1E93]|[\\u1E95-\\u1E9B]|[\\u1EA1-\\u1EA1]|[\\u1EA3-\\u1EA3]|[\\u1EA5-\\u1EA5]|[\\u1EA7-\\u1EA7]|[\\u1EA9-\\u1EA9]|[\\u1EAB-\\u1EAB]|[\\u1EAD-\\u1EAD]|[\\u1EAF-\\u1EAF]|[\\u1EB1-\\u1EB1]|[\\u1EB3-\\u1EB3]|[\\u1EB5-\\u1EB5]|[\\u1EB7-\\u1EB7]|[\\u1EB9-\\u1EB9]|[\\u1EBB-\\u1EBB]|[\\u1EBD-\\u1EBD]|[\\u1EBF-\\u1EBF]|[\\u1EC1-\\u1EC1]|[\\u1EC3-\\u1EC3]|[\\u1EC5-\\u1EC5]|[\\u1EC7-\\u1EC7]|[\\u1EC9-\\u1EC9]|[\\u1ECB-\\u1ECB]|[\\u1ECD-\\u1ECD]|[\\u1ECF-\\u1ECF]|[\\u1ED1-\\u1ED1]|[\\u1ED3-\\u1ED3]|[\\u1ED5-\\u1ED5]|[\\u1ED7-\\u1ED7]|[\\u1ED9-\\u1ED9]|[\\u1EDB-\\u1EDB]|[\\u1EDD-\\u1EDD]|[\\u1EDF-\\u1EDF]|[\\u1EE1-\\u1EE1]|[\\u1EE3-\\u1EE3]|[\\u1EE5-\\u1EE5]|[\\u1EE7-\\u1EE7]|[\\u1EE9-\\u1EE9]|[\\u1EEB-\\u1EEB]|[\\u1EED-\\u1EED]|[\\u1EEF-\\u1EEF]|[\\u1EF1-\\u1EF1]|[\\u1EF3-\\u1EF3]|[\\u1EF5-\\u1EF5]|[\\u1EF7-\\u1EF7]|[\\u1EF9-\\u1EF9]|[\\u1F00-\\u1F07]|[\\u1F10-\\u1F15]|[\\u1F20-\\u1F27]|[\\u1F30-\\u1F37]|[\\u1F40-\\u1F45]|[\\u1F50-\\u1F57]|[\\u1F60-\\u1F67]|[\\u1F70-\\u1F7D]|[\\u1F80-\\u1F87]|[\\u1F90-\\u1F97]|[\\u1FA0-\\u1FA7]|[\\u1FB0-\\u1FB4]|[\\u1FB6-\\u1FB7]|[\\u1FBE-\\u1FBE]|[\\u1FC2-\\u1FC4]|[\\u1FC6-\\u1FC7]|[\\u1FD0-\\u1FD3]|[\\u1FD6-\\u1FD7]|[\\u1FE0-\\u1FE7]|[\\u1FF2-\\u1FF4]|[\\u1FF6-\\u1FF7]|[\\u207F-\\u207F]|[\\u210A-\\u210A]|[\\u210E-\\u210F]|[\\u2113-\\u2113]|[\\u2118-\\u2118]|[\\u212E-\\u212F]|[\\u2134-\\u2134]|[\\uFB00-\\uFB06]|[\\uFB13-\\uFB17]|[\\uFF41-\\uFF5A]/,\n  Lt   : /[\\u01C5-\\u01C5]|[\\u01C8-\\u01C8]|[\\u01CB-\\u01CB]|[\\u01F2-\\u01F2]/,\n  Lm   : /[\\u02B0-\\u02B8]|[\\u02BB-\\u02C1]|[\\u02D0-\\u02D1]|[\\u02E0-\\u02E4]|[\\u037A-\\u037A]|[\\u0559-\\u0559]|[\\u0640-\\u0640]|[\\u06E5-\\u06E6]|[\\u0E46-\\u0E46]|[\\u0EC6-\\u0EC6]|[\\u3005-\\u3005]|[\\u3031-\\u3035]|[\\u309D-\\u309E]|[\\u30FC-\\u30FE]|[\\uFF70-\\uFF70]|[\\uFF9E-\\uFF9F]/,\n  Lo   : /[\\u01AA-\\u01AA]|[\\u01BB-\\u01BB]|[\\u01BE-\\u01C3]|[\\u03F3-\\u03F3]|[\\u04C0-\\u04C0]|[\\u05D0-\\u05EA]|[\\u05F0-\\u05F2]|[\\u0621-\\u063A]|[\\u0641-\\u064A]|[\\u0671-\\u06B7]|[\\u06BA-\\u06BE]|[\\u06C0-\\u06CE]|[\\u06D0-\\u06D3]|[\\u06D5-\\u06D5]|[\\u0905-\\u0939]|[\\u093D-\\u093D]|[\\u0950-\\u0950]|[\\u0958-\\u0961]|[\\u0985-\\u098C]|[\\u098F-\\u0990]|[\\u0993-\\u09A8]|[\\u09AA-\\u09B0]|[\\u09B2-\\u09B2]|[\\u09B6-\\u09B9]|[\\u09DC-\\u09DD]|[\\u09DF-\\u09E1]|[\\u09F0-\\u09F1]|[\\u0A05-\\u0A0A]|[\\u0A0F-\\u0A10]|[\\u0A13-\\u0A28]|[\\u0A2A-\\u0A30]|[\\u0A32-\\u0A33]|[\\u0A35-\\u0A36]|[\\u0A38-\\u0A39]|[\\u0A59-\\u0A5C]|[\\u0A5E-\\u0A5E]|[\\u0A72-\\u0A74]|[\\u0A85-\\u0A8B]|[\\u0A8D-\\u0A8D]|[\\u0A8F-\\u0A91]|[\\u0A93-\\u0AA8]|[\\u0AAA-\\u0AB0]|[\\u0AB2-\\u0AB3]|[\\u0AB5-\\u0AB9]|[\\u0ABD-\\u0ABD]|[\\u0AD0-\\u0AD0]|[\\u0AE0-\\u0AE0]|[\\u0B05-\\u0B0C]|[\\u0B0F-\\u0B10]|[\\u0B13-\\u0B28]|[\\u0B2A-\\u0B30]|[\\u0B32-\\u0B33]|[\\u0B36-\\u0B39]|[\\u0B3D-\\u0B3D]|[\\u0B5C-\\u0B5D]|[\\u0B5F-\\u0B61]|[\\u0B85-\\u0B8A]|[\\u0B8E-\\u0B90]|[\\u0B92-\\u0B95]|[\\u0B99-\\u0B9A]|[\\u0B9C-\\u0B9C]|[\\u0B9E-\\u0B9F]|[\\u0BA3-\\u0BA4]|[\\u0BA8-\\u0BAA]|[\\u0BAE-\\u0BB5]|[\\u0BB7-\\u0BB9]|[\\u0C05-\\u0C0C]|[\\u0C0E-\\u0C10]|[\\u0C12-\\u0C28]|[\\u0C2A-\\u0C33]|[\\u0C35-\\u0C39]|[\\u0C60-\\u0C61]|[\\u0C85-\\u0C8C]|[\\u0C8E-\\u0C90]|[\\u0C92-\\u0CA8]|[\\u0CAA-\\u0CB3]|[\\u0CB5-\\u0CB9]|[\\u0CDE-\\u0CDE]|[\\u0CE0-\\u0CE1]|[\\u0D05-\\u0D0C]|[\\u0D0E-\\u0D10]|[\\u0D12-\\u0D28]|[\\u0D2A-\\u0D39]|[\\u0D60-\\u0D61]|[\\u0E01-\\u0E30]|[\\u0E32-\\u0E33]|[\\u0E40-\\u0E45]|[\\u0E81-\\u0E82]|[\\u0E84-\\u0E84]|[\\u0E87-\\u0E88]|[\\u0E8A-\\u0E8A]|[\\u0E8D-\\u0E8D]|[\\u0E94-\\u0E97]|[\\u0E99-\\u0E9F]|[\\u0EA1-\\u0EA3]|[\\u0EA5-\\u0EA5]|[\\u0EA7-\\u0EA7]|[\\u0EAA-\\u0EAB]|[\\u0EAD-\\u0EB0]|[\\u0EB2-\\u0EB3]|[\\u0EBD-\\u0EBD]|[\\u0EC0-\\u0EC4]|[\\u0EDC-\\u0EDD]|[\\u0F00-\\u0F00]|[\\u0F40-\\u0F47]|[\\u0F49-\\u0F69]|[\\u0F88-\\u0F8B]|[\\u1100-\\u1159]|[\\u115F-\\u11A2]|[\\u11A8-\\u11F9]|[\\u2135-\\u2138]|[\\u3006-\\u3006]|[\\u3041-\\u3094]|[\\u30A1-\\u30FA]|[\\u3105-\\u312C]|[\\u3131-\\u318E]|[\\u4E00-\\u9FA5]|[\\uAC00-\\uD7A3]|[\\uF900-\\uFA2D]|[\\uFB1F-\\uFB28]|[\\uFB2A-\\uFB36]|[\\uFB38-\\uFB3C]|[\\uFB3E-\\uFB3E]|[\\uFB40-\\uFB41]|[\\uFB43-\\uFB44]|[\\uFB46-\\uFBB1]|[\\uFBD3-\\uFD3D]|[\\uFD50-\\uFD8F]|[\\uFD92-\\uFDC7]|[\\uFDF0-\\uFDFB]|[\\uFE70-\\uFE72]|[\\uFE74-\\uFE74]|[\\uFE76-\\uFEFC]|[\\uFF66-\\uFF6F]|[\\uFF71-\\uFF9D]|[\\uFFA0-\\uFFBE]|[\\uFFC2-\\uFFC7]|[\\uFFCA-\\uFFCF]|[\\uFFD2-\\uFFD7]|[\\uFFDA-\\uFFDC]/,\n/* --- */\n\n  Nl   : /[\\u2160-\\u2182]|[\\u3007-\\u3007]|[\\u3021-\\u3029]/,\n  Mn   : /[\\u0300-\\u0345]|[\\u0360-\\u0361]|[\\u0483-\\u0486]|[\\u0591-\\u05A1]|[\\u05A3-\\u05B9]|[\\u05BB-\\u05BD]|[\\u05BF-\\u05BF]|[\\u05C1-\\u05C2]|[\\u05C4-\\u05C4]|[\\u064B-\\u0652]|[\\u0670-\\u0670]|[\\u06D6-\\u06DC]|[\\u06DF-\\u06E4]|[\\u06E7-\\u06E8]|[\\u06EA-\\u06ED]|[\\u0901-\\u0902]|[\\u093C-\\u093C]|[\\u0941-\\u0948]|[\\u094D-\\u094D]|[\\u0951-\\u0954]|[\\u0962-\\u0963]|[\\u0981-\\u0981]|[\\u09BC-\\u09BC]|[\\u09C1-\\u09C4]|[\\u09CD-\\u09CD]|[\\u09E2-\\u09E3]|[\\u0A02-\\u0A02]|[\\u0A3C-\\u0A3C]|[\\u0A41-\\u0A42]|[\\u0A47-\\u0A48]|[\\u0A4B-\\u0A4D]|[\\u0A70-\\u0A71]|[\\u0A81-\\u0A82]|[\\u0ABC-\\u0ABC]|[\\u0AC1-\\u0AC5]|[\\u0AC7-\\u0AC8]|[\\u0ACD-\\u0ACD]|[\\u0B01-\\u0B01]|[\\u0B3C-\\u0B3C]|[\\u0B3F-\\u0B3F]|[\\u0B41-\\u0B43]|[\\u0B4D-\\u0B4D]|[\\u0B56-\\u0B56]|[\\u0B82-\\u0B82]|[\\u0BC0-\\u0BC0]|[\\u0BCD-\\u0BCD]|[\\u0C3E-\\u0C40]|[\\u0C46-\\u0C48]|[\\u0C4A-\\u0C4D]|[\\u0C55-\\u0C56]|[\\u0CBF-\\u0CBF]|[\\u0CC6-\\u0CC6]|[\\u0CCC-\\u0CCD]|[\\u0D41-\\u0D43]|[\\u0D4D-\\u0D4D]|[\\u0E31-\\u0E31]|[\\u0E34-\\u0E3A]|[\\u0E47-\\u0E4E]|[\\u0EB1-\\u0EB1]|[\\u0EB4-\\u0EB9]|[\\u0EBB-\\u0EBC]|[\\u0EC8-\\u0ECD]|[\\u0F18-\\u0F19]|[\\u0F35-\\u0F35]|[\\u0F37-\\u0F37]|[\\u0F39-\\u0F39]|[\\u0F71-\\u0F7E]|[\\u0F80-\\u0F84]|[\\u0F86-\\u0F87]|[\\u0F90-\\u0F95]|[\\u0F97-\\u0F97]|[\\u0F99-\\u0FAD]|[\\u0FB1-\\u0FB7]|[\\u0FB9-\\u0FB9]|[\\u20D0-\\u20DC]|[\\u20E1-\\u20E1]|[\\u302A-\\u302F]|[\\u3099-\\u309A]|[\\uFB1E-\\uFB1E]|[\\uFE20-\\uFE23]/,\n  Mc   : /[\\u0903-\\u0903]|[\\u093E-\\u0940]|[\\u0949-\\u094C]|[\\u0982-\\u0983]|[\\u09BE-\\u09C0]|[\\u09C7-\\u09C8]|[\\u09CB-\\u09CC]|[\\u09D7-\\u09D7]|[\\u0A3E-\\u0A40]|[\\u0A83-\\u0A83]|[\\u0ABE-\\u0AC0]|[\\u0AC9-\\u0AC9]|[\\u0ACB-\\u0ACC]|[\\u0B02-\\u0B03]|[\\u0B3E-\\u0B3E]|[\\u0B40-\\u0B40]|[\\u0B47-\\u0B48]|[\\u0B4B-\\u0B4C]|[\\u0B57-\\u0B57]|[\\u0B83-\\u0B83]|[\\u0BBE-\\u0BBF]|[\\u0BC1-\\u0BC2]|[\\u0BC6-\\u0BC8]|[\\u0BCA-\\u0BCC]|[\\u0BD7-\\u0BD7]|[\\u0C01-\\u0C03]|[\\u0C41-\\u0C44]|[\\u0C82-\\u0C83]|[\\u0CBE-\\u0CBE]|[\\u0CC0-\\u0CC4]|[\\u0CC7-\\u0CC8]|[\\u0CCA-\\u0CCB]|[\\u0CD5-\\u0CD6]|[\\u0D02-\\u0D03]|[\\u0D3E-\\u0D40]|[\\u0D46-\\u0D48]|[\\u0D4A-\\u0D4C]|[\\u0D57-\\u0D57]|[\\u0F3E-\\u0F3F]|[\\u0F7F-\\u0F7F]/,\n  Nd   : /[\\u0030-\\u0039]|[\\u0660-\\u0669]|[\\u06F0-\\u06F9]|[\\u0966-\\u096F]|[\\u09E6-\\u09EF]|[\\u0A66-\\u0A6F]|[\\u0AE6-\\u0AEF]|[\\u0B66-\\u0B6F]|[\\u0BE7-\\u0BEF]|[\\u0C66-\\u0C6F]|[\\u0CE6-\\u0CEF]|[\\u0D66-\\u0D6F]|[\\u0E50-\\u0E59]|[\\u0ED0-\\u0ED9]|[\\u0F20-\\u0F29]|[\\uFF10-\\uFF19]/,\n  Pc   : /[\\u005F-\\u005F]|[\\u203F-\\u2040]|[\\u30FB-\\u30FB]|[\\uFE33-\\uFE34]|[\\uFE4D-\\uFE4F]|[\\uFF3F-\\uFF3F]|[\\uFF65-\\uFF65]/,\n  Zs   : /[\\u2000-\\u200B]|[\\u3000-\\u3000]/,\n};\n"]} +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["/Users/awarth/prog/ohm/node_modules/browserify/node_modules/browser-pack/_prelude.js","/Users/awarth/prog/ohm/dist/built-in-rules.js","/Users/awarth/prog/ohm/dist/ohm-grammar.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/buffer/index.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/buffer/node_modules/base64-js/lib/b64.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/buffer/node_modules/ieee754/index.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/crypto-browserify/helpers.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/crypto-browserify/index.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/crypto-browserify/md5.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/crypto-browserify/rng.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/crypto-browserify/sha.js","/Users/awarth/prog/ohm/node_modules/browserify/node_modules/crypto-browserify/sha256.js","/Users/awarth/prog/ohm/node_modules/inherits/inherits_browser.js","/Users/awarth/prog/ohm/node_modules/symbol/index.js","/Users/awarth/prog/ohm/node_modules/util-extend/extend.js","/Users/awarth/prog/ohm/src/Builder.js","/Users/awarth/prog/ohm/src/Grammar.js","/Users/awarth/prog/ohm/src/GrammarDecl.js","/Users/awarth/prog/ohm/src/InputStream.js","/Users/awarth/prog/ohm/src/Interval.js","/Users/awarth/prog/ohm/src/MatchResult.js","/Users/awarth/prog/ohm/src/Namespace.js","/Users/awarth/prog/ohm/src/PosInfo.js","/Users/awarth/prog/ohm/src/Semantics.js","/Users/awarth/prog/ohm/src/State.js","/Users/awarth/prog/ohm/src/Trace.js","/Users/awarth/prog/ohm/src/common.js","/Users/awarth/prog/ohm/src/errors.js","/Users/awarth/prog/ohm/src/main.js","/Users/awarth/prog/ohm/src/nodes.js","/Users/awarth/prog/ohm/src/pexprs-assertAllApplicationsAreValid.js","/Users/awarth/prog/ohm/src/pexprs-assertChoicesHaveUniformArity.js","/Users/awarth/prog/ohm/src/pexprs-assertIteratedExprsAreNotNullable.js","/Users/awarth/prog/ohm/src/pexprs-check.js","/Users/awarth/prog/ohm/src/pexprs-eval.js","/Users/awarth/prog/ohm/src/pexprs-getArity.js","/Users/awarth/prog/ohm/src/pexprs-introduceParams.js","/Users/awarth/prog/ohm/src/pexprs-isNullable.js","/Users/awarth/prog/ohm/src/pexprs-maybeRecordFailure.js","/Users/awarth/prog/ohm/src/pexprs-outputRecipe.js","/Users/awarth/prog/ohm/src/pexprs-substituteParams.js","/Users/awarth/prog/ohm/src/pexprs-toDisplayString.js","/Users/awarth/prog/ohm/src/pexprs-toExpected.js","/Users/awarth/prog/ohm/src/pexprs-toString.js","/Users/awarth/prog/ohm/src/pexprs.js","/Users/awarth/prog/ohm/src/util.js","/Users/awarth/prog/ohm/third_party/unicode.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrlCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7SA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/ZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3YA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5aA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);throw new Error(\"Cannot find module '\"+o+\"'\")}var f=n[o]={exports:{}};t[o][0].call(f.exports,function(e){var n=t[o][1][e];return s(n?n:e)},f,f.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","var ohm = require('..');\nmodule.exports = ohm.makeRecipe(function() {\n  return new this.newGrammar('BuiltInRules')\n    .define('alnum', [], this.prim(/[0-9a-zA-Z]/), 'an alpha-numeric character')\n    .define('letter', [], this.prim(/[a-zA-Z]/), 'a letter')\n    .define('lower', [], this.prim(/[a-z]/), 'a lower-case letter')\n    .define('upper', [], this.prim(/[A-Z]/), 'an upper-case letter')\n    .define('digit', [], this.prim(/[0-9]/), 'a digit')\n    .define('hexDigit', [], this.prim(/[0-9a-fA-F]/), 'a hexadecimal digit')\n    .define('ListOf_some', ['elem', 'sep'], this.seq(this.param(0), this.star(this.seq(this.param(1), this.param(0)))))\n    .define('ListOf_none', ['elem', 'sep'], this.seq())\n    .define('ListOf', ['elem', 'sep'], this.alt(this.app('ListOf_some', [this.app('elem'), this.app('sep')]), this.app('ListOf_none', [this.app('elem'), this.app('sep')])))\n    .build();\n});\n\n","var ohm = require('..');\nmodule.exports = ohm.makeRecipe(function() {\n  return new this.newGrammar('Ohm')\n    .withDefaultStartRule('Grammars')\n    .define('Grammars', [], this.star(this.app('Grammar')))\n    .define('Grammar', [], this.seq(this.app('ident'), this.opt(this.app('SuperGrammar')), this.prim('{'), this.star(this.app('Rule')), this.prim('}')))\n    .define('SuperGrammar', [], this.seq(this.prim('<:'), this.app('ident')))\n    .define('Rule_define', [], this.seq(this.app('ident'), this.opt(this.app('Formals')), this.opt(this.app('ruleDescr')), this.prim('='), this.app('Alt')))\n    .define('Rule_override', [], this.seq(this.app('ident'), this.opt(this.app('Formals')), this.prim(':='), this.app('Alt')))\n    .define('Rule_extend', [], this.seq(this.app('ident'), this.opt(this.app('Formals')), this.prim('+='), this.app('Alt')))\n    .define('Rule', [], this.alt(this.app('Rule_define'), this.app('Rule_override'), this.app('Rule_extend')))\n    .define('Formals', [], this.seq(this.prim('<'), this.app('ListOf', [this.app('ident'), this.prim(',')]), this.prim('>')))\n    .define('Params', [], this.seq(this.prim('<'), this.app('ListOf', [this.app('Seq'), this.prim(',')]), this.prim('>')))\n    .define('Alt', [], this.seq(this.app('Term'), this.star(this.seq(this.prim('|'), this.app('Term')))))\n    .define('Term_inline', [], this.seq(this.app('Seq'), this.app('caseName')))\n    .define('Term', [], this.alt(this.app('Term_inline'), this.app('Seq')))\n    .define('Seq', [], this.star(this.app('Iter')))\n    .define('Iter_star', [], this.seq(this.app('Pred'), this.prim('*')))\n    .define('Iter_plus', [], this.seq(this.app('Pred'), this.prim('+')))\n    .define('Iter_opt', [], this.seq(this.app('Pred'), this.prim('?')))\n    .define('Iter', [], this.alt(this.app('Iter_star'), this.app('Iter_plus'), this.app('Iter_opt'), this.app('Pred')))\n    .define('Pred_not', [], this.seq(this.prim('~'), this.app('Base')))\n    .define('Pred_lookahead', [], this.seq(this.prim('&'), this.app('Base')))\n    .define('Pred', [], this.alt(this.app('Pred_not'), this.app('Pred_lookahead'), this.app('Base')))\n    .define('Base_application', [], this.seq(this.app('ident'), this.opt(this.app('Params')), this.not(this.alt(this.seq(this.opt(this.app('ruleDescr')), this.prim('=')), this.prim(':='), this.prim('+=')))))\n    .define('Base_prim', [], this.alt(this.app('keyword'), this.app('string'), this.app('regExp'), this.app('number')))\n    .define('Base_paren', [], this.seq(this.prim('('), this.app('Alt'), this.prim(')')))\n    .define('Base_arr', [], this.seq(this.prim('['), this.app('Alt'), this.prim(']')))\n    .define('Base_str', [], this.seq(this.prim('``'), this.app('Alt'), this.prim(\"''\")))\n    .define('Base_obj', [], this.seq(this.prim('{'), this.opt(this.prim('...')), this.prim('}')))\n    .define('Base_objWithProps', [], this.seq(this.prim('{'), this.app('Props'), this.opt(this.seq(this.prim(','), this.prim('...'))), this.prim('}')))\n    .define('Base', [], this.alt(this.app('Base_application'), this.app('Base_prim'), this.app('Base_paren'), this.app('Base_arr'), this.app('Base_str'), this.app('Base_obj'), this.app('Base_objWithProps')))\n    .define('Props', [], this.seq(this.app('Prop'), this.star(this.seq(this.prim(','), this.app('Prop')))))\n    .define('Prop', [], this.seq(this.alt(this.app('name'), this.app('string')), this.prim(':'), this.app('Alt')))\n    .define('ruleDescr', [], this.seq(this.prim('('), this.app('ruleDescrText'), this.prim(')')), 'a rule description')\n    .define('ruleDescrText', [], this.star(this.seq(this.not(this.prim(')')), this.app('_'))))\n    .define('caseName', [], this.seq(this.prim('--'), this.star(this.seq(this.not(this.prim('\\n')), this.app('space'))), this.app('name'), this.star(this.seq(this.not(this.prim('\\n')), this.app('space'))), this.alt(this.prim('\\n'), this.la(this.prim('}')))))\n    .define('name', [], this.seq(this.app('nameFirst'), this.star(this.app('nameRest'))), 'a name')\n    .define('nameFirst', [], this.alt(this.prim('_'), this.app('letter')))\n    .define('nameRest', [], this.alt(this.prim('_'), this.app('alnum')))\n    .define('ident', [], this.seq(this.not(this.app('keyword')), this.app('name')), 'an identifier')\n    .define('keyword_null', [], this.seq(this.prim('null'), this.not(this.app('nameRest'))))\n    .define('keyword_true', [], this.seq(this.prim('true'), this.not(this.app('nameRest'))))\n    .define('keyword_false', [], this.seq(this.prim('false'), this.not(this.app('nameRest'))))\n    .define('keyword', [], this.alt(this.app('keyword_null'), this.app('keyword_true'), this.app('keyword_false')))\n    .define('string', [], this.seq(this.prim('\"'), this.star(this.app('strChar')), this.prim('\"')), 'a string literal')\n    .define('strChar', [], this.alt(this.app('escapeChar'), this.seq(this.not(this.prim('\\\\')), this.not(this.prim('\"')), this.not(this.prim('\\n')), this.app('_'))))\n    .define('escapeChar_backslash', [], this.prim('\\\\\\\\'))\n    .define('escapeChar_doubleQuote', [], this.prim('\\\\\"'))\n    .define('escapeChar_singleQuote', [], this.prim(\"\\\\'\"))\n    .define('escapeChar_backspace', [], this.prim('\\\\b'))\n    .define('escapeChar_lineFeed', [], this.prim('\\\\n'))\n    .define('escapeChar_carriageReturn', [], this.prim('\\\\r'))\n    .define('escapeChar_tab', [], this.prim('\\\\t'))\n    .define('escapeChar_unicodeEscape', [], this.seq(this.prim('\\\\u'), this.app('hexDigit'), this.app('hexDigit'), this.app('hexDigit'), this.app('hexDigit')))\n    .define('escapeChar_hexEscape', [], this.seq(this.prim('\\\\x'), this.app('hexDigit'), this.app('hexDigit')))\n    .define('escapeChar', [], this.alt(this.app('escapeChar_backslash'), this.app('escapeChar_doubleQuote'), this.app('escapeChar_singleQuote'), this.app('escapeChar_backspace'), this.app('escapeChar_lineFeed'), this.app('escapeChar_carriageReturn'), this.app('escapeChar_tab'), this.app('escapeChar_unicodeEscape'), this.app('escapeChar_hexEscape')))\n    .define('regExp', [], this.seq(this.prim('/'), this.app('reCharClass'), this.prim('/')), 'a regular expression')\n    .define('reCharClass_unicode', [], this.seq(this.prim('\\\\p{'), this.plus(this.prim(/[A-Za-z]/)), this.prim('}')))\n    .define('reCharClass_ordinary', [], this.seq(this.prim('['), this.star(this.alt(this.prim('\\\\]'), this.seq(this.not(this.prim(']')), this.app('_')))), this.prim(']')))\n    .define('reCharClass', [], this.alt(this.app('reCharClass_unicode'), this.app('reCharClass_ordinary')))\n    .define('number', [], this.seq(this.opt(this.prim('-')), this.plus(this.app('digit'))), 'a number')\n    .define('space_singleLine', [], this.seq(this.prim('//'), this.star(this.seq(this.not(this.prim('\\n')), this.app('_'))), this.prim('\\n')))\n    .define('space_multiLine', [], this.seq(this.prim('/*'), this.star(this.seq(this.not(this.prim('*/')), this.app('_'))), this.prim('*/')))\n    .extend('space', [], this.alt(this.alt(this.app('space_singleLine'), this.app('space_multiLine')), this.prim(/[\\s]/)), 'a space')\n    .build();\n});\n\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * @license  MIT\n */\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = Buffer\nexports.INSPECT_MAX_BYTES = 50\nBuffer.poolSize = 8192\n\n/**\n * If `Buffer._useTypedArrays`:\n *   === true    Use Uint8Array implementation (fastest)\n *   === false   Use Object implementation (compatible down to IE6)\n */\nBuffer._useTypedArrays = (function () {\n  // Detect if browser supports Typed Arrays. Supported browsers are IE 10+, Firefox 4+,\n  // Chrome 7+, Safari 5.1+, Opera 11.6+, iOS 4.2+. If the browser does not support adding\n  // properties to `Uint8Array` instances, then that's the same as no `Uint8Array` support\n  // because we need to be able to add all the node Buffer API methods. This is an issue\n  // in Firefox 4-29. Now fixed: https://bugzilla.mozilla.org/show_bug.cgi?id=695438\n  try {\n    var buf = new ArrayBuffer(0)\n    var arr = new Uint8Array(buf)\n    arr.foo = function () { return 42 }\n    return 42 === arr.foo() &&\n        typeof arr.subarray === 'function' // Chrome 9-10 lack `subarray`\n  } catch (e) {\n    return false\n  }\n})()\n\n/**\n * Class: Buffer\n * =============\n *\n * The Buffer constructor returns instances of `Uint8Array` that are augmented\n * with function properties for all the node `Buffer` API functions. We use\n * `Uint8Array` so that square bracket notation works as expected -- it returns\n * a single octet.\n *\n * By augmenting the instances, we can avoid modifying the `Uint8Array`\n * prototype.\n */\nfunction Buffer (subject, encoding, noZero) {\n  if (!(this instanceof Buffer))\n    return new Buffer(subject, encoding, noZero)\n\n  var type = typeof subject\n\n  // Workaround: node's base64 implementation allows for non-padded strings\n  // while base64-js does not.\n  if (encoding === 'base64' && type === 'string') {\n    subject = stringtrim(subject)\n    while (subject.length % 4 !== 0) {\n      subject = subject + '='\n    }\n  }\n\n  // Find the length\n  var length\n  if (type === 'number')\n    length = coerce(subject)\n  else if (type === 'string')\n    length = Buffer.byteLength(subject, encoding)\n  else if (type === 'object')\n    length = coerce(subject.length) // assume that object is array-like\n  else\n    throw new Error('First argument needs to be a number, array or string.')\n\n  var buf\n  if (Buffer._useTypedArrays) {\n    // Preferred: Return an augmented `Uint8Array` instance for best performance\n    buf = Buffer._augment(new Uint8Array(length))\n  } else {\n    // Fallback: Return THIS instance of Buffer (created by `new`)\n    buf = this\n    buf.length = length\n    buf._isBuffer = true\n  }\n\n  var i\n  if (Buffer._useTypedArrays && typeof subject.byteLength === 'number') {\n    // Speed optimization -- use set if we're copying from a typed array\n    buf._set(subject)\n  } else if (isArrayish(subject)) {\n    // Treat array-ish objects as a byte array\n    for (i = 0; i < length; i++) {\n      if (Buffer.isBuffer(subject))\n        buf[i] = subject.readUInt8(i)\n      else\n        buf[i] = subject[i]\n    }\n  } else if (type === 'string') {\n    buf.write(subject, 0, encoding)\n  } else if (type === 'number' && !Buffer._useTypedArrays && !noZero) {\n    for (i = 0; i < length; i++) {\n      buf[i] = 0\n    }\n  }\n\n  return buf\n}\n\n// STATIC METHODS\n// ==============\n\nBuffer.isEncoding = function (encoding) {\n  switch (String(encoding).toLowerCase()) {\n    case 'hex':\n    case 'utf8':\n    case 'utf-8':\n    case 'ascii':\n    case 'binary':\n    case 'base64':\n    case 'raw':\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      return true\n    default:\n      return false\n  }\n}\n\nBuffer.isBuffer = function (b) {\n  return !!(b !== null && b !== undefined && b._isBuffer)\n}\n\nBuffer.byteLength = function (str, encoding) {\n  var ret\n  str = str + ''\n  switch (encoding || 'utf8') {\n    case 'hex':\n      ret = str.length / 2\n      break\n    case 'utf8':\n    case 'utf-8':\n      ret = utf8ToBytes(str).length\n      break\n    case 'ascii':\n    case 'binary':\n    case 'raw':\n      ret = str.length\n      break\n    case 'base64':\n      ret = base64ToBytes(str).length\n      break\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      ret = str.length * 2\n      break\n    default:\n      throw new Error('Unknown encoding')\n  }\n  return ret\n}\n\nBuffer.concat = function (list, totalLength) {\n  assert(isArray(list), 'Usage: Buffer.concat(list, [totalLength])\\n' +\n      'list should be an Array.')\n\n  if (list.length === 0) {\n    return new Buffer(0)\n  } else if (list.length === 1) {\n    return list[0]\n  }\n\n  var i\n  if (typeof totalLength !== 'number') {\n    totalLength = 0\n    for (i = 0; i < list.length; i++) {\n      totalLength += list[i].length\n    }\n  }\n\n  var buf = new Buffer(totalLength)\n  var pos = 0\n  for (i = 0; i < list.length; i++) {\n    var item = list[i]\n    item.copy(buf, pos)\n    pos += item.length\n  }\n  return buf\n}\n\n// BUFFER INSTANCE METHODS\n// =======================\n\nfunction _hexWrite (buf, string, offset, length) {\n  offset = Number(offset) || 0\n  var remaining = buf.length - offset\n  if (!length) {\n    length = remaining\n  } else {\n    length = Number(length)\n    if (length > remaining) {\n      length = remaining\n    }\n  }\n\n  // must be an even number of digits\n  var strLen = string.length\n  assert(strLen % 2 === 0, 'Invalid hex string')\n\n  if (length > strLen / 2) {\n    length = strLen / 2\n  }\n  for (var i = 0; i < length; i++) {\n    var byte = parseInt(string.substr(i * 2, 2), 16)\n    assert(!isNaN(byte), 'Invalid hex string')\n    buf[offset + i] = byte\n  }\n  Buffer._charsWritten = i * 2\n  return i\n}\n\nfunction _utf8Write (buf, string, offset, length) {\n  var charsWritten = Buffer._charsWritten =\n    blitBuffer(utf8ToBytes(string), buf, offset, length)\n  return charsWritten\n}\n\nfunction _asciiWrite (buf, string, offset, length) {\n  var charsWritten = Buffer._charsWritten =\n    blitBuffer(asciiToBytes(string), buf, offset, length)\n  return charsWritten\n}\n\nfunction _binaryWrite (buf, string, offset, length) {\n  return _asciiWrite(buf, string, offset, length)\n}\n\nfunction _base64Write (buf, string, offset, length) {\n  var charsWritten = Buffer._charsWritten =\n    blitBuffer(base64ToBytes(string), buf, offset, length)\n  return charsWritten\n}\n\nfunction _utf16leWrite (buf, string, offset, length) {\n  var charsWritten = Buffer._charsWritten =\n    blitBuffer(utf16leToBytes(string), buf, offset, length)\n  return charsWritten\n}\n\nBuffer.prototype.write = function (string, offset, length, encoding) {\n  // Support both (string, offset, length, encoding)\n  // and the legacy (string, encoding, offset, length)\n  if (isFinite(offset)) {\n    if (!isFinite(length)) {\n      encoding = length\n      length = undefined\n    }\n  } else {  // legacy\n    var swap = encoding\n    encoding = offset\n    offset = length\n    length = swap\n  }\n\n  offset = Number(offset) || 0\n  var remaining = this.length - offset\n  if (!length) {\n    length = remaining\n  } else {\n    length = Number(length)\n    if (length > remaining) {\n      length = remaining\n    }\n  }\n  encoding = String(encoding || 'utf8').toLowerCase()\n\n  var ret\n  switch (encoding) {\n    case 'hex':\n      ret = _hexWrite(this, string, offset, length)\n      break\n    case 'utf8':\n    case 'utf-8':\n      ret = _utf8Write(this, string, offset, length)\n      break\n    case 'ascii':\n      ret = _asciiWrite(this, string, offset, length)\n      break\n    case 'binary':\n      ret = _binaryWrite(this, string, offset, length)\n      break\n    case 'base64':\n      ret = _base64Write(this, string, offset, length)\n      break\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      ret = _utf16leWrite(this, string, offset, length)\n      break\n    default:\n      throw new Error('Unknown encoding')\n  }\n  return ret\n}\n\nBuffer.prototype.toString = function (encoding, start, end) {\n  var self = this\n\n  encoding = String(encoding || 'utf8').toLowerCase()\n  start = Number(start) || 0\n  end = (end !== undefined)\n    ? Number(end)\n    : end = self.length\n\n  // Fastpath empty strings\n  if (end === start)\n    return ''\n\n  var ret\n  switch (encoding) {\n    case 'hex':\n      ret = _hexSlice(self, start, end)\n      break\n    case 'utf8':\n    case 'utf-8':\n      ret = _utf8Slice(self, start, end)\n      break\n    case 'ascii':\n      ret = _asciiSlice(self, start, end)\n      break\n    case 'binary':\n      ret = _binarySlice(self, start, end)\n      break\n    case 'base64':\n      ret = _base64Slice(self, start, end)\n      break\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      ret = _utf16leSlice(self, start, end)\n      break\n    default:\n      throw new Error('Unknown encoding')\n  }\n  return ret\n}\n\nBuffer.prototype.toJSON = function () {\n  return {\n    type: 'Buffer',\n    data: Array.prototype.slice.call(this._arr || this, 0)\n  }\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function (target, target_start, start, end) {\n  var source = this\n\n  if (!start) start = 0\n  if (!end && end !== 0) end = this.length\n  if (!target_start) target_start = 0\n\n  // Copy 0 bytes; we're done\n  if (end === start) return\n  if (target.length === 0 || source.length === 0) return\n\n  // Fatal error conditions\n  assert(end >= start, 'sourceEnd < sourceStart')\n  assert(target_start >= 0 && target_start < target.length,\n      'targetStart out of bounds')\n  assert(start >= 0 && start < source.length, 'sourceStart out of bounds')\n  assert(end >= 0 && end <= source.length, 'sourceEnd out of bounds')\n\n  // Are we oob?\n  if (end > this.length)\n    end = this.length\n  if (target.length - target_start < end - start)\n    end = target.length - target_start + start\n\n  var len = end - start\n\n  if (len < 100 || !Buffer._useTypedArrays) {\n    for (var i = 0; i < len; i++)\n      target[i + target_start] = this[i + start]\n  } else {\n    target._set(this.subarray(start, start + len), target_start)\n  }\n}\n\nfunction _base64Slice (buf, start, end) {\n  if (start === 0 && end === buf.length) {\n    return base64.fromByteArray(buf)\n  } else {\n    return base64.fromByteArray(buf.slice(start, end))\n  }\n}\n\nfunction _utf8Slice (buf, start, end) {\n  var res = ''\n  var tmp = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; i++) {\n    if (buf[i] <= 0x7F) {\n      res += decodeUtf8Char(tmp) + String.fromCharCode(buf[i])\n      tmp = ''\n    } else {\n      tmp += '%' + buf[i].toString(16)\n    }\n  }\n\n  return res + decodeUtf8Char(tmp)\n}\n\nfunction _asciiSlice (buf, start, end) {\n  var ret = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; i++)\n    ret += String.fromCharCode(buf[i])\n  return ret\n}\n\nfunction _binarySlice (buf, start, end) {\n  return _asciiSlice(buf, start, end)\n}\n\nfunction _hexSlice (buf, start, end) {\n  var len = buf.length\n\n  if (!start || start < 0) start = 0\n  if (!end || end < 0 || end > len) end = len\n\n  var out = ''\n  for (var i = start; i < end; i++) {\n    out += toHex(buf[i])\n  }\n  return out\n}\n\nfunction _utf16leSlice (buf, start, end) {\n  var bytes = buf.slice(start, end)\n  var res = ''\n  for (var i = 0; i < bytes.length; i += 2) {\n    res += String.fromCharCode(bytes[i] + bytes[i+1] * 256)\n  }\n  return res\n}\n\nBuffer.prototype.slice = function (start, end) {\n  var len = this.length\n  start = clamp(start, len, 0)\n  end = clamp(end, len, len)\n\n  if (Buffer._useTypedArrays) {\n    return Buffer._augment(this.subarray(start, end))\n  } else {\n    var sliceLen = end - start\n    var newBuf = new Buffer(sliceLen, undefined, true)\n    for (var i = 0; i < sliceLen; i++) {\n      newBuf[i] = this[i + start]\n    }\n    return newBuf\n  }\n}\n\n// `get` will be removed in Node 0.13+\nBuffer.prototype.get = function (offset) {\n  console.log('.get() is deprecated. Access using array indexes instead.')\n  return this.readUInt8(offset)\n}\n\n// `set` will be removed in Node 0.13+\nBuffer.prototype.set = function (v, offset) {\n  console.log('.set() is deprecated. Access using array indexes instead.')\n  return this.writeUInt8(v, offset)\n}\n\nBuffer.prototype.readUInt8 = function (offset, noAssert) {\n  if (!noAssert) {\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset < this.length, 'Trying to read beyond buffer length')\n  }\n\n  if (offset >= this.length)\n    return\n\n  return this[offset]\n}\n\nfunction _readUInt16 (buf, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 1 < buf.length, 'Trying to read beyond buffer length')\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  var val\n  if (littleEndian) {\n    val = buf[offset]\n    if (offset + 1 < len)\n      val |= buf[offset + 1] << 8\n  } else {\n    val = buf[offset] << 8\n    if (offset + 1 < len)\n      val |= buf[offset + 1]\n  }\n  return val\n}\n\nBuffer.prototype.readUInt16LE = function (offset, noAssert) {\n  return _readUInt16(this, offset, true, noAssert)\n}\n\nBuffer.prototype.readUInt16BE = function (offset, noAssert) {\n  return _readUInt16(this, offset, false, noAssert)\n}\n\nfunction _readUInt32 (buf, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 3 < buf.length, 'Trying to read beyond buffer length')\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  var val\n  if (littleEndian) {\n    if (offset + 2 < len)\n      val = buf[offset + 2] << 16\n    if (offset + 1 < len)\n      val |= buf[offset + 1] << 8\n    val |= buf[offset]\n    if (offset + 3 < len)\n      val = val + (buf[offset + 3] << 24 >>> 0)\n  } else {\n    if (offset + 1 < len)\n      val = buf[offset + 1] << 16\n    if (offset + 2 < len)\n      val |= buf[offset + 2] << 8\n    if (offset + 3 < len)\n      val |= buf[offset + 3]\n    val = val + (buf[offset] << 24 >>> 0)\n  }\n  return val\n}\n\nBuffer.prototype.readUInt32LE = function (offset, noAssert) {\n  return _readUInt32(this, offset, true, noAssert)\n}\n\nBuffer.prototype.readUInt32BE = function (offset, noAssert) {\n  return _readUInt32(this, offset, false, noAssert)\n}\n\nBuffer.prototype.readInt8 = function (offset, noAssert) {\n  if (!noAssert) {\n    assert(offset !== undefined && offset !== null,\n        'missing offset')\n    assert(offset < this.length, 'Trying to read beyond buffer length')\n  }\n\n  if (offset >= this.length)\n    return\n\n  var neg = this[offset] & 0x80\n  if (neg)\n    return (0xff - this[offset] + 1) * -1\n  else\n    return this[offset]\n}\n\nfunction _readInt16 (buf, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 1 < buf.length, 'Trying to read beyond buffer length')\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  var val = _readUInt16(buf, offset, littleEndian, true)\n  var neg = val & 0x8000\n  if (neg)\n    return (0xffff - val + 1) * -1\n  else\n    return val\n}\n\nBuffer.prototype.readInt16LE = function (offset, noAssert) {\n  return _readInt16(this, offset, true, noAssert)\n}\n\nBuffer.prototype.readInt16BE = function (offset, noAssert) {\n  return _readInt16(this, offset, false, noAssert)\n}\n\nfunction _readInt32 (buf, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 3 < buf.length, 'Trying to read beyond buffer length')\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  var val = _readUInt32(buf, offset, littleEndian, true)\n  var neg = val & 0x80000000\n  if (neg)\n    return (0xffffffff - val + 1) * -1\n  else\n    return val\n}\n\nBuffer.prototype.readInt32LE = function (offset, noAssert) {\n  return _readInt32(this, offset, true, noAssert)\n}\n\nBuffer.prototype.readInt32BE = function (offset, noAssert) {\n  return _readInt32(this, offset, false, noAssert)\n}\n\nfunction _readFloat (buf, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset + 3 < buf.length, 'Trying to read beyond buffer length')\n  }\n\n  return ieee754.read(buf, offset, littleEndian, 23, 4)\n}\n\nBuffer.prototype.readFloatLE = function (offset, noAssert) {\n  return _readFloat(this, offset, true, noAssert)\n}\n\nBuffer.prototype.readFloatBE = function (offset, noAssert) {\n  return _readFloat(this, offset, false, noAssert)\n}\n\nfunction _readDouble (buf, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset + 7 < buf.length, 'Trying to read beyond buffer length')\n  }\n\n  return ieee754.read(buf, offset, littleEndian, 52, 8)\n}\n\nBuffer.prototype.readDoubleLE = function (offset, noAssert) {\n  return _readDouble(this, offset, true, noAssert)\n}\n\nBuffer.prototype.readDoubleBE = function (offset, noAssert) {\n  return _readDouble(this, offset, false, noAssert)\n}\n\nBuffer.prototype.writeUInt8 = function (value, offset, noAssert) {\n  if (!noAssert) {\n    assert(value !== undefined && value !== null, 'missing value')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset < this.length, 'trying to write beyond buffer length')\n    verifuint(value, 0xff)\n  }\n\n  if (offset >= this.length) return\n\n  this[offset] = value\n}\n\nfunction _writeUInt16 (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(value !== undefined && value !== null, 'missing value')\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 1 < buf.length, 'trying to write beyond buffer length')\n    verifuint(value, 0xffff)\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  for (var i = 0, j = Math.min(len - offset, 2); i < j; i++) {\n    buf[offset + i] =\n        (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>\n            (littleEndian ? i : 1 - i) * 8\n  }\n}\n\nBuffer.prototype.writeUInt16LE = function (value, offset, noAssert) {\n  _writeUInt16(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeUInt16BE = function (value, offset, noAssert) {\n  _writeUInt16(this, value, offset, false, noAssert)\n}\n\nfunction _writeUInt32 (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(value !== undefined && value !== null, 'missing value')\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 3 < buf.length, 'trying to write beyond buffer length')\n    verifuint(value, 0xffffffff)\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  for (var i = 0, j = Math.min(len - offset, 4); i < j; i++) {\n    buf[offset + i] =\n        (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff\n  }\n}\n\nBuffer.prototype.writeUInt32LE = function (value, offset, noAssert) {\n  _writeUInt32(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeUInt32BE = function (value, offset, noAssert) {\n  _writeUInt32(this, value, offset, false, noAssert)\n}\n\nBuffer.prototype.writeInt8 = function (value, offset, noAssert) {\n  if (!noAssert) {\n    assert(value !== undefined && value !== null, 'missing value')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset < this.length, 'Trying to write beyond buffer length')\n    verifsint(value, 0x7f, -0x80)\n  }\n\n  if (offset >= this.length)\n    return\n\n  if (value >= 0)\n    this.writeUInt8(value, offset, noAssert)\n  else\n    this.writeUInt8(0xff + value + 1, offset, noAssert)\n}\n\nfunction _writeInt16 (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(value !== undefined && value !== null, 'missing value')\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 1 < buf.length, 'Trying to write beyond buffer length')\n    verifsint(value, 0x7fff, -0x8000)\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  if (value >= 0)\n    _writeUInt16(buf, value, offset, littleEndian, noAssert)\n  else\n    _writeUInt16(buf, 0xffff + value + 1, offset, littleEndian, noAssert)\n}\n\nBuffer.prototype.writeInt16LE = function (value, offset, noAssert) {\n  _writeInt16(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeInt16BE = function (value, offset, noAssert) {\n  _writeInt16(this, value, offset, false, noAssert)\n}\n\nfunction _writeInt32 (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(value !== undefined && value !== null, 'missing value')\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 3 < buf.length, 'Trying to write beyond buffer length')\n    verifsint(value, 0x7fffffff, -0x80000000)\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  if (value >= 0)\n    _writeUInt32(buf, value, offset, littleEndian, noAssert)\n  else\n    _writeUInt32(buf, 0xffffffff + value + 1, offset, littleEndian, noAssert)\n}\n\nBuffer.prototype.writeInt32LE = function (value, offset, noAssert) {\n  _writeInt32(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeInt32BE = function (value, offset, noAssert) {\n  _writeInt32(this, value, offset, false, noAssert)\n}\n\nfunction _writeFloat (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(value !== undefined && value !== null, 'missing value')\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 3 < buf.length, 'Trying to write beyond buffer length')\n    verifIEEE754(value, 3.4028234663852886e+38, -3.4028234663852886e+38)\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  ieee754.write(buf, value, offset, littleEndian, 23, 4)\n}\n\nBuffer.prototype.writeFloatLE = function (value, offset, noAssert) {\n  _writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function (value, offset, noAssert) {\n  _writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction _writeDouble (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    assert(value !== undefined && value !== null, 'missing value')\n    assert(typeof littleEndian === 'boolean', 'missing or invalid endian')\n    assert(offset !== undefined && offset !== null, 'missing offset')\n    assert(offset + 7 < buf.length,\n        'Trying to write beyond buffer length')\n    verifIEEE754(value, 1.7976931348623157E+308, -1.7976931348623157E+308)\n  }\n\n  var len = buf.length\n  if (offset >= len)\n    return\n\n  ieee754.write(buf, value, offset, littleEndian, 52, 8)\n}\n\nBuffer.prototype.writeDoubleLE = function (value, offset, noAssert) {\n  _writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function (value, offset, noAssert) {\n  _writeDouble(this, value, offset, false, noAssert)\n}\n\n// fill(value, start=0, end=buffer.length)\nBuffer.prototype.fill = function (value, start, end) {\n  if (!value) value = 0\n  if (!start) start = 0\n  if (!end) end = this.length\n\n  if (typeof value === 'string') {\n    value = value.charCodeAt(0)\n  }\n\n  assert(typeof value === 'number' && !isNaN(value), 'value is not a number')\n  assert(end >= start, 'end < start')\n\n  // Fill 0 bytes; we're done\n  if (end === start) return\n  if (this.length === 0) return\n\n  assert(start >= 0 && start < this.length, 'start out of bounds')\n  assert(end >= 0 && end <= this.length, 'end out of bounds')\n\n  for (var i = start; i < end; i++) {\n    this[i] = value\n  }\n}\n\nBuffer.prototype.inspect = function () {\n  var out = []\n  var len = this.length\n  for (var i = 0; i < len; i++) {\n    out[i] = toHex(this[i])\n    if (i === exports.INSPECT_MAX_BYTES) {\n      out[i + 1] = '...'\n      break\n    }\n  }\n  return '<Buffer ' + out.join(' ') + '>'\n}\n\n/**\n * Creates a new `ArrayBuffer` with the *copied* memory of the buffer instance.\n * Added in Node 0.12. Only available in browsers that support ArrayBuffer.\n */\nBuffer.prototype.toArrayBuffer = function () {\n  if (typeof Uint8Array !== 'undefined') {\n    if (Buffer._useTypedArrays) {\n      return (new Buffer(this)).buffer\n    } else {\n      var buf = new Uint8Array(this.length)\n      for (var i = 0, len = buf.length; i < len; i += 1)\n        buf[i] = this[i]\n      return buf.buffer\n    }\n  } else {\n    throw new Error('Buffer.toArrayBuffer not supported in this browser')\n  }\n}\n\n// HELPER FUNCTIONS\n// ================\n\nfunction stringtrim (str) {\n  if (str.trim) return str.trim()\n  return str.replace(/^\\s+|\\s+$/g, '')\n}\n\nvar BP = Buffer.prototype\n\n/**\n * Augment a Uint8Array *instance* (not the Uint8Array class!) with Buffer methods\n */\nBuffer._augment = function (arr) {\n  arr._isBuffer = true\n\n  // save reference to original Uint8Array get/set methods before overwriting\n  arr._get = arr.get\n  arr._set = arr.set\n\n  // deprecated, will be removed in node 0.13+\n  arr.get = BP.get\n  arr.set = BP.set\n\n  arr.write = BP.write\n  arr.toString = BP.toString\n  arr.toLocaleString = BP.toString\n  arr.toJSON = BP.toJSON\n  arr.copy = BP.copy\n  arr.slice = BP.slice\n  arr.readUInt8 = BP.readUInt8\n  arr.readUInt16LE = BP.readUInt16LE\n  arr.readUInt16BE = BP.readUInt16BE\n  arr.readUInt32LE = BP.readUInt32LE\n  arr.readUInt32BE = BP.readUInt32BE\n  arr.readInt8 = BP.readInt8\n  arr.readInt16LE = BP.readInt16LE\n  arr.readInt16BE = BP.readInt16BE\n  arr.readInt32LE = BP.readInt32LE\n  arr.readInt32BE = BP.readInt32BE\n  arr.readFloatLE = BP.readFloatLE\n  arr.readFloatBE = BP.readFloatBE\n  arr.readDoubleLE = BP.readDoubleLE\n  arr.readDoubleBE = BP.readDoubleBE\n  arr.writeUInt8 = BP.writeUInt8\n  arr.writeUInt16LE = BP.writeUInt16LE\n  arr.writeUInt16BE = BP.writeUInt16BE\n  arr.writeUInt32LE = BP.writeUInt32LE\n  arr.writeUInt32BE = BP.writeUInt32BE\n  arr.writeInt8 = BP.writeInt8\n  arr.writeInt16LE = BP.writeInt16LE\n  arr.writeInt16BE = BP.writeInt16BE\n  arr.writeInt32LE = BP.writeInt32LE\n  arr.writeInt32BE = BP.writeInt32BE\n  arr.writeFloatLE = BP.writeFloatLE\n  arr.writeFloatBE = BP.writeFloatBE\n  arr.writeDoubleLE = BP.writeDoubleLE\n  arr.writeDoubleBE = BP.writeDoubleBE\n  arr.fill = BP.fill\n  arr.inspect = BP.inspect\n  arr.toArrayBuffer = BP.toArrayBuffer\n\n  return arr\n}\n\n// slice(start, end)\nfunction clamp (index, len, defaultValue) {\n  if (typeof index !== 'number') return defaultValue\n  index = ~~index;  // Coerce to integer.\n  if (index >= len) return len\n  if (index >= 0) return index\n  index += len\n  if (index >= 0) return index\n  return 0\n}\n\nfunction coerce (length) {\n  // Coerce length to a number (possibly NaN), round up\n  // in case it's fractional (e.g. 123.456) then do a\n  // double negate to coerce a NaN to 0. Easy, right?\n  length = ~~Math.ceil(+length)\n  return length < 0 ? 0 : length\n}\n\nfunction isArray (subject) {\n  return (Array.isArray || function (subject) {\n    return Object.prototype.toString.call(subject) === '[object Array]'\n  })(subject)\n}\n\nfunction isArrayish (subject) {\n  return isArray(subject) || Buffer.isBuffer(subject) ||\n      subject && typeof subject === 'object' &&\n      typeof subject.length === 'number'\n}\n\nfunction toHex (n) {\n  if (n < 16) return '0' + n.toString(16)\n  return n.toString(16)\n}\n\nfunction utf8ToBytes (str) {\n  var byteArray = []\n  for (var i = 0; i < str.length; i++) {\n    var b = str.charCodeAt(i)\n    if (b <= 0x7F)\n      byteArray.push(str.charCodeAt(i))\n    else {\n      var start = i\n      if (b >= 0xD800 && b <= 0xDFFF) i++\n      var h = encodeURIComponent(str.slice(start, i+1)).substr(1).split('%')\n      for (var j = 0; j < h.length; j++)\n        byteArray.push(parseInt(h[j], 16))\n    }\n  }\n  return byteArray\n}\n\nfunction asciiToBytes (str) {\n  var byteArray = []\n  for (var i = 0; i < str.length; i++) {\n    // Node's code seems to be doing this and not & 0x7F..\n    byteArray.push(str.charCodeAt(i) & 0xFF)\n  }\n  return byteArray\n}\n\nfunction utf16leToBytes (str) {\n  var c, hi, lo\n  var byteArray = []\n  for (var i = 0; i < str.length; i++) {\n    c = str.charCodeAt(i)\n    hi = c >> 8\n    lo = c % 256\n    byteArray.push(lo)\n    byteArray.push(hi)\n  }\n\n  return byteArray\n}\n\nfunction base64ToBytes (str) {\n  return base64.toByteArray(str)\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n  var pos\n  for (var i = 0; i < length; i++) {\n    if ((i + offset >= dst.length) || (i >= src.length))\n      break\n    dst[i + offset] = src[i]\n  }\n  return i\n}\n\nfunction decodeUtf8Char (str) {\n  try {\n    return decodeURIComponent(str)\n  } catch (err) {\n    return String.fromCharCode(0xFFFD) // UTF 8 invalid char\n  }\n}\n\n/*\n * We have to make sure that the value is a valid integer. This means that it\n * is non-negative. It has no fractional component and that it does not\n * exceed the maximum allowed value.\n */\nfunction verifuint (value, max) {\n  assert(typeof value === 'number', 'cannot write a non-number as a number')\n  assert(value >= 0, 'specified a negative value for writing an unsigned value')\n  assert(value <= max, 'value is larger than maximum value for type')\n  assert(Math.floor(value) === value, 'value has a fractional component')\n}\n\nfunction verifsint (value, max, min) {\n  assert(typeof value === 'number', 'cannot write a non-number as a number')\n  assert(value <= max, 'value larger than maximum allowed value')\n  assert(value >= min, 'value smaller than minimum allowed value')\n  assert(Math.floor(value) === value, 'value has a fractional component')\n}\n\nfunction verifIEEE754 (value, max, min) {\n  assert(typeof value === 'number', 'cannot write a non-number as a number')\n  assert(value <= max, 'value larger than maximum allowed value')\n  assert(value >= min, 'value smaller than minimum allowed value')\n}\n\nfunction assert (test, message) {\n  if (!test) throw new Error(message || 'Failed assertion')\n}\n","var lookup = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\n\n;(function (exports) {\n\t'use strict';\n\n  var Arr = (typeof Uint8Array !== 'undefined')\n    ? Uint8Array\n    : Array\n\n\tvar PLUS   = '+'.charCodeAt(0)\n\tvar SLASH  = '/'.charCodeAt(0)\n\tvar NUMBER = '0'.charCodeAt(0)\n\tvar LOWER  = 'a'.charCodeAt(0)\n\tvar UPPER  = 'A'.charCodeAt(0)\n\tvar PLUS_URL_SAFE = '-'.charCodeAt(0)\n\tvar SLASH_URL_SAFE = '_'.charCodeAt(0)\n\n\tfunction decode (elt) {\n\t\tvar code = elt.charCodeAt(0)\n\t\tif (code === PLUS ||\n\t\t    code === PLUS_URL_SAFE)\n\t\t\treturn 62 // '+'\n\t\tif (code === SLASH ||\n\t\t    code === SLASH_URL_SAFE)\n\t\t\treturn 63 // '/'\n\t\tif (code < NUMBER)\n\t\t\treturn -1 //no match\n\t\tif (code < NUMBER + 10)\n\t\t\treturn code - NUMBER + 26 + 26\n\t\tif (code < UPPER + 26)\n\t\t\treturn code - UPPER\n\t\tif (code < LOWER + 26)\n\t\t\treturn code - LOWER + 26\n\t}\n\n\tfunction b64ToByteArray (b64) {\n\t\tvar i, j, l, tmp, placeHolders, arr\n\n\t\tif (b64.length % 4 > 0) {\n\t\t\tthrow new Error('Invalid string. Length must be a multiple of 4')\n\t\t}\n\n\t\t// the number of equal signs (place holders)\n\t\t// if there are two placeholders, than the two characters before it\n\t\t// represent one byte\n\t\t// if there is only one, then the three characters before it represent 2 bytes\n\t\t// this is just a cheap hack to not do indexOf twice\n\t\tvar len = b64.length\n\t\tplaceHolders = '=' === b64.charAt(len - 2) ? 2 : '=' === b64.charAt(len - 1) ? 1 : 0\n\n\t\t// base64 is 4/3 + up to two characters of the original data\n\t\tarr = new Arr(b64.length * 3 / 4 - placeHolders)\n\n\t\t// if there are placeholders, only get up to the last complete 4 chars\n\t\tl = placeHolders > 0 ? b64.length - 4 : b64.length\n\n\t\tvar L = 0\n\n\t\tfunction push (v) {\n\t\t\tarr[L++] = v\n\t\t}\n\n\t\tfor (i = 0, j = 0; i < l; i += 4, j += 3) {\n\t\t\ttmp = (decode(b64.charAt(i)) << 18) | (decode(b64.charAt(i + 1)) << 12) | (decode(b64.charAt(i + 2)) << 6) | decode(b64.charAt(i + 3))\n\t\t\tpush((tmp & 0xFF0000) >> 16)\n\t\t\tpush((tmp & 0xFF00) >> 8)\n\t\t\tpush(tmp & 0xFF)\n\t\t}\n\n\t\tif (placeHolders === 2) {\n\t\t\ttmp = (decode(b64.charAt(i)) << 2) | (decode(b64.charAt(i + 1)) >> 4)\n\t\t\tpush(tmp & 0xFF)\n\t\t} else if (placeHolders === 1) {\n\t\t\ttmp = (decode(b64.charAt(i)) << 10) | (decode(b64.charAt(i + 1)) << 4) | (decode(b64.charAt(i + 2)) >> 2)\n\t\t\tpush((tmp >> 8) & 0xFF)\n\t\t\tpush(tmp & 0xFF)\n\t\t}\n\n\t\treturn arr\n\t}\n\n\tfunction uint8ToBase64 (uint8) {\n\t\tvar i,\n\t\t\textraBytes = uint8.length % 3, // if we have 1 byte left, pad 2 bytes\n\t\t\toutput = \"\",\n\t\t\ttemp, length\n\n\t\tfunction encode (num) {\n\t\t\treturn lookup.charAt(num)\n\t\t}\n\n\t\tfunction tripletToBase64 (num) {\n\t\t\treturn encode(num >> 18 & 0x3F) + encode(num >> 12 & 0x3F) + encode(num >> 6 & 0x3F) + encode(num & 0x3F)\n\t\t}\n\n\t\t// go through the array every three bytes, we'll deal with trailing stuff later\n\t\tfor (i = 0, length = uint8.length - extraBytes; i < length; i += 3) {\n\t\t\ttemp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2])\n\t\t\toutput += tripletToBase64(temp)\n\t\t}\n\n\t\t// pad the end with zeros, but make sure to not forget the extra bytes\n\t\tswitch (extraBytes) {\n\t\t\tcase 1:\n\t\t\t\ttemp = uint8[uint8.length - 1]\n\t\t\t\toutput += encode(temp >> 2)\n\t\t\t\toutput += encode((temp << 4) & 0x3F)\n\t\t\t\toutput += '=='\n\t\t\t\tbreak\n\t\t\tcase 2:\n\t\t\t\ttemp = (uint8[uint8.length - 2] << 8) + (uint8[uint8.length - 1])\n\t\t\t\toutput += encode(temp >> 10)\n\t\t\t\toutput += encode((temp >> 4) & 0x3F)\n\t\t\t\toutput += encode((temp << 2) & 0x3F)\n\t\t\t\toutput += '='\n\t\t\t\tbreak\n\t\t}\n\n\t\treturn output\n\t}\n\n\texports.toByteArray = b64ToByteArray\n\texports.fromByteArray = uint8ToBase64\n}(typeof exports === 'undefined' ? (this.base64js = {}) : exports))\n","exports.read = function (buffer, offset, isLE, mLen, nBytes) {\n  var e, m,\n      eLen = nBytes * 8 - mLen - 1,\n      eMax = (1 << eLen) - 1,\n      eBias = eMax >> 1,\n      nBits = -7,\n      i = isLE ? (nBytes - 1) : 0,\n      d = isLE ? -1 : 1,\n      s = buffer[offset + i]\n\n  i += d\n\n  e = s & ((1 << (-nBits)) - 1)\n  s >>= (-nBits)\n  nBits += eLen\n  for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  m = e & ((1 << (-nBits)) - 1)\n  e >>= (-nBits)\n  nBits += mLen\n  for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  if (e === 0) {\n    e = 1 - eBias\n  } else if (e === eMax) {\n    return m ? NaN : ((s ? -1 : 1) * Infinity)\n  } else {\n    m = m + Math.pow(2, mLen)\n    e = e - eBias\n  }\n  return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n  var e, m, c,\n      eLen = nBytes * 8 - mLen - 1,\n      eMax = (1 << eLen) - 1,\n      eBias = eMax >> 1,\n      rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0),\n      i = isLE ? 0 : (nBytes - 1),\n      d = isLE ? 1 : -1,\n      s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n  value = Math.abs(value)\n\n  if (isNaN(value) || value === Infinity) {\n    m = isNaN(value) ? 1 : 0\n    e = eMax\n  } else {\n    e = Math.floor(Math.log(value) / Math.LN2)\n    if (value * (c = Math.pow(2, -e)) < 1) {\n      e--\n      c *= 2\n    }\n    if (e + eBias >= 1) {\n      value += rt / c\n    } else {\n      value += rt * Math.pow(2, 1 - eBias)\n    }\n    if (value * c >= 2) {\n      e++\n      c /= 2\n    }\n\n    if (e + eBias >= eMax) {\n      m = 0\n      e = eMax\n    } else if (e + eBias >= 1) {\n      m = (value * c - 1) * Math.pow(2, mLen)\n      e = e + eBias\n    } else {\n      m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n      e = 0\n    }\n  }\n\n  for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n  e = (e << mLen) | m\n  eLen += mLen\n  for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n  buffer[offset + i - d] |= s * 128\n}\n","var Buffer = require('buffer').Buffer;\nvar intSize = 4;\nvar zeroBuffer = new Buffer(intSize); zeroBuffer.fill(0);\nvar chrsz = 8;\n\nfunction toArray(buf, bigEndian) {\n  if ((buf.length % intSize) !== 0) {\n    var len = buf.length + (intSize - (buf.length % intSize));\n    buf = Buffer.concat([buf, zeroBuffer], len);\n  }\n\n  var arr = [];\n  var fn = bigEndian ? buf.readInt32BE : buf.readInt32LE;\n  for (var i = 0; i < buf.length; i += intSize) {\n    arr.push(fn.call(buf, i));\n  }\n  return arr;\n}\n\nfunction toBuffer(arr, size, bigEndian) {\n  var buf = new Buffer(size);\n  var fn = bigEndian ? buf.writeInt32BE : buf.writeInt32LE;\n  for (var i = 0; i < arr.length; i++) {\n    fn.call(buf, arr[i], i * 4, true);\n  }\n  return buf;\n}\n\nfunction hash(buf, fn, hashSize, bigEndian) {\n  if (!Buffer.isBuffer(buf)) buf = new Buffer(buf);\n  var arr = fn(toArray(buf, bigEndian), buf.length * chrsz);\n  return toBuffer(arr, hashSize, bigEndian);\n}\n\nmodule.exports = { hash: hash };\n","var Buffer = require('buffer').Buffer\nvar sha = require('./sha')\nvar sha256 = require('./sha256')\nvar rng = require('./rng')\nvar md5 = require('./md5')\n\nvar algorithms = {\n  sha1: sha,\n  sha256: sha256,\n  md5: md5\n}\n\nvar blocksize = 64\nvar zeroBuffer = new Buffer(blocksize); zeroBuffer.fill(0)\nfunction hmac(fn, key, data) {\n  if(!Buffer.isBuffer(key)) key = new Buffer(key)\n  if(!Buffer.isBuffer(data)) data = new Buffer(data)\n\n  if(key.length > blocksize) {\n    key = fn(key)\n  } else if(key.length < blocksize) {\n    key = Buffer.concat([key, zeroBuffer], blocksize)\n  }\n\n  var ipad = new Buffer(blocksize), opad = new Buffer(blocksize)\n  for(var i = 0; i < blocksize; i++) {\n    ipad[i] = key[i] ^ 0x36\n    opad[i] = key[i] ^ 0x5C\n  }\n\n  var hash = fn(Buffer.concat([ipad, data]))\n  return fn(Buffer.concat([opad, hash]))\n}\n\nfunction hash(alg, key) {\n  alg = alg || 'sha1'\n  var fn = algorithms[alg]\n  var bufs = []\n  var length = 0\n  if(!fn) error('algorithm:', alg, 'is not yet supported')\n  return {\n    update: function (data) {\n      if(!Buffer.isBuffer(data)) data = new Buffer(data)\n        \n      bufs.push(data)\n      length += data.length\n      return this\n    },\n    digest: function (enc) {\n      var buf = Buffer.concat(bufs)\n      var r = key ? hmac(fn, key, buf) : fn(buf)\n      bufs = null\n      return enc ? r.toString(enc) : r\n    }\n  }\n}\n\nfunction error () {\n  var m = [].slice.call(arguments).join(' ')\n  throw new Error([\n    m,\n    'we accept pull requests',\n    'http://github.com/dominictarr/crypto-browserify'\n    ].join('\\n'))\n}\n\nexports.createHash = function (alg) { return hash(alg) }\nexports.createHmac = function (alg, key) { return hash(alg, key) }\nexports.randomBytes = function(size, callback) {\n  if (callback && callback.call) {\n    try {\n      callback.call(this, undefined, new Buffer(rng(size)))\n    } catch (err) { callback(err) }\n  } else {\n    return new Buffer(rng(size))\n  }\n}\n\nfunction each(a, f) {\n  for(var i in a)\n    f(a[i], i)\n}\n\n// the least I can do is make error messages for the rest of the node.js/crypto api.\neach(['createCredentials'\n, 'createCipher'\n, 'createCipheriv'\n, 'createDecipher'\n, 'createDecipheriv'\n, 'createSign'\n, 'createVerify'\n, 'createDiffieHellman'\n, 'pbkdf2'], function (name) {\n  exports[name] = function () {\n    error('sorry,', name, 'is not implemented yet')\n  }\n})\n","/*\r\n * A JavaScript implementation of the RSA Data Security, Inc. MD5 Message\r\n * Digest Algorithm, as defined in RFC 1321.\r\n * Version 2.1 Copyright (C) Paul Johnston 1999 - 2002.\r\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\r\n * Distributed under the BSD License\r\n * See http://pajhome.org.uk/crypt/md5 for more info.\r\n */\r\n\r\nvar helpers = require('./helpers');\r\n\r\n/*\r\n * Perform a simple self-test to see if the VM is working\r\n */\r\nfunction md5_vm_test()\r\n{\r\n  return hex_md5(\"abc\") == \"900150983cd24fb0d6963f7d28e17f72\";\r\n}\r\n\r\n/*\r\n * Calculate the MD5 of an array of little-endian words, and a bit length\r\n */\r\nfunction core_md5(x, len)\r\n{\r\n  /* append padding */\r\n  x[len >> 5] |= 0x80 << ((len) % 32);\r\n  x[(((len + 64) >>> 9) << 4) + 14] = len;\r\n\r\n  var a =  1732584193;\r\n  var b = -271733879;\r\n  var c = -1732584194;\r\n  var d =  271733878;\r\n\r\n  for(var i = 0; i < x.length; i += 16)\r\n  {\r\n    var olda = a;\r\n    var oldb = b;\r\n    var oldc = c;\r\n    var oldd = d;\r\n\r\n    a = md5_ff(a, b, c, d, x[i+ 0], 7 , -680876936);\r\n    d = md5_ff(d, a, b, c, x[i+ 1], 12, -389564586);\r\n    c = md5_ff(c, d, a, b, x[i+ 2], 17,  606105819);\r\n    b = md5_ff(b, c, d, a, x[i+ 3], 22, -1044525330);\r\n    a = md5_ff(a, b, c, d, x[i+ 4], 7 , -176418897);\r\n    d = md5_ff(d, a, b, c, x[i+ 5], 12,  1200080426);\r\n    c = md5_ff(c, d, a, b, x[i+ 6], 17, -1473231341);\r\n    b = md5_ff(b, c, d, a, x[i+ 7], 22, -45705983);\r\n    a = md5_ff(a, b, c, d, x[i+ 8], 7 ,  1770035416);\r\n    d = md5_ff(d, a, b, c, x[i+ 9], 12, -1958414417);\r\n    c = md5_ff(c, d, a, b, x[i+10], 17, -42063);\r\n    b = md5_ff(b, c, d, a, x[i+11], 22, -1990404162);\r\n    a = md5_ff(a, b, c, d, x[i+12], 7 ,  1804603682);\r\n    d = md5_ff(d, a, b, c, x[i+13], 12, -40341101);\r\n    c = md5_ff(c, d, a, b, x[i+14], 17, -1502002290);\r\n    b = md5_ff(b, c, d, a, x[i+15], 22,  1236535329);\r\n\r\n    a = md5_gg(a, b, c, d, x[i+ 1], 5 , -165796510);\r\n    d = md5_gg(d, a, b, c, x[i+ 6], 9 , -1069501632);\r\n    c = md5_gg(c, d, a, b, x[i+11], 14,  643717713);\r\n    b = md5_gg(b, c, d, a, x[i+ 0], 20, -373897302);\r\n    a = md5_gg(a, b, c, d, x[i+ 5], 5 , -701558691);\r\n    d = md5_gg(d, a, b, c, x[i+10], 9 ,  38016083);\r\n    c = md5_gg(c, d, a, b, x[i+15], 14, -660478335);\r\n    b = md5_gg(b, c, d, a, x[i+ 4], 20, -405537848);\r\n    a = md5_gg(a, b, c, d, x[i+ 9], 5 ,  568446438);\r\n    d = md5_gg(d, a, b, c, x[i+14], 9 , -1019803690);\r\n    c = md5_gg(c, d, a, b, x[i+ 3], 14, -187363961);\r\n    b = md5_gg(b, c, d, a, x[i+ 8], 20,  1163531501);\r\n    a = md5_gg(a, b, c, d, x[i+13], 5 , -1444681467);\r\n    d = md5_gg(d, a, b, c, x[i+ 2], 9 , -51403784);\r\n    c = md5_gg(c, d, a, b, x[i+ 7], 14,  1735328473);\r\n    b = md5_gg(b, c, d, a, x[i+12], 20, -1926607734);\r\n\r\n    a = md5_hh(a, b, c, d, x[i+ 5], 4 , -378558);\r\n    d = md5_hh(d, a, b, c, x[i+ 8], 11, -2022574463);\r\n    c = md5_hh(c, d, a, b, x[i+11], 16,  1839030562);\r\n    b = md5_hh(b, c, d, a, x[i+14], 23, -35309556);\r\n    a = md5_hh(a, b, c, d, x[i+ 1], 4 , -1530992060);\r\n    d = md5_hh(d, a, b, c, x[i+ 4], 11,  1272893353);\r\n    c = md5_hh(c, d, a, b, x[i+ 7], 16, -155497632);\r\n    b = md5_hh(b, c, d, a, x[i+10], 23, -1094730640);\r\n    a = md5_hh(a, b, c, d, x[i+13], 4 ,  681279174);\r\n    d = md5_hh(d, a, b, c, x[i+ 0], 11, -358537222);\r\n    c = md5_hh(c, d, a, b, x[i+ 3], 16, -722521979);\r\n    b = md5_hh(b, c, d, a, x[i+ 6], 23,  76029189);\r\n    a = md5_hh(a, b, c, d, x[i+ 9], 4 , -640364487);\r\n    d = md5_hh(d, a, b, c, x[i+12], 11, -421815835);\r\n    c = md5_hh(c, d, a, b, x[i+15], 16,  530742520);\r\n    b = md5_hh(b, c, d, a, x[i+ 2], 23, -995338651);\r\n\r\n    a = md5_ii(a, b, c, d, x[i+ 0], 6 , -198630844);\r\n    d = md5_ii(d, a, b, c, x[i+ 7], 10,  1126891415);\r\n    c = md5_ii(c, d, a, b, x[i+14], 15, -1416354905);\r\n    b = md5_ii(b, c, d, a, x[i+ 5], 21, -57434055);\r\n    a = md5_ii(a, b, c, d, x[i+12], 6 ,  1700485571);\r\n    d = md5_ii(d, a, b, c, x[i+ 3], 10, -1894986606);\r\n    c = md5_ii(c, d, a, b, x[i+10], 15, -1051523);\r\n    b = md5_ii(b, c, d, a, x[i+ 1], 21, -2054922799);\r\n    a = md5_ii(a, b, c, d, x[i+ 8], 6 ,  1873313359);\r\n    d = md5_ii(d, a, b, c, x[i+15], 10, -30611744);\r\n    c = md5_ii(c, d, a, b, x[i+ 6], 15, -1560198380);\r\n    b = md5_ii(b, c, d, a, x[i+13], 21,  1309151649);\r\n    a = md5_ii(a, b, c, d, x[i+ 4], 6 , -145523070);\r\n    d = md5_ii(d, a, b, c, x[i+11], 10, -1120210379);\r\n    c = md5_ii(c, d, a, b, x[i+ 2], 15,  718787259);\r\n    b = md5_ii(b, c, d, a, x[i+ 9], 21, -343485551);\r\n\r\n    a = safe_add(a, olda);\r\n    b = safe_add(b, oldb);\r\n    c = safe_add(c, oldc);\r\n    d = safe_add(d, oldd);\r\n  }\r\n  return Array(a, b, c, d);\r\n\r\n}\r\n\r\n/*\r\n * These functions implement the four basic operations the algorithm uses.\r\n */\r\nfunction md5_cmn(q, a, b, x, s, t)\r\n{\r\n  return safe_add(bit_rol(safe_add(safe_add(a, q), safe_add(x, t)), s),b);\r\n}\r\nfunction md5_ff(a, b, c, d, x, s, t)\r\n{\r\n  return md5_cmn((b & c) | ((~b) & d), a, b, x, s, t);\r\n}\r\nfunction md5_gg(a, b, c, d, x, s, t)\r\n{\r\n  return md5_cmn((b & d) | (c & (~d)), a, b, x, s, t);\r\n}\r\nfunction md5_hh(a, b, c, d, x, s, t)\r\n{\r\n  return md5_cmn(b ^ c ^ d, a, b, x, s, t);\r\n}\r\nfunction md5_ii(a, b, c, d, x, s, t)\r\n{\r\n  return md5_cmn(c ^ (b | (~d)), a, b, x, s, t);\r\n}\r\n\r\n/*\r\n * Add integers, wrapping at 2^32. This uses 16-bit operations internally\r\n * to work around bugs in some JS interpreters.\r\n */\r\nfunction safe_add(x, y)\r\n{\r\n  var lsw = (x & 0xFFFF) + (y & 0xFFFF);\r\n  var msw = (x >> 16) + (y >> 16) + (lsw >> 16);\r\n  return (msw << 16) | (lsw & 0xFFFF);\r\n}\r\n\r\n/*\r\n * Bitwise rotate a 32-bit number to the left.\r\n */\r\nfunction bit_rol(num, cnt)\r\n{\r\n  return (num << cnt) | (num >>> (32 - cnt));\r\n}\r\n\r\nmodule.exports = function md5(buf) {\r\n  return helpers.hash(buf, core_md5, 16);\r\n};\r\n","// Original code adapted from Robert Kieffer.\n// details at https://github.com/broofa/node-uuid\n(function() {\n  var _global = this;\n\n  var mathRNG, whatwgRNG;\n\n  // NOTE: Math.random() does not guarantee \"cryptographic quality\"\n  mathRNG = function(size) {\n    var bytes = new Array(size);\n    var r;\n\n    for (var i = 0, r; i < size; i++) {\n      if ((i & 0x03) == 0) r = Math.random() * 0x100000000;\n      bytes[i] = r >>> ((i & 0x03) << 3) & 0xff;\n    }\n\n    return bytes;\n  }\n\n  if (_global.crypto && crypto.getRandomValues) {\n    whatwgRNG = function(size) {\n      var bytes = new Uint8Array(size);\n      crypto.getRandomValues(bytes);\n      return bytes;\n    }\n  }\n\n  module.exports = whatwgRNG || mathRNG;\n\n}())\n","/*\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-1, as defined\n * in FIPS PUB 180-1\n * Version 2.1a Copyright Paul Johnston 2000 - 2002.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n * Distributed under the BSD License\n * See http://pajhome.org.uk/crypt/md5 for details.\n */\n\nvar helpers = require('./helpers');\n\n/*\n * Calculate the SHA-1 of an array of big-endian words, and a bit length\n */\nfunction core_sha1(x, len)\n{\n  /* append padding */\n  x[len >> 5] |= 0x80 << (24 - len % 32);\n  x[((len + 64 >> 9) << 4) + 15] = len;\n\n  var w = Array(80);\n  var a =  1732584193;\n  var b = -271733879;\n  var c = -1732584194;\n  var d =  271733878;\n  var e = -1009589776;\n\n  for(var i = 0; i < x.length; i += 16)\n  {\n    var olda = a;\n    var oldb = b;\n    var oldc = c;\n    var oldd = d;\n    var olde = e;\n\n    for(var j = 0; j < 80; j++)\n    {\n      if(j < 16) w[j] = x[i + j];\n      else w[j] = rol(w[j-3] ^ w[j-8] ^ w[j-14] ^ w[j-16], 1);\n      var t = safe_add(safe_add(rol(a, 5), sha1_ft(j, b, c, d)),\n                       safe_add(safe_add(e, w[j]), sha1_kt(j)));\n      e = d;\n      d = c;\n      c = rol(b, 30);\n      b = a;\n      a = t;\n    }\n\n    a = safe_add(a, olda);\n    b = safe_add(b, oldb);\n    c = safe_add(c, oldc);\n    d = safe_add(d, oldd);\n    e = safe_add(e, olde);\n  }\n  return Array(a, b, c, d, e);\n\n}\n\n/*\n * Perform the appropriate triplet combination function for the current\n * iteration\n */\nfunction sha1_ft(t, b, c, d)\n{\n  if(t < 20) return (b & c) | ((~b) & d);\n  if(t < 40) return b ^ c ^ d;\n  if(t < 60) return (b & c) | (b & d) | (c & d);\n  return b ^ c ^ d;\n}\n\n/*\n * Determine the appropriate additive constant for the current iteration\n */\nfunction sha1_kt(t)\n{\n  return (t < 20) ?  1518500249 : (t < 40) ?  1859775393 :\n         (t < 60) ? -1894007588 : -899497514;\n}\n\n/*\n * Add integers, wrapping at 2^32. This uses 16-bit operations internally\n * to work around bugs in some JS interpreters.\n */\nfunction safe_add(x, y)\n{\n  var lsw = (x & 0xFFFF) + (y & 0xFFFF);\n  var msw = (x >> 16) + (y >> 16) + (lsw >> 16);\n  return (msw << 16) | (lsw & 0xFFFF);\n}\n\n/*\n * Bitwise rotate a 32-bit number to the left.\n */\nfunction rol(num, cnt)\n{\n  return (num << cnt) | (num >>> (32 - cnt));\n}\n\nmodule.exports = function sha1(buf) {\n  return helpers.hash(buf, core_sha1, 20, true);\n};\n","\n/**\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-256, as defined\n * in FIPS 180-2\n * Version 2.2-beta Copyright Angel Marin, Paul Johnston 2000 - 2009.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n *\n */\n\nvar helpers = require('./helpers');\n\nvar safe_add = function(x, y) {\n  var lsw = (x & 0xFFFF) + (y & 0xFFFF);\n  var msw = (x >> 16) + (y >> 16) + (lsw >> 16);\n  return (msw << 16) | (lsw & 0xFFFF);\n};\n\nvar S = function(X, n) {\n  return (X >>> n) | (X << (32 - n));\n};\n\nvar R = function(X, n) {\n  return (X >>> n);\n};\n\nvar Ch = function(x, y, z) {\n  return ((x & y) ^ ((~x) & z));\n};\n\nvar Maj = function(x, y, z) {\n  return ((x & y) ^ (x & z) ^ (y & z));\n};\n\nvar Sigma0256 = function(x) {\n  return (S(x, 2) ^ S(x, 13) ^ S(x, 22));\n};\n\nvar Sigma1256 = function(x) {\n  return (S(x, 6) ^ S(x, 11) ^ S(x, 25));\n};\n\nvar Gamma0256 = function(x) {\n  return (S(x, 7) ^ S(x, 18) ^ R(x, 3));\n};\n\nvar Gamma1256 = function(x) {\n  return (S(x, 17) ^ S(x, 19) ^ R(x, 10));\n};\n\nvar core_sha256 = function(m, l) {\n  var K = new Array(0x428A2F98,0x71374491,0xB5C0FBCF,0xE9B5DBA5,0x3956C25B,0x59F111F1,0x923F82A4,0xAB1C5ED5,0xD807AA98,0x12835B01,0x243185BE,0x550C7DC3,0x72BE5D74,0x80DEB1FE,0x9BDC06A7,0xC19BF174,0xE49B69C1,0xEFBE4786,0xFC19DC6,0x240CA1CC,0x2DE92C6F,0x4A7484AA,0x5CB0A9DC,0x76F988DA,0x983E5152,0xA831C66D,0xB00327C8,0xBF597FC7,0xC6E00BF3,0xD5A79147,0x6CA6351,0x14292967,0x27B70A85,0x2E1B2138,0x4D2C6DFC,0x53380D13,0x650A7354,0x766A0ABB,0x81C2C92E,0x92722C85,0xA2BFE8A1,0xA81A664B,0xC24B8B70,0xC76C51A3,0xD192E819,0xD6990624,0xF40E3585,0x106AA070,0x19A4C116,0x1E376C08,0x2748774C,0x34B0BCB5,0x391C0CB3,0x4ED8AA4A,0x5B9CCA4F,0x682E6FF3,0x748F82EE,0x78A5636F,0x84C87814,0x8CC70208,0x90BEFFFA,0xA4506CEB,0xBEF9A3F7,0xC67178F2);\n  var HASH = new Array(0x6A09E667, 0xBB67AE85, 0x3C6EF372, 0xA54FF53A, 0x510E527F, 0x9B05688C, 0x1F83D9AB, 0x5BE0CD19);\n    var W = new Array(64);\n    var a, b, c, d, e, f, g, h, i, j;\n    var T1, T2;\n  /* append padding */\n  m[l >> 5] |= 0x80 << (24 - l % 32);\n  m[((l + 64 >> 9) << 4) + 15] = l;\n  for (var i = 0; i < m.length; i += 16) {\n    a = HASH[0]; b = HASH[1]; c = HASH[2]; d = HASH[3]; e = HASH[4]; f = HASH[5]; g = HASH[6]; h = HASH[7];\n    for (var j = 0; j < 64; j++) {\n      if (j < 16) {\n        W[j] = m[j + i];\n      } else {\n        W[j] = safe_add(safe_add(safe_add(Gamma1256(W[j - 2]), W[j - 7]), Gamma0256(W[j - 15])), W[j - 16]);\n      }\n      T1 = safe_add(safe_add(safe_add(safe_add(h, Sigma1256(e)), Ch(e, f, g)), K[j]), W[j]);\n      T2 = safe_add(Sigma0256(a), Maj(a, b, c));\n      h = g; g = f; f = e; e = safe_add(d, T1); d = c; c = b; b = a; a = safe_add(T1, T2);\n    }\n    HASH[0] = safe_add(a, HASH[0]); HASH[1] = safe_add(b, HASH[1]); HASH[2] = safe_add(c, HASH[2]); HASH[3] = safe_add(d, HASH[3]);\n    HASH[4] = safe_add(e, HASH[4]); HASH[5] = safe_add(f, HASH[5]); HASH[6] = safe_add(g, HASH[6]); HASH[7] = safe_add(h, HASH[7]);\n  }\n  return HASH;\n};\n\nmodule.exports = function sha256(buf) {\n  return helpers.hash(buf, core_sha256, 32, true);\n};\n","if (typeof Object.create === 'function') {\n  // implementation from standard node.js 'util' module\n  module.exports = function inherits(ctor, superCtor) {\n    ctor.super_ = superCtor\n    ctor.prototype = Object.create(superCtor.prototype, {\n      constructor: {\n        value: ctor,\n        enumerable: false,\n        writable: true,\n        configurable: true\n      }\n    });\n  };\n} else {\n  // old school shim for old browsers\n  module.exports = function inherits(ctor, superCtor) {\n    ctor.super_ = superCtor\n    var TempCtor = function () {}\n    TempCtor.prototype = superCtor.prototype\n    ctor.prototype = new TempCtor()\n    ctor.prototype.constructor = ctor\n  }\n}\n","/* This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at http://mozilla.org/MPL/2.0/. */\n\nvar crypto = require('crypto');\n\nvar defineProperty = Object.defineProperty;\nfunction next() {\n  return \"@@symbol:\" + crypto.randomBytes(8).toString('hex');\n}\n\n\nfunction Symbol(desc) {\n  if (!(this instanceof Symbol)) {\n    return new Symbol(desc);\n  }\n  var _symbol = this._symbol = next();\n  defineProperty(this, '_desc', {\n    value: desc,\n    enumerable: false,\n    writable: false,\n    configurable: false\n  });\n  defineProperty(Object.prototype, _symbol, {\n    set: function(value) {\n      defineProperty(this, _symbol, {\n        value: value,\n        enumerable: false,\n        writable: true\n      });\n    }\n  });\n}\n\nSymbol.prototype.toString = function toString() {\n  return this._symbol;\n};\n\nvar globalSymbolRegistry = {};\nSymbol.for = function symbolFor(key) {\n  key = String(key);\n  return globalSymbolRegistry[key] || (globalSymbolRegistry[key] = Symbol(key));\n};\n\nSymbol.keyFor = function keyFor(sym) {\n  if (!(sym instanceof Symbol)) {\n    throw new TypeError(\"Symbol.keyFor requires a Symbol argument\");\n  }\n  for (var key in globalSymbolRegistry) {\n    if (globalSymbolRegistry[key] === sym) {\n      return key;\n    }\n  }\n  return undefined;\n};\n\nmodule.exports = this.Symbol || Symbol;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nmodule.exports = extend;\nfunction extend(origin, add) {\n  // Don't do anything if add isn't an object\n  if (!add || typeof add !== 'object') return origin;\n\n  var keys = Object.keys(add);\n  var i = keys.length;\n  while (i--) {\n    origin[keys[i]] = add[keys[i]];\n  }\n  return origin;\n}\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar GrammarDecl = require('./GrammarDecl');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction Builder() {}\n\nBuilder.prototype = {\n  newGrammar: function(name) {\n    return new GrammarDecl(name);\n  },\n\n  anything: function() {\n    return pexprs.anything;\n  },\n\n  end: function() {\n    return pexprs.end;\n  },\n\n  prim: function(x) {\n    return pexprs.makePrim(x);\n  },\n\n  param: function(index) {\n    return new pexprs.Param(index);\n  },\n\n  alt: function(/* term1, term1, ... */) {\n    var terms = [];\n    for (var idx = 0; idx < arguments.length; idx++) {\n      var arg = arguments[idx];\n      if (arg instanceof pexprs.Alt) {\n        terms = terms.concat(arg.terms);\n      } else {\n        terms.push(arg);\n      }\n    }\n    return terms.length === 1 ? terms[0] : new pexprs.Alt(terms);\n  },\n\n  seq: function(/* factor1, factor2, ... */) {\n    var factors = [];\n    for (var idx = 0; idx < arguments.length; idx++) {\n      var arg = arguments[idx];\n      if (arg instanceof pexprs.Seq) {\n        factors = factors.concat(arg.factors);\n      } else {\n        factors.push(arg);\n      }\n    }\n    return factors.length === 1 ? factors[0] : new pexprs.Seq(factors);\n  },\n\n  star: function(expr) {\n    return new pexprs.Star(expr);\n  },\n\n  plus: function(expr) {\n    return new pexprs.Plus(expr);\n  },\n\n  opt: function(expr) {\n    return new pexprs.Opt(expr);\n  },\n\n  not: function(expr) {\n    return new pexprs.Not(expr);\n  },\n\n  la: function(expr) {\n    return new pexprs.Lookahead(expr);\n  },\n\n  arr: function(expr) {\n    return new pexprs.Arr(expr);\n  },\n\n  str: function(expr) {\n    return new pexprs.Str(expr);\n  },\n\n  obj: function(properties, isLenient) {\n    return new pexprs.Obj(properties, !!isLenient);\n  },\n\n  app: function(ruleName, optParams) {\n    return new pexprs.Apply(ruleName, optParams);\n  }\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Builder;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar InputStream = require('./InputStream');\nvar Interval = require('./Interval');\nvar MatchResult = require('./MatchResult');\nvar Semantics = require('./Semantics');\nvar State = require('./State');\nvar common = require('./common');\nvar errors = require('./errors');\nvar nodes = require('./nodes');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction Grammar(name, superGrammar, ruleDict, optDefaultStartRule) {\n  this.name = name;\n  this.superGrammar = superGrammar;\n  this.ruleDict = ruleDict;\n  if (optDefaultStartRule) {\n    if (!(optDefaultStartRule in ruleDict)) {\n      throw new Error(\"Invalid start rule: '\" + optDefaultStartRule +\n                      \"' is not a rule in grammar '\" + name + \"'\");\n    }\n    this.defaultStartRule = optDefaultStartRule;\n  }\n  this.constructors = this.ctors = this.createConstructors();\n}\n\nGrammar.prototype = {\n  construct: function(ruleName, children) {\n    var body = this.ruleDict[ruleName];\n    if (!body || !body.check(this, children) || children.length !== body.getArity()) {\n      throw new errors.InvalidConstructorCall(this, ruleName, children);\n    }\n    var interval = new Interval(InputStream.newFor(children), 0, children.length);\n    return new nodes.Node(this, ruleName, children, interval);\n  },\n\n  createConstructors: function() {\n    var self = this;\n    var constructors = {};\n\n    function makeConstructor(ruleName) {\n      return function(/* val1, val2, ... */) {\n        return self.construct(ruleName, Array.prototype.slice.call(arguments));\n      };\n    }\n\n    for (var ruleName in this.ruleDict) {\n      // We want *all* properties, not just own properties, because of\n      // supergrammars.\n      constructors[ruleName] = makeConstructor(ruleName);\n    }\n    return constructors;\n  },\n\n  // Return true if the grammar is a built-in grammar, otherwise false.\n  // NOTE: This might give an unexpected result if called before BuiltInRules is defined!\n  isBuiltIn: function() {\n    return this === Grammar.ProtoBuiltInRules || this === Grammar.BuiltInRules;\n  },\n\n  match: function(obj, optStartRule) {\n    var startRule = optStartRule || this.defaultStartRule;\n    if (!startRule) {\n      throw new Error('Missing start rule argument -- the grammar has no default start rule.');\n    }\n    var state = this._match(obj, startRule, false);\n    return MatchResult.newFor(state);\n  },\n\n  _match: function(obj, startRule, tracingEnabled) {\n    var inputStream = InputStream.newFor(typeof obj === 'string' ? obj : [obj]);\n    var state = new State(this, inputStream, startRule, tracingEnabled);\n    var succeeded = new pexprs.Apply(startRule).eval(state);\n    if (succeeded) {\n      // Link every CSTNode to its parent.\n      var stack = [undefined];\n      var helpers = this.semantics().addOperation('setParents', {\n        _terminal: function() {\n          this._node.parent = stack[stack.length - 1];\n        },\n        _iter: function(children) {\n          stack.push(this._node);\n          children.forEach(function(child) { child.setParents(); });\n          stack.pop();\n          this._node.parent = stack[stack.length - 1];\n        },\n        _default: function(children) {\n          stack.push(this._node);\n          children.forEach(function(child) { child.setParents(); });\n          stack.pop();\n          this._node.parent = stack[stack.length - 1];\n        }\n      });\n      helpers(MatchResult.newFor(state)).setParents();\n    }\n    return state;\n  },\n\n  trace: function(obj, optStartRule) {\n    var startRule = optStartRule || this.defaultStartRule;\n    if (!startRule) {\n      throw new Error('Missing start rule argument -- the grammar has no default start rule.');\n    }\n    var state = this._match(obj, startRule, true);\n\n    var rootTrace = state.trace[0];\n    rootTrace.state = state;\n    rootTrace.result = MatchResult.newFor(state);\n    return rootTrace;\n  },\n\n  semantics: function() {\n    return Semantics.createSemantics(this);\n  },\n\n  extendSemantics: function(superSemantics) {\n    return Semantics.createSemantics(this, superSemantics._getSemantics());\n  },\n\n  // Check that every key in `actionDict` corresponds to a semantic action, and that it maps to\n  // a function of the correct arity. If not, throw an exception.\n  _checkTopDownActionDict: function(what, name, actionDict) {\n    function isSpecialAction(name) {\n      return name === '_terminal' || name === '_iter' || name === '_default';\n    }\n\n    var problems = [];\n    for (var k in actionDict) {\n      var v = actionDict[k];\n      if (!isSpecialAction(k) && !(k in this.ruleDict)) {\n        problems.push(\"'\" + k + \"' is not a valid semantic action for '\" + this.name + \"'\");\n      } else if (typeof v !== 'function') {\n        problems.push(\n            \"'\" + k + \"' must be a function in an action dictionary for '\" + this.name + \"'\");\n      } else {\n        var actual = v.length;\n        var expected = this._topDownActionArity(k);\n        if (actual !== expected) {\n          problems.push(\n              \"Semantic action '\" + k + \"' has the wrong arity: \" +\n              'expected ' + expected + ', got ' + actual);\n        }\n      }\n    }\n    if (problems.length > 0) {\n      var prettyProblems = problems.map(function(problem) { return '- ' + problem; });\n      var error = new Error(\n          \"Found errors in the action dictionary of the '\" + name + \"' \" + what + ':\\n' +\n          prettyProblems.join('\\n'));\n      error.problems = problems;\n      throw error;\n    }\n  },\n\n  // Return the expected arity for a semantic action named `actionName`, which\n  // is either a rule name or a special action name like '_default'.\n  _topDownActionArity: function(actionName) {\n    if (actionName === '_default' || actionName === '_iter') {\n      return 1;\n    } else if (actionName === '_terminal') {\n      return 0;\n    }\n    return this.ruleDict[actionName].getArity();\n  },\n\n  _inheritsFrom: function(grammar) {\n    var g = this.superGrammar;\n    while (g) {\n      if (g === grammar) {\n        return true;\n      }\n      g = g.superGrammar;\n    }\n    return false;\n  },\n\n  toRecipe: function(optVarName) {\n    if (this.isBuiltIn()) {\n      throw new Error(\n          'Why would anyone want to generate a recipe for the ' + this.name + ' grammar?!?!');\n    }\n\n    var sb = new common.StringBuffer();\n    if (optVarName) {\n      sb.append('var ' + optVarName + ' = ');\n    }\n    sb.append('(function() {\\n');\n\n    // Include the supergrammar in the recipe if it's not a built-in grammar.\n    var superGrammarDecl = '';\n    if (!this.superGrammar.isBuiltIn()) {\n      sb.append(this.superGrammar.toRecipe('buildSuperGrammar'));\n      superGrammarDecl = '    .withSuperGrammar(buildSuperGrammar.call(this))\\n';\n    }\n    sb.append('  return new this.newGrammar(' + common.toStringLiteral(this.name) + ')\\n');\n    sb.append(superGrammarDecl);\n\n    if (this.defaultStartRule) {\n      sb.append(\"    .withDefaultStartRule('\" + this.defaultStartRule + \"')\\n\");\n    }\n\n    var self = this;\n    Object.keys(this.ruleDict).forEach(function(ruleName) {\n      var body = self.ruleDict[ruleName];\n      sb.append('    .');\n      if (self.superGrammar.ruleDict[ruleName]) {\n        sb.append(body instanceof pexprs.Extend ? 'extend' : 'override');\n      } else {\n        sb.append('define');\n      }\n      var formals = '[' + body.formals.map(common.toStringLiteral).join(', ') + ']';\n      sb.append('(' + common.toStringLiteral(ruleName) + ', ' + formals + ', ');\n      body.outputRecipe(sb, body.formals);\n      if (body.description) {\n        sb.append(', ' + common.toStringLiteral(body.description));\n      }\n      sb.append(')\\n');\n    });\n    sb.append('    .build();\\n});\\n');\n    return sb.contents();\n  },\n\n  // TODO: Come up with better names for these methods.\n  // TODO: Write the analog of these methods for inherited attributes.\n  toOperationActionDictionaryTemplate: function() {\n    return this._toOperationOrAttributeActionDictionaryTemplate();\n  },\n  toAttributeActionDictionaryTemplate: function() {\n    return this._toOperationOrAttributeActionDictionaryTemplate();\n  },\n\n  _toOperationOrAttributeActionDictionaryTemplate: function() {\n    // TODO: add the super-grammar's templates at the right place, e.g., a case for AddExpr_plus\n    // should appear next to other cases of AddExpr.\n\n    var sb = new common.StringBuffer();\n    sb.append('{');\n\n    var first = true;\n    for (var ruleName in this.ruleDict) {\n      if (ruleName === 'spaces_') {\n        // This rule is not for the user, it's more of an implementation detail of syntactic rules.\n        continue;\n      }\n      var body = this.ruleDict[ruleName];\n      if (first) {\n        first = false;\n      } else {\n        sb.append(',');\n      }\n      sb.append('\\n');\n      sb.append('  ');\n      this.addSemanticActionTemplate(ruleName, body, sb);\n    }\n\n    sb.append('\\n}');\n    return sb.contents();\n  },\n\n  addSemanticActionTemplate: function(ruleName, body, sb) {\n    sb.append(ruleName);\n    sb.append(': function(');\n    var arity = this._topDownActionArity(ruleName);\n    sb.append(common.repeat('_', arity).join(', '));\n    sb.append(') {\\n');\n    sb.append('  }');\n  }\n};\n\n// The following grammar contains a few rules that couldn't be written  in \"userland\".\n// At the bottom of src/main.js, we create a sub-grammar of this grammar that's called\n// `BuiltInRules`. That grammar contains several convenience rules, e.g., `letter` and\n// `digit`, and is implicitly the super-grammar of any grammar whose super-grammar\n// isn't specified.\nGrammar.ProtoBuiltInRules = new Grammar('ProtoBuiltInRules', undefined, {\n  // The following rules can't be written in userland because they reference\n  // `anything` and `end` directly.\n  _: pexprs.anything.withFormals([]),\n  end: pexprs.end.withFormals([]),\n\n  // The following rule is part of the Ohm implementation. Its name ends with '_' to\n  // discourage programmers from invoking, extending, and overriding it.\n  spaces_: new pexprs.Star(new pexprs.Apply('space')).withFormals([]),\n\n  // The `space` rule must be defined here because it's referenced by `spaces_`.\n  space: pexprs.makePrim(/[\\s]/).withFormals([]).withDescription('a space')\n});\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Grammar;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Grammar = require('./Grammar');\nvar common = require('./common');\nvar errors = require('./errors');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Private Stuff\n// --------------------------------------------------------------------\n\n// Constructors\n\nfunction GrammarDecl(name) {\n  this.name = name;\n}\n\n// Helpers\n\nfunction onOhmError(doFn, onErrorFn) {\n  try {\n    doFn();\n  } catch (e) {\n    if (e instanceof errors.Error) {\n      onErrorFn(e);\n    } else {\n      throw e;\n    }\n  }\n}\n\nGrammarDecl.prototype.ensureSuperGrammar = function() {\n  if (!this.superGrammar) {\n    this.withSuperGrammar(\n        // TODO: The conditional expression below is an ugly hack. It's kind of ok because\n        // I doubt anyone will ever try to declare a grammar called `BuiltInRules`. Still,\n        // we should try to find a better way to do this.\n        this.name === 'BuiltInRules' ?\n            Grammar.ProtoBuiltInRules :\n            Grammar.BuiltInRules);\n  }\n  return this.superGrammar;\n};\n\nGrammarDecl.prototype.installOverriddenOrExtendedRule = function(name, formals, body) {\n  var duplicateParameterNames = common.getDuplicates(formals);\n  if (duplicateParameterNames.length > 0) {\n    throw new errors.DuplicateParameterNames(name, duplicateParameterNames);\n  }\n  var baseRule = this.ensureSuperGrammar().ruleDict[name];\n  if (formals.length !== baseRule.formals.length) {\n    throw new errors.WrongNumberOfParameters(name, baseRule.formals.length, formals.length);\n  }\n  return this.install(name, formals, baseRule.description, body);\n};\n\nGrammarDecl.prototype.install = function(name, formals, description, body) {\n  body = body.introduceParams(formals);\n  body.formals = formals;\n  body.description = description;\n  this.ruleDict[name] = body;\n  return this;\n};\n\n// Stuff that you should only do once\n\nGrammarDecl.prototype.withSuperGrammar = function(superGrammar) {\n  if (this.superGrammar) {\n    throw new Error('the super grammar of a GrammarDecl cannot be set more than once');\n  }\n  this.superGrammar = superGrammar;\n  this.ruleDict = Object.create(superGrammar.ruleDict);\n\n  // Grammars with an explicit supergrammar inherit a default start rule.\n  if (!superGrammar.isBuiltIn()) {\n    this.defaultStartRule = superGrammar.defaultStartRule;\n  }\n  return this;\n};\n\nGrammarDecl.prototype.withDefaultStartRule = function(ruleName) {\n  this.defaultStartRule = ruleName;\n  return this;\n};\n\n// Creates a Grammar instance, and if it passes the sanity checks, returns it.\nGrammarDecl.prototype.build = function() {\n  var grammar =\n      new Grammar(this.name, this.ensureSuperGrammar(), this.ruleDict, this.defaultStartRule);\n  // TODO: change the pexpr.prototype.assert... methods to make them add\n  // exceptions to an array that's provided as an arg. Then we'll be able to\n  // show more than one error of the same type at a time.\n  // TODO: include the offending pexpr in the errors, that way we can show\n  // the part of the source that caused it.\n  var grammarErrors = [];\n  var grammarHasInvalidApplications = false;\n  Object.keys(grammar.ruleDict).forEach(function(ruleName) {\n    var body = grammar.ruleDict[ruleName];\n    onOhmError(\n        function() { body.assertChoicesHaveUniformArity(ruleName); },\n        function(e) { grammarErrors.push(e); });\n    onOhmError(\n        function() { body.assertAllApplicationsAreValid(grammar); },\n        function(e) {\n          grammarErrors.push(e);\n          grammarHasInvalidApplications = true;\n        });\n  });\n  if (!grammarHasInvalidApplications) {\n    // The following check can only be done if the grammar has no invalid applications.\n    Object.keys(grammar.ruleDict).forEach(function(ruleName) {\n      var body = grammar.ruleDict[ruleName];\n      onOhmError(\n          function() { body.assertIteratedExprsAreNotNullable(grammar, ruleName); },\n          function(e) { grammarErrors.push(e); });\n    });\n  }\n  if (grammarErrors.length > 0) {\n    errors.throwErrors(grammarErrors);\n  }\n  return grammar;\n};\n\n// Rule declarations\n\nGrammarDecl.prototype.define = function(name, formals, body, optDescr) {\n  this.ensureSuperGrammar();\n  if (this.superGrammar.ruleDict[name]) {\n    throw new errors.DuplicateRuleDeclaration(name, this.name, this.superGrammar.name);\n  } else if (this.ruleDict[name]) {\n    throw new errors.DuplicateRuleDeclaration(name, this.name, this.name);\n  }\n  var duplicateParameterNames = common.getDuplicates(formals);\n  if (duplicateParameterNames.length > 0) {\n    throw new errors.DuplicateParameterNames(name, duplicateParameterNames);\n  }\n  return this.install(name, formals, optDescr, body);\n};\n\nGrammarDecl.prototype.override = function(name, formals, body) {\n  var baseRule = this.ensureSuperGrammar().ruleDict[name];\n  if (!baseRule) {\n    throw new errors.CannotOverrideUndeclaredRule(name, this.superGrammar.name);\n  }\n  this.installOverriddenOrExtendedRule(name, formals, body);\n  return this;\n};\n\nGrammarDecl.prototype.extend = function(name, formals, body) {\n  var baseRule = this.ensureSuperGrammar().ruleDict[name];\n  if (!baseRule) {\n    throw new errors.CannotExtendUndeclaredRule(name, this.superGrammar.name);\n  }\n  this.installOverriddenOrExtendedRule(\n      name, formals, new pexprs.Extend(this.superGrammar, name, body));\n  return this;\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = GrammarDecl;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar Interval = require('./Interval');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction InputStream() {\n  throw new Error('InputStream cannot be instantiated -- it\\'s abstract');\n}\n\nInputStream.newFor = function(obj) {\n  if (typeof obj === 'string') {\n    return new StringInputStream(obj);\n  } else if (Array.isArray(obj)) {\n    return new ListInputStream(obj);\n  } else if (obj instanceof InputStream) {\n    return obj;\n  } else {\n    throw new Error('cannot make input stream for ' + obj);\n  }\n};\n\nInputStream.prototype = {\n  init: function(source) {\n    this.source = source;\n    this.pos = 0;\n    this.posInfos = [];\n  },\n\n  atEnd: function() {\n    return this.pos === this.source.length;\n  },\n\n  next: function() {\n    if (this.atEnd()) {\n      return common.fail;\n    } else {\n      return this.source[this.pos++];\n    }\n  },\n\n  matchExactly: function(x) {\n    return this.next() === x ? true : common.fail;\n  },\n\n  sourceSlice: function(startIdx, endIdx) {\n    return this.source.slice(startIdx, endIdx);\n  },\n\n  intervalFrom: function(startIdx) {\n    return new Interval(this, startIdx, this.pos);\n  }\n};\n\nfunction StringInputStream(source) {\n  this.init(source);\n}\n\nStringInputStream.prototype = Object.create(InputStream.prototype, {\n  matchString: {\n    value: function(s) {\n      for (var idx = 0; idx < s.length; idx++) {\n        if (this.matchExactly(s[idx]) === common.fail) {\n          return common.fail;\n        }\n      }\n      return true;\n    }\n  },\n\n  matchRegExp: {\n    value: function(e) {\n      // IMPORTANT: e must be a non-global, one-character expression, e.g., /./ and /[0-9]/\n      var c = this.next();\n      return c !== common.fail && e.test(c) ? true : common.fail;\n    }\n  }\n});\n\nfunction ListInputStream(source) {\n  this.init(source);\n}\n\nListInputStream.prototype = Object.create(InputStream.prototype, {\n  matchString: {\n    value: function(s) {\n      return this.matchExactly(s);\n    }\n  },\n\n  matchRegExp: {\n    value: function(e) {\n      return this.matchExactly(e);\n    }\n  }\n});\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = InputStream;\n\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar errors = require('./errors');\nvar util = require('./util');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction Interval(inputStream, startIdx, endIdx) {\n  this.inputStream = inputStream;\n  this.startIdx = startIdx;\n  this.endIdx = endIdx;\n}\n\nInterval.coverage = function(/* interval1, interval2, ... */) {\n  var inputStream = arguments[0].inputStream;\n  var startIdx = arguments[0].startIdx;\n  var endIdx = arguments[0].endIdx;\n  for (var idx = 1; idx < arguments.length; idx++) {\n    var interval = arguments[idx];\n    if (interval.inputStream !== inputStream) {\n      throw new errors.IntervalSourcesDontMatch();\n    } else {\n      startIdx = Math.min(startIdx, arguments[idx].startIdx);\n      endIdx = Math.max(endIdx, arguments[idx].endIdx);\n    }\n  }\n  return new Interval(inputStream, startIdx, endIdx);\n};\n\nInterval.prototype = {\n  coverageWith: function(/* interval1, interval2, ... */) {\n    var intervals = Array.prototype.slice.call(arguments);\n    intervals.push(this);\n    return Interval.coverage.apply(undefined, intervals);\n  },\n\n  collapsedLeft: function() {\n    return new Interval(this.inputStream, this.startIdx, this.startIdx);\n  },\n\n  collapsedRight: function() {\n    return new Interval(this.inputStream, this.endIdx, this.endIdx);\n  },\n\n  getLineAndColumnMessage: function() {\n    return util.getLineAndColumnMessage(this.inputStream.source, this.startIdx);\n  },\n\n  // Returns a new Interval which contains the same contents as this one,\n  // but with whitespace trimmed from both ends. (This only makes sense when\n  // the input stream is a string.)\n  trimmed: function() {\n    var contents = this.contents;\n    var startIdx = this.startIdx + contents.match(/^\\s*/)[0].length;\n    var endIdx = this.endIdx - contents.match(/\\s*$/)[0].length;\n    return new Interval(this.inputStream, startIdx, endIdx);\n  }\n};\n\nObject.defineProperties(Interval.prototype, {\n  contents: {\n    get: function() {\n      if (this._contents === undefined) {\n        this._contents = this.inputStream.sourceSlice(this.startIdx, this.endIdx);\n      }\n      return this._contents;\n    },\n    enumerable: true\n  }\n});\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Interval;\n\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar inherits = require('inherits');\n\nvar common = require('./common');\nvar util = require('./util');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// Create a short error message for an error that occurred during matching.\nfunction getShortMatchErrorMessage(pos, source, detail) {\n  var errorInfo = util.getLineAndColumn(source, pos);\n  return 'Line ' + errorInfo.lineNum + ', col ' + errorInfo.colNum + ': ' + detail;\n}\n\n// ----------------- MatchFailure -----------------\n\nfunction MatchResult(state) {\n  this.state = state;\n  this._cst = state.bindings[0];\n}\n\nMatchResult.newFor = function(state) {\n  var succeeded = state.bindings.length === 1;\n  return succeeded ? new MatchResult(state) : new MatchFailure(state);\n};\n\nMatchResult.prototype.failed = function() {\n  return false;\n};\n\nMatchResult.prototype.succeeded = function() {\n  return !this.failed();\n};\n\n// ----------------- MatchFailure -----------------\n\nfunction MatchFailure(state) {\n  this.state = state;\n  common.defineLazyProperty(this, '_exprsAndStacks', function() {\n    return this.state.getFailures();\n  });\n  common.defineLazyProperty(this, 'message', function() {\n    var source = this.state.inputStream.source;\n    if (typeof source !== 'string') {\n      return 'match failed at position ' + this.getPos();\n    }\n\n    var detail = 'Expected ' + this.getExpectedText();\n    return util.getLineAndColumnMessage(source, this.getPos()) + detail;\n  });\n  common.defineLazyProperty(this, 'shortMessage', function() {\n    if (typeof this.state.inputStream.source !== 'string') {\n      return 'match failed at position ' + this.getPos();\n    }\n    var detail = 'expected ' + this.getExpectedText();\n    return getShortMatchErrorMessage(this.getPos(), this.state.inputStream.source, detail);\n  });\n}\ninherits(MatchFailure, MatchResult);\n\nMatchFailure.prototype.toString = function() {\n  return '[MatchFailure at position ' + this.getPos() + ']';\n};\n\nMatchFailure.prototype.failed = function() {\n  return true;\n};\n\nMatchFailure.prototype.getPos = function() {\n  return this.state.getFailuresPos();\n};\n\n// Return a string summarizing the expected contents of the input stream when\n// the match failure occurred.\nMatchFailure.prototype.getExpectedText = function() {\n  var sb = new common.StringBuffer();\n  var expected = this.getExpected();\n  for (var idx = 0; idx < expected.length; idx++) {\n    if (idx > 0) {\n      if (idx === expected.length - 1) {\n        sb.append((expected.length > 2 ? ', or ' : ' or '));\n      } else {\n        sb.append(', ');\n      }\n    }\n    sb.append(expected[idx]);\n  }\n  return sb.contents();\n};\n\n// Return an Array of unique strings representing the terminals or rules that\n// were expected to be matched.\nMatchFailure.prototype.getExpected = function() {\n  var expected = {};\n  var ruleDict = this.state.grammar.ruleDict;\n  this._exprsAndStacks.forEach(function(obj) {\n    expected[obj.expr.toExpected(ruleDict)] = true;\n  });\n  return Object.keys(expected);\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = MatchResult;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar extend = require('util-extend');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction Namespace() {\n}\nNamespace.prototype = Object.create(null);\n\nNamespace.asNamespace = function(objOrNamespace) {\n  if (objOrNamespace instanceof Namespace) {\n    return objOrNamespace;\n  }\n  return Namespace.createNamespace(objOrNamespace);\n};\n\n// Create a new namespace. If `optProps` is specified, all of its properties\n// will be copied to the new namespace.\nNamespace.createNamespace = function(optProps) {\n  return Namespace.extend(Namespace.prototype, optProps);\n};\n\n// Create a new namespace which extends another namespace. If `optProps` is\n// specified, all of its properties will be copied to the new namespace.\nNamespace.extend = function(namespace, optProps) {\n  if (namespace !== Namespace.prototype && !(namespace instanceof Namespace)) {\n    throw new TypeError('not a Namespace object: ' + namespace);\n  }\n  var ns = Object.create(namespace, {\n    constructor: {\n      value: Namespace,\n      enumerable: false,\n      writable: true,\n      configurable: true\n    }\n  });\n  return extend(ns, optProps);\n};\n\n// TODO: Should this be a regular method?\nNamespace.toString = function(ns) {\n  return Object.prototype.toString.call(ns);\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Namespace;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction PosInfo(globalApplicationStack) {\n  this.globalApplicationStack = globalApplicationStack;\n  this.applicationStack = [];\n  // Redundant (could be generated from applicationStack) but useful for performance reasons.\n  this.activeApplications = {};\n  this.memo = {};\n}\n\nPosInfo.prototype = {\n  isActive: function(application) {\n    return this.activeApplications[application.toMemoKey()];\n  },\n\n  enter: function(application) {\n    this.globalApplicationStack.push(application);\n    this.applicationStack.push(application);\n    this.activeApplications[application.toMemoKey()] = true;\n  },\n\n  exit: function() {\n    var application = this.globalApplicationStack.pop();\n    this.applicationStack.pop();\n    this.activeApplications[application.toMemoKey()] = false;\n  },\n\n  shouldUseMemoizedResult: function(memoRec) {\n    var involvedApplications = memoRec.involvedApplications;\n    for (var memoKey in involvedApplications) {\n      if (involvedApplications[memoKey] && this.activeApplications[memoKey]) {\n        return false;\n      }\n    }\n    return true;\n  },\n\n  getCurrentLeftRecursion: function() {\n    if (this.leftRecursionStack) {\n      return this.leftRecursionStack[this.leftRecursionStack.length - 1];\n    }\n  },\n\n  startLeftRecursion: function(application) {\n    if (!this.leftRecursionStack) {\n      this.leftRecursionStack = [];\n    }\n    this.leftRecursionStack.push({\n        memoKey: application.toMemoKey(),\n        value: false,\n        pos: -1,\n        involvedApplications: {}});\n    this.updateInvolvedApplications();\n  },\n\n  endLeftRecursion: function(application) {\n    this.leftRecursionStack.pop();\n  },\n\n  updateInvolvedApplications: function() {\n    var currentLeftRecursion = this.getCurrentLeftRecursion();\n    var involvedApplications = currentLeftRecursion.involvedApplications;\n    var lrApplicationMemoKey = currentLeftRecursion.memoKey;\n    var idx = this.applicationStack.length - 1;\n    while (true) {\n      var memoKey = this.applicationStack[idx--].toMemoKey();\n      if (memoKey === lrApplicationMemoKey) {\n        break;\n      }\n      involvedApplications[memoKey] = true;\n    }\n  }\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = PosInfo;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Symbol = require('symbol');  // eslint-disable-line no-undef\nvar inherits = require('inherits');\n\nvar MatchResult = require('./MatchResult');\nvar common = require('./common');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// ----------------- Wrappers -----------------\n\n// Wrappers decorate CST nodes with all of the functionality (i.e., operations and attributes)\n// provided by a Semantics (see below). `Wrapper` is the abstract superclass of all wrappers. A\n// `Wrapper` must have `_node` and `_semantics` instance variables, which refer to the CST node and\n// Semantics (resp.) for which it was created, and a `_childWrappers` instance variable which is\n// used to cache the wrapper instances that are created for its child nodes. Setting these instance\n// variables is the responsibility of the constructor of each Semantics-specific subclass of\n// `Wrapper`.\nfunction Wrapper() {}\n\nWrapper.prototype.toString = function() {\n  return '[semantics wrapper for ' + this._node.grammar.name + ']';\n};\n\n// Returns the wrapper of the specified child node. Child wrappers are created lazily and cached in\n// the parent wrapper's `_childWrappers` instance variable.\nWrapper.prototype.child = function(idx) {\n  if (!(0 <= idx && idx < this._node.numChildren())) {\n    // TODO: Consider throwing an exception here.\n    return undefined;\n  }\n  var childWrapper = this._childWrappers[idx];\n  if (!childWrapper) {\n    childWrapper = this._childWrappers[idx] = this._semantics.wrap(this._node.childAt(idx));\n  }\n  return childWrapper;\n};\n\n// Returns an array containing the wrappers of all of the children of the node associated with this\n// wrapper.\nWrapper.prototype._children = function() {\n  // Force the creation of all child wrappers\n  for (var idx = 0; idx < this._node.numChildren(); idx++) {\n    this.child(idx);\n  }\n  return this._childWrappers;\n};\n\n// Returns the wrapper of the first child node. Throws an exception if the node associated with this\n// wrapper doesn't have exactly one child.\nWrapper.prototype._onlyChild = function() {\n  if (this._node.numChildren() !== 1) {\n    throw new Error(\n        'cannot get only child of a node of type ' + this.ctorName() +\n        ' (it has ' + this._node.numChildren() + ' children)');\n  } else {\n    return this.child(0);\n  }\n};\n\n// Returns `true` if the CST node associated with this wrapper corresponds to an iteration\n// expression, i.e., a Kleene-*, Kleene-+, or an optional. Returns `false` otherwise.\nWrapper.prototype.isIteration = function() {\n  return this._node.ctorName === '_iter';\n};\n\n// Returns `true` if the CST node associated with this wrapper is a terminal node, `false`\n// otherwise.\nWrapper.prototype.isTerminal = function() {\n  return this._node.isTerminal();\n};\n\nObject.defineProperties(Wrapper.prototype, {\n  // Returns an array containing the children of this CST node.\n  children: {get: function() { return this._children(); }},\n\n  // Returns the name of grammar rule that created this CST node.\n  ctorName: {get: function() { return this._node.ctorName; }},\n\n  // Returns the interval consumed by the CST node associated with this wrapper.\n  interval: {get: function() { return this._node.interval; }},\n\n  // Returns the number of children of this CST node.\n  numChildren: {get: function() { return this._node.numChildren(); }},\n\n  // Returns the primitive value of this CST node, if it's a terminal node. Otherwise,\n  // throws an exception.\n  primitiveValue: {\n    get: function() {\n      if (this.isTerminal()) {\n        return this._node.primitiveValue;\n      }\n      throw new TypeError(\n          \"tried to access the 'primitiveValue' attribute of a non-terminal CST node\");\n    }\n  }\n});\n\n// ----------------- Semantics -----------------\n\n// A Semantics is a container for a family of Operations and Attributes for a given grammar.\n// Semantics enable modularity (different clients of a grammar can create their set of operations\n// and attributes in isolation) and extensibility even when operations and attributes are mutually-\n// recursive. This constructor should not be called directly except from\n// `Semantics.createSemantics`. The normal ways to create a Semantics, given a grammar 'g', are\n// `g.semantics()` and `g.extendSemantics(parentSemantics)`.\nfunction Semantics(grammar, optSuperSemantics) {\n  var self = this;\n  this.grammar = grammar;\n  this.checkedActionDicts = false;\n\n  // Constructor for wrapper instances, which are passed as the arguments to the semantic actions\n  // of an operation or attribute. Operations and attributes require double dispatch: the semantic\n  // action is chosen based on both the node's type and the semantics. Wrappers ensure that\n  // the `execute` method is called with the correct (most specific) semantics object as an\n  // argument.\n  this.Wrapper = function(node) {\n    self.checkActionDictsIfHaventAlready();\n    this._semantics = self;\n    this._node = node;\n    this._childWrappers = [];\n  };\n\n  if (optSuperSemantics) {\n    this.super = optSuperSemantics;\n    if (grammar !== this.super.grammar && !grammar._inheritsFrom(this.super.grammar)) {\n      throw new Error(\n          \"Cannot extend a semantics for grammar '\" + this.super.grammar.name +\n          \"' for use with grammar '\" + grammar.name + \"' (not a sub-grammar)\");\n    }\n    inherits(this.Wrapper, this.super.Wrapper);\n    this.operations = Object.create(this.super.operations);\n    this.attributes = Object.create(this.super.attributes);\n    this.attributeKeys = Object.create(null);\n\n    // Assign unique symbols for each of the attributes inherited from the super-semantics so that\n    // they are memoized independently.\n    for (var attributeName in this.attributes) {\n      this.attributeKeys[attributeName] = Symbol();\n    }\n  } else {\n    inherits(this.Wrapper, Wrapper);\n    this.operations = Object.create(null);\n    this.attributes = Object.create(null);\n    this.attributeKeys = Object.create(null);\n  }\n}\n\nSemantics.prototype.toString = function() {\n  return '[semantics for ' + this.grammar.name + ']';\n};\n\nSemantics.prototype.checkActionDictsIfHaventAlready = function() {\n  if (!this.checkedActionDicts) {\n    this.checkActionDicts();\n    this.checkedActionDicts = true;\n  }\n};\n\n// Checks that the action dictionaries for all operations and attributes in this semantics,\n// including the ones that were inherited from the super-semantics, agree with the grammar.\n// Throws an exception if one or more of them doesn't.\nSemantics.prototype.checkActionDicts = function() {\n  for (var name in this.operations) {\n    this.operations[name].checkActionDict(this.grammar);\n  }\n  for (name in this.attributes) {\n    this.attributes[name].checkActionDict(this.grammar);\n  }\n};\n\nSemantics.prototype.addOperationOrAttribute = function(type, name, actionDict) {\n  var typePlural = type + 's';\n  var Ctor = type === 'operation' ? Operation : Attribute;\n\n  this.assertNewName(name, type);\n\n  // Create the action dictionary for this operation / attribute. We begin by defining the default\n  // behavior of terminal and iteration nodes, and add a '_default' action that throws an error if\n  // a rule in the grammar doesn't have a corresponding action in this operation / attribute...\n  var realActionDict = {\n    _terminal: function() {\n      return this.primitiveValue;\n    },\n    _iter: function(children) {\n      // This CST node corresponds to an iteration expression in the grammar (*, +, or ?). The\n      // default behavior is to map this operation or attribute over all of its child nodes.\n      var thisSemantics = this._semantics;\n      var thisThing = thisSemantics[typePlural][name];\n      return children.map(function(child) { return thisThing.execute(thisSemantics, child); });\n    },\n    _default: function(children) {\n      if (children.length === 1) {\n        var thisSemantics = this._semantics;\n        var thisThing = thisSemantics[typePlural][name];\n        return thisThing.execute(thisSemantics, children[0]);\n      }\n      throw new Error('missing semantic action for ' + this.ctorName + ' in ' + name + ' ' + type);\n    }\n  };\n  // ... and add in the actions supplied by the programmer, which may override some or all of the\n  // default ones.\n  Object.keys(actionDict).forEach(function(name) {\n    realActionDict[name] = actionDict[name];\n  });\n\n  this[typePlural][name] = new Ctor(name, realActionDict);\n\n  // The following check is not strictly necessary (it will happen later anyway) but it's better to\n  // catch errors early.\n  this[typePlural][name].checkActionDict(this.grammar);\n\n  function doIt() {\n    // Dispatch to most specific version of this operation / attribute -- it may have been\n    // overridden by a sub-semantics.\n    var thisThing = this._semantics[typePlural][name];\n    return thisThing.execute(this._semantics, this);\n  }\n\n  if (type === 'operation') {\n    this.Wrapper.prototype[name] = doIt;\n    this.Wrapper.prototype[name].toString = function() {\n      return '[' + name + ' operation]';\n    };\n  } else {\n    Object.defineProperty(this.Wrapper.prototype, name, {get: doIt});\n    this.attributeKeys[name] = Symbol();\n  }\n};\n\nSemantics.prototype.extendOperationOrAttribute = function(type, name, actionDict) {\n  var typePlural = type + 's';\n  var Ctor = type === 'operation' ? Operation : Attribute;\n\n  if (!(this.super && name in this.super[typePlural])) {\n    throw new Error('Cannot extend ' + type + \" '\" + name +\n        \"': did not inherit an \" + type + ' with that name');\n  }\n  if (Object.prototype.hasOwnProperty.call(this[typePlural], name)) {\n    throw new Error('Cannot extend ' + type + \" '\" + name + \"' again\");\n  }\n\n  // Create a new operation / attribute whose actionDict delegates to the super operation /\n  // attribute's actionDict, and which has all the keys from `inheritedActionDict`.\n  var inheritedActionDict = this[typePlural][name].actionDict;\n  var newActionDict = Object.create(inheritedActionDict);\n  Object.keys(actionDict).forEach(function(name) {\n    newActionDict[name] = actionDict[name];\n  });\n\n  this[typePlural][name] = new Ctor(name, newActionDict);\n\n  // The following check is not strictly necessary (it will happen later anyway) but it's better to\n  // catch errors early.\n  this[typePlural][name].checkActionDict(this.grammar);\n};\n\nSemantics.prototype.assertNewName = function(name, type) {\n  if (Wrapper.prototype.hasOwnProperty(name)) {\n    throw new Error(\n        'Cannot add ' + type + \" '\" + name + \"': that's a reserved name\");\n  }\n  if (name in this.operations) {\n    throw new Error(\n        'Cannot add ' + type + \" '\" + name + \"': an operation with that name already exists\");\n  }\n  if (name in this.attributes) {\n    throw new Error(\n        'Cannot add ' + type + \" '\" + name + \"': an attribute with that name already exists\");\n  }\n};\n\n// Returns a wrapper for the given CST `node` in this semantics.\nSemantics.prototype.wrap = function(node) {\n  return new this.Wrapper(node);\n};\n\n// Creates a new Semantics instance for `grammar`, inheriting operations and attributes from\n// `optSuperSemantics`, if it is specified. Returns a function that acts as a proxy for the new\n// Semantics instance. When that function is invoked with a CST node as an argument, it returns\n// a wrapper for that node which gives access to the operations and attributes provided by this\n// semantics.\nSemantics.createSemantics = function(grammar, optSuperSemantics) {\n  var s = new Semantics(grammar, optSuperSemantics);\n\n  // To enable clients to invoke a semantics like a function, return a function that acts as a proxy\n  // for `s`, which is the real `Semantics` instance.\n  var proxy = function ASemantics(matchResult) {\n    if (!(matchResult instanceof MatchResult)) {\n      throw new TypeError(\n          'Semantics expected a MatchResult, but got ' + common.unexpectedObjToString(matchResult));\n    }\n    if (!matchResult.succeeded()) {\n      throw new TypeError(\n          'cannot apply Semantics to ' + matchResult.toString());\n    }\n\n    var cst = matchResult._cst;\n    if (cst.grammar !== grammar) {\n      throw new Error(\n          \"Cannot use a CST node created by grammar '\" + cst.grammar.name +\n          \"' with a semantics for '\" + grammar.name + \"'\");\n    }\n    return s.wrap(cst);\n  };\n\n  // Forward public methods from the proxy to the semantics instance.\n  proxy.addOperation = function(name, actionDict) {\n    s.addOperationOrAttribute.call(s, 'operation', name, actionDict);\n    return proxy;\n  };\n  proxy.extendOperation = function(name, actionDict) {\n    s.extendOperationOrAttribute.call(s, 'operation', name, actionDict);\n    return proxy;\n  };\n  proxy.addAttribute = function(name, actionDict) {\n    s.addOperationOrAttribute.call(s, 'attribute', name, actionDict);\n    return proxy;\n  };\n  proxy.extendAttribute = function(name, actionDict) {\n    s.extendOperationOrAttribute.call(s, 'attribute', name, actionDict);\n    return proxy;\n  };\n\n  // Make the proxy's toString() work.\n  proxy.toString = s.toString.bind(s);\n\n  // Returns the semantics for the proxy.\n  proxy._getSemantics = function() {\n    return s;\n  };\n\n  return proxy;\n};\n\n// ----------------- Operation -----------------\n\n// An Operation represents a function to be applied to a concrete syntax tree (CST) -- it's very\n// similar to a Visitor (http://en.wikipedia.org/wiki/Visitor_pattern). An operation is executed by\n// recursively walking the CST, and at each node, invoking the matching semantic action from\n// `actionDict`. See `Operation.prototype.execute` for details of how a CST node's matching semantic\n// action is found.\nfunction Operation(name, actionDict) {\n  this.name = name;\n  this.actionDict = actionDict;\n}\n\nOperation.prototype.typeName = 'operation';\n\nOperation.prototype.checkActionDict = function(grammar) {\n  grammar._checkTopDownActionDict(this.typeName, this.name, this.actionDict);\n};\n\n// Execute this operation on the CST node associated with `nodeWrapper` in the context of the given\n// Semantics instance.\nOperation.prototype.execute = function(semantics, nodeWrapper) {\n  // Look for a semantic action whose name matches the node's constructor name, which is either the\n  // name of a rule in the grammar, or '_terminal' (for a terminal node), or '_iter' (for an\n  // iteration node). In the latter case, the action function receives a single argument, which is\n  // an array containing all of the children of the CST node.\n  var actionFn = this.actionDict[nodeWrapper._node.ctorName];\n  if (actionFn) {\n    return this.doAction(semantics, nodeWrapper, actionFn, nodeWrapper.isIteration());\n  }\n\n  // The action dictionary does not contain a semantic action for this specific type of node, so\n  // invoke the '_default' semantic action. The built-in implementation of the `_default` semantic\n  // action just throws an error, but the programmer may have overridden it.\n  return this.doAction(semantics, nodeWrapper, this.actionDict._default, true);\n};\n\n// Invoke `actionFn` on the CST node that corresponds to `nodeWrapper`, in the context of\n// `semantics`. If `optPassChildrenAsArray` is true, `actionFn` will be called with a single\n// argument, which is an array of wrappers. Otherwise, the number of arguments to `actionFn` will\n// be equal to the number of children in the CST node.\nOperation.prototype.doAction = function(semantics, nodeWrapper, actionFn, optPassChildrenAsArray) {\n  return optPassChildrenAsArray ?\n      actionFn.call(nodeWrapper, nodeWrapper._children()) :\n      actionFn.apply(nodeWrapper, nodeWrapper._children());\n};\n\n// ----------------- Attribute -----------------\n\n// Attributes are Operations whose results are memoized. This means that, for any given semantics,\n// the semantic action for a CST node will be invoked no more than once.\nfunction Attribute(name, actionDict) {\n  this.name = name;\n  this.actionDict = actionDict;\n}\ninherits(Attribute, Operation);\n\nAttribute.prototype.typeName = 'attribute';\n\nAttribute.prototype.execute = function(semantics, nodeWrapper) {\n  var node = nodeWrapper._node;\n  var key = semantics.attributeKeys[this.name];\n  if (!node.hasOwnProperty(key)) {\n    // The following is a super-send -- isn't JS beautiful? :/\n    node[key] = Operation.prototype.execute.call(this, semantics, nodeWrapper);\n  }\n  return node[key];\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Semantics;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar PosInfo = require('./PosInfo');\nvar Trace = require('./Trace');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction State(grammar, inputStream, startRule, tracingEnabled) {\n  this.grammar = grammar;\n  this.origInputStream = inputStream;\n  this.startRule = startRule;\n  this.tracingEnabled = tracingEnabled;\n  this.rightmostFailPos = -1;\n  this.init();\n}\n\nState.prototype = {\n  init: function(optFailuresArray) {\n    this.inputStreamStack = [];\n    this.posInfosStack = [];\n    this.pushInputStream(this.origInputStream);\n    this.applicationStack = [];\n    this.bindings = [];\n    this.failures = optFailuresArray;\n    this.ignoreFailuresCount = 0;\n    if (this.isTracing()) {\n      this.trace = [];\n    }\n  },\n\n  pushInputStream: function(inputStream) {\n    this.inputStreamStack.push(this.inputStream);\n    this.posInfosStack.push(this.posInfos);\n    this.inputStream = inputStream;\n    this.posInfos = [];\n  },\n\n  popInputStream: function() {\n    this.inputStream = this.inputStreamStack.pop();\n    this.posInfos = this.posInfosStack.pop();\n  },\n\n  getCurrentPosInfo: function() {\n    return this.getPosInfo(this.inputStream.pos);\n  },\n\n  getPosInfo: function(pos) {\n    var posInfo = this.posInfos[pos];\n    return posInfo || (this.posInfos[pos] = new PosInfo(this.applicationStack));\n  },\n\n  recordFailure: function(pos, expr) {\n    if (this.ignoreFailuresCount > 0) {\n      return;\n    }\n    if (pos < this.rightmostFailPos) {\n      // it would be useless to record this failure, so don't do it\n      return;\n    } else if (pos > this.rightmostFailPos) {\n      // new rightmost failure!\n      this.rightmostFailPos = pos;\n    }\n    if (!this.failures) {\n      // we're not really recording failures, so we're done\n      return;\n    }\n\n    // TODO: consider making this code more OO, e.g., add an ExprAndStacks class\n    // that supports an addStack(stack) method.\n    function addStack(stack, stacks) {\n      for (var idx = 0; idx < stacks.length; idx++) {\n        var otherStack = stacks[idx];\n        if (stack.length !== otherStack.length) {\n          continue;\n        }\n        for (var idx2 = 0; idx2 < stack.length; idx2++) {\n          if (stack[idx2] !== otherStack[idx2]) {\n            break;\n          }\n        }\n        if (idx2 === stack.length) {\n          // found it, no need to add\n          return;\n        }\n      }\n      stacks.push(stack);\n    }\n\n    // Another failure at right-most position -- record it if it wasn't already.\n    var stack = this.applicationStack.slice();\n    var exprsAndStacks = this.failures;\n    for (var idx = 0; idx < exprsAndStacks.length; idx++) {\n      var exprAndStacks = exprsAndStacks[idx];\n      if (exprAndStacks.expr === expr) {\n        addStack(stack, exprAndStacks.stacks);\n        return;\n      }\n    }\n    exprsAndStacks.push({expr: expr, stacks: [stack]});\n  },\n\n  ignoreFailures: function() {\n    this.ignoreFailuresCount++;\n  },\n\n  recordFailures: function() {\n    this.ignoreFailuresCount--;\n  },\n\n  getFailuresPos: function() {\n    return this.rightmostFailPos;\n  },\n\n  getFailures: function() {\n    if (!this.failures) {\n      // Rewind, then try to match the input again, recording failures.\n      this.init([]);\n      this.tracingEnabled = false;\n      var succeeded = new pexprs.Apply(this.startRule).eval(this);\n      if (succeeded) {\n        this.failures = [];\n      }\n    }\n    return this.failures;\n  },\n\n  // Returns the memoized trace entry for `pos` and `expr`, if one exists.\n  getMemoizedTraceEntry: function(pos, expr) {\n    var posInfo = this.posInfos[pos];\n    if (posInfo && expr.ruleName) {\n      var memoRec = posInfo.memo[expr.ruleName];\n      if (memoRec) {\n        return memoRec.traceEntry;\n      }\n    }\n    return null;\n  },\n\n  // Make a new trace entry, using the currently active trace array as the\n  // new entry's children.\n  getTraceEntry: function(pos, expr, result) {\n    var entry = this.getMemoizedTraceEntry(pos, expr);\n    if (!entry) {\n      entry = new Trace(this.inputStream, pos, expr, result, this.trace);\n    }\n    return entry;\n  },\n\n  isTracing: function() {\n    return this.tracingEnabled;\n  }\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = State;\n\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Interval = require('./Interval');\nvar common = require('./common');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// Unicode characters that are used in the `toString` output.\nvar BALLOT_X = '\\u2717';\nvar CHECK_MARK = '\\u2713';\nvar DOT_OPERATOR = '\\u22C5';\nvar RIGHTWARDS_DOUBLE_ARROW = '\\u21D2';\nvar SYMBOL_FOR_HORIZONTAL_TABULATION = '\\u2409';\nvar SYMBOL_FOR_LINE_FEED = '\\u240A';\nvar SYMBOL_FOR_CARRIAGE_RETURN = '\\u240D';\n\nfunction linkLeftRecursiveChildren(children) {\n  for (var i = 0; i < children.length; ++i) {\n    var child = children[i];\n    var nextChild = children[i + 1];\n\n    if (nextChild && child.expr === nextChild.expr) {\n      child.replacedBy = nextChild;\n    }\n  }\n}\n\nfunction spaces(n) {\n  return common.repeat(' ', n).join('');\n}\n\n// Return a string representation of a portion of `inputStream` at offset `pos`.\n// The result will contain exactly `len` characters.\nfunction getInputExcerpt(inputStream, pos, len) {\n  var excerpt = asEscapedString(inputStream.sourceSlice(pos, pos + len));\n\n  // Pad the output if necessary.\n  if (excerpt.length < len) {\n    return excerpt + common.repeat(' ', len - excerpt.length).join('');\n  }\n  return excerpt;\n}\n\nfunction asEscapedString(obj) {\n  if (typeof obj === 'string') {\n    // Replace non-printable characters with visible symbols.\n    return obj\n        .replace(/ /g, DOT_OPERATOR)\n        .replace(/\\t/g, SYMBOL_FOR_HORIZONTAL_TABULATION)\n        .replace(/\\n/g, SYMBOL_FOR_LINE_FEED)\n        .replace(/\\r/g, SYMBOL_FOR_CARRIAGE_RETURN);\n  }\n  return String(obj);\n}\n\n// ----------------- Trace -----------------\n\nfunction Trace(inputStream, pos, expr, ans, optChildren) {\n  this.children = optChildren || [];\n  this.expr = expr;\n  if (ans) {\n    this.interval = new Interval(inputStream, pos, inputStream.pos);\n  }\n  this.isLeftRecursive = false;\n  this.pos = pos;\n  this.inputStream = inputStream;\n  this.succeeded = !!ans;\n}\n\nObject.defineProperty(Trace.prototype, 'displayString', {\n  get: function() { return this.expr.toDisplayString(); }\n});\n\nTrace.prototype.setLeftRecursive = function(leftRecursive) {\n  this.isLeftRecursive = leftRecursive;\n  if (leftRecursive) {\n    linkLeftRecursiveChildren(this.children);\n  }\n};\n\n// Recursively traverse this trace node and all its descendents, calling a visitor function\n// for each node that is visited. If `vistorObjOrFn` is an object, then its 'enter' property\n// is a function to call before visiting the children of a node, and its 'exit' property is\n// a function to call afterwards. If `visitorObjOrFn` is a function, it represents the 'enter'\n// function.\n//\n// The functions are called with three arguments: the Trace node, its parent Trace, and a number\n// representing the depth of the node in the tree. (The root node has depth 0.) `optThisArg`, if\n// specified, is the value to use for `this` when executing the visitor functions.\nTrace.prototype.walk = function(visitorObjOrFn, optThisArg) {\n  var visitor = visitorObjOrFn;\n  if (typeof visitor === 'function') {\n    visitor = {enter: visitor};\n  }\n  return (function _walk(node, parent, depth) {\n    if (visitor.enter) {\n      visitor.enter.call(optThisArg, node, parent, depth);\n    }\n    node.children.forEach(function(c) {\n      if (c && ('walk' in c)) {\n        _walk(c, node, depth + 1);\n      }\n    });\n    if (visitor.exit) {\n      visitor.exit.call(optThisArg, node, parent, depth);\n    }\n  })(this, null, 0);\n};\n\n// Return a string representation of the trace.\n// Sample:\n//     12⋅+⋅2⋅*⋅3 ✓ exp ⇒  \"12\"\n//     12⋅+⋅2⋅*⋅3   ✓ addExp (LR) ⇒  \"12\"\n//     12⋅+⋅2⋅*⋅3       ✗ addExp_plus\nTrace.prototype.toString = function() {\n  var sb = new common.StringBuffer();\n  this.walk(function(node, parent, depth) {\n    var ctorName = node.expr.constructor.name;\n    if (ctorName === 'Alt') {\n      return;  // Don't print anything for Alt nodes.\n    }\n    sb.append(getInputExcerpt(node.inputStream, node.pos, 10) + spaces(depth * 2 + 1));\n    sb.append((node.succeeded ? CHECK_MARK : BALLOT_X) + ' ' + node.displayString);\n    if (node.isLeftRecursive) {\n      sb.append(' (LR)');\n    }\n    if (node.succeeded) {\n      var contents = asEscapedString(node.interval.contents);\n      sb.append(' ' + RIGHTWARDS_DOUBLE_ARROW + '  ');\n      sb.append(typeof contents === 'string' ? '\"' + contents + '\"' : contents);\n    }\n    sb.append('\\n');\n  });\n  return sb.contents();\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Trace;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar extend = require('util-extend');\n\n// --------------------------------------------------------------------\n// Private Stuff\n// --------------------------------------------------------------------\n\n// Helpers\n\nvar escapeStringFor = {};\nfor (var c = 0; c < 128; c++) {\n  escapeStringFor[c] = String.fromCharCode(c);\n}\nescapeStringFor[\"'\".charCodeAt(0)]  = \"\\\\'\";\nescapeStringFor['\"'.charCodeAt(0)]  = '\\\\\"';\nescapeStringFor['\\\\'.charCodeAt(0)] = '\\\\\\\\';\nescapeStringFor['\\b'.charCodeAt(0)] = '\\\\b';\nescapeStringFor['\\f'.charCodeAt(0)] = '\\\\f';\nescapeStringFor['\\n'.charCodeAt(0)] = '\\\\n';\nescapeStringFor['\\r'.charCodeAt(0)] = '\\\\r';\nescapeStringFor['\\t'.charCodeAt(0)] = '\\\\t';\nescapeStringFor['\\u000b'.charCodeAt(0)] = '\\\\v';\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nexports.abstract = function() {\n  throw new Error('this method is abstract!');\n};\n\nexports.assert = function(cond, message) {\n  if (!cond) {\n    throw new Error(message);\n  }\n};\n\n// Define a lazily-computed, non-enumerable property named `propName`\n// on the object `obj`. `getterFn` will be called to compute the value the\n// first time the property is accessed.\nexports.defineLazyProperty = function(obj, propName, getterFn) {\n  var memo;\n  Object.defineProperty(obj, propName, {\n    get: function() {\n      if (!memo) {\n        memo = getterFn.call(this);\n      }\n      return memo;\n    }\n  });\n};\n\nexports.clone = function(obj) {\n  if (obj) {\n    return extend({}, obj);\n  }\n  return obj;\n};\n\nexports.extend = extend;\n\nexports.repeatFn = function(fn, n) {\n  var arr = [];\n  while (n-- > 0) {\n    arr.push(fn());\n  }\n  return arr;\n};\n\nexports.repeatStr = function(str, n) {\n  return new Array(n + 1).join(str);\n};\n\nexports.repeat = function(x, n) {\n  return exports.repeatFn(function() { return x; }, n);\n};\n\nexports.getDuplicates = function(array) {\n  var duplicates = [];\n  for (var idx = 0; idx < array.length; idx++) {\n    var x = array[idx];\n    if (array.lastIndexOf(x) !== idx && duplicates.indexOf(x) < 0) {\n      duplicates.push(x);\n    }\n  }\n  return duplicates;\n};\n\nexports.fail = {};\n\nexports.isSyntactic = function(ruleName) {\n  var firstChar = ruleName[0];\n  return ('A' <= firstChar && firstChar <= 'Z');\n};\n\nexports.padLeft = function(str, len, optChar) {\n  var ch = optChar || ' ';\n  if (str.length < len) {\n    return exports.repeatStr(ch, len - str.length) + str;\n  }\n  return str;\n};\n\n// StringBuffer\n\nexports.StringBuffer = function() {\n  this.strings = [];\n};\n\nexports.StringBuffer.prototype.append = function(str) {\n  this.strings.push(str);\n};\n\nexports.StringBuffer.prototype.contents = function() {\n  return this.strings.join('');\n};\n\n// Character escaping and unescaping\n\nexports.escapeChar = function(c, optDelim) {\n  var charCode = c.charCodeAt(0);\n  if ((c === '\"' || c === \"'\") && optDelim && c !== optDelim) {\n    return c;\n  } else if (charCode < 128) {\n    return escapeStringFor[charCode];\n  } else if (128 <= charCode && charCode < 256) {\n    return '\\\\x' + exports.padLeft(charCode.toString(16), 2, '0');\n  } else {\n    return '\\\\u' + exports.padLeft(charCode.toString(16), 4, '0');\n  }\n};\n\nexports.unescapeChar = function(s) {\n  if (s.charAt(0) === '\\\\') {\n    switch (s.charAt(1)) {\n      case 'b': return '\\b';\n      case 'f': return '\\f';\n      case 'n': return '\\n';\n      case 'r': return '\\r';\n      case 't': return '\\t';\n      case 'v': return '\\v';\n      case 'x': return String.fromCharCode(parseInt(s.substring(2, 4), 16));\n      case 'u': return String.fromCharCode(parseInt(s.substring(2, 6), 16));\n      default:   return s.charAt(1);\n    }\n  } else {\n    return s;\n  }\n};\n\n// Helper for producing a description of an unknown object in a safe way.\n// Especially useful for error messages where an unexpected type of object was encountered.\nexports.unexpectedObjToString = function(obj) {\n  if (obj == null) {\n    return String(obj);\n  }\n  var baseToString = Object.prototype.toString.call(obj);\n  try {\n    var typeName;\n    if (obj.constructor && obj.constructor.name) {\n      typeName = obj.constructor.name;\n    } else if (baseToString.indexOf('[object ') === 0) {\n      typeName = baseToString.slice(8, -1);  // Extract e.g. \"Array\" from \"[object Array]\".\n    } else {\n      typeName = typeof obj;\n    }\n    return typeName + ': ' + JSON.stringify(String(obj));\n  } catch (e) {\n    return baseToString;\n  }\n};\n\n// Pretty-printing of strings\n\nexports.toStringLiteral = function(str) {\n  if (typeof str !== 'string') {\n    throw new Error('toStringLiteral only works on strings');\n  }\n  var hasSingleQuotes = str.indexOf(\"'\") >= 0;\n  var hasDoubleQuotes = str.indexOf('\"') >= 0;\n  var delim = hasSingleQuotes && !hasDoubleQuotes ? '\"' : \"'\";\n  var sb = new exports.StringBuffer();\n  sb.append(delim);\n  for (var idx = 0; idx < str.length; idx++) {\n    sb.append(exports.escapeChar(str[idx], delim));\n  }\n  sb.append(delim);\n  return sb.contents();\n};\n\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Namespace = require('./Namespace');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction OhmError() {}\nOhmError.prototype = Object.create(Error.prototype);\n\nfunction makeCustomError(name, initFn) {\n  // Make E think it's really called OhmError, so that errors look nicer when they're\n  // console.log'ed in Chrome.\n  var E = function OhmError() {\n    initFn.apply(this, arguments);\n    // `captureStackTrace` is V8-only.\n    if (typeof Error.captureStackTrace === 'function') {\n      Error.captureStackTrace(this, this.constructor);\n    } else {\n      var e = new Error();\n      Object.defineProperty(this, 'stack', {get: function() { return e.stack; }});\n    }\n  };\n  E.prototype = Object.create(OhmError.prototype);\n  E.prototype.constructor = E;\n  E.prototype.name = name;\n  return E;\n}\n\n// ----------------- errors about intervals -----------------\n\nvar IntervalSourcesDontMatch = makeCustomError(\n    'ohm.error.IntervalSourcesDontMatch',\n    function() {\n      this.message = \"Interval sources don't match\";\n    }\n);\n\n// ----------------- errors about grammars -----------------\n\n// Grammar syntax error\n\nvar GrammarSyntaxError = makeCustomError(\n    'ohm.error.GrammarSyntaxError',\n    function(matchFailure) {\n      Object.defineProperty(this, 'message', {\n        get: function() {\n          return 'Failed to parse grammar:\\n' + matchFailure.message;\n        }\n      });\n    }\n);\n\n// Undeclared grammar\n\nvar UndeclaredGrammar = makeCustomError(\n    'ohm.error.UndeclaredGrammar',\n    function(grammarName, namespace) {\n      this.grammarName = grammarName;\n      this.namespace = namespace;\n      if (this.namespace) {\n        this.message = 'Grammar ' + this.grammarName +\n            ' is not declared in namespace ' + Namespace.toString(this.namespace);\n      } else {\n        this.message = 'Undeclared grammar ' + this.grammarName;\n      }\n    }\n);\n\n// Duplicate grammar declaration\n\nvar DuplicateGrammarDeclaration = makeCustomError(\n    'ohm.error.DuplicateGrammarDeclaration',\n    function(grammarName, namespace) {\n      this.grammarName = grammarName;\n      this.namespace = namespace;\n      this.message = 'Grammar ' + this.grammarName +\n          ' is already declared in namespace ' + Namespace.toString(this.namespace);\n    }\n);\n\n// ----------------- rules -----------------\n\n// Undeclared rule\n\nvar UndeclaredRule = makeCustomError(\n    'ohm.error.UndeclaredRule',\n    function(ruleName, grammarName) {\n      this.ruleName = ruleName;\n      this.grammarName = grammarName;\n      this.message = 'Rule ' + this.ruleName + ' is not declared in grammar ' + this.grammarName;\n    }\n);\n\n// Cannot override undeclared rule\n\nvar CannotOverrideUndeclaredRule = makeCustomError(\n    'ohm.error.CannotOverrideUndeclaredRule',\n    function(ruleName, grammarName) {\n      this.ruleName = ruleName;\n      this.grammarName = grammarName;\n      this.message =\n          'Cannot override rule ' + this.ruleName +\n          ' because it is not declared in ' + this.grammarName;\n    }\n);\n\n// Cannot extend undeclared rule\n\nvar CannotExtendUndeclaredRule = makeCustomError(\n    'ohm.error.CannotExtendUndeclaredRule',\n    function(ruleName, grammarName) {\n      this.ruleName = ruleName;\n      this.grammarName = grammarName;\n      this.message =\n          'Cannot extend rule ' + this.ruleName +\n          ' because it is not declared in ' + this.grammarName;\n    }\n);\n\n// Duplicate rule declaration\n\nvar DuplicateRuleDeclaration = makeCustomError(\n    'ohm.error.DuplicateRuleDeclaration',\n    function(ruleName, offendingGrammarName, declGrammarName) {\n      this.ruleName = ruleName;\n      this.offendingGrammarName = offendingGrammarName;\n      this.declGrammarName = declGrammarName;\n      this.message = \"Duplicate declaration for rule '\" + this.ruleName +\n                     \"' in grammar '\" + this.offendingGrammarName + \"'\";\n      if (this.offendingGrammarName !== declGrammarName) {\n        this.message += \" (originally declared in grammar '\" + this.declGrammarName + \"')\";\n      }\n    }\n);\n\n// Wrong number of parameters\n\nvar WrongNumberOfParameters = makeCustomError(\n    'ohm.error.WrongNumberOfParameters',\n    function(ruleName, expected, actual) {\n      this.ruleName = ruleName;\n      this.expected = expected;\n      this.actual = actual;\n      this.message = 'Wrong number of parameters for rule ' + this.ruleName +\n                     ' (expected ' + this.expected + ', got ' + this.actual + ')';\n    }\n);\n\n// Duplicate parameter names\n\nvar DuplicateParameterNames = makeCustomError(\n    'ohm.error.DuplicateParameterNames',\n    function(ruleName, duplicates) {\n      this.ruleName = ruleName;\n      this.duplicates = duplicates;\n      this.message = 'Duplicate parameter names in rule ' + this.ruleName + ': ' +\n                     this.duplicates.join(',');\n    }\n);\n\n// Invalid parameter expression\n\nvar InvalidParameter = makeCustomError(\n    'ohm.error.InvalidParameter',\n    function(ruleName, expr) {\n      this.ruleName = ruleName;\n      this.expr = expr;\n      this.message = 'Invalid parameter to rule ' + this.ruleName + ': ' + this.expr +\n                     ' has arity ' + this.expr.getArity() + ', but parameter expressions ' +\n                     'must have arity 1';\n    }\n);\n\n// ----------------- Kleene operators -----------------\n\nvar KleeneExprHasNullableOperand = makeCustomError(\n    'ohm.error.KleeneExprHasNullableOperand',\n    function(kleeneExpr) {\n      this.expr = kleeneExpr;\n\n      var operator = kleeneExpr.operator;\n      var nullableExpr = kleeneExpr.expr;\n      this.message = nullableExpr.interval.getLineAndColumnMessage() +\n                     'Nullable expression ' + nullableExpr.interval.contents +\n                     \" is not allowed inside '\" + operator + \"' (possible infinite loop)\";\n    }\n);\n\n// ----------------- arity -----------------\n\nvar InconsistentArity = makeCustomError(\n    'ohm.error.InconsistentArity',\n    function(ruleName, expected, actual) {\n      this.ruleName = ruleName;\n      this.expected = expected;\n      this.actual = actual;\n      this.message =\n          'Rule ' + this.ruleName + ' involves an alternation which has inconsistent arity ' +\n          '(expected ' + this.expected + ', got ' + this.actual + ')';\n    }\n);\n\n// ----------------- properties -----------------\n\nvar DuplicatePropertyNames = makeCustomError(\n    'ohm.error.DuplicatePropertyNames',\n    function(duplicates) {\n      this.duplicates = duplicates;\n      this.message = 'Object pattern has duplicate property names: ' + this.duplicates.join(', ');\n    }\n);\n\n// ----------------- constructors -----------------\n\nvar InvalidConstructorCall = makeCustomError(\n    'ohm.error.InvalidConstructorCall',\n    function(grammar, ctorName, children) {\n      this.grammar = grammar;\n      this.ctorName = ctorName;\n      this.children = children;\n      this.message = 'Attempt to invoke constructor ' + this.ctorName +\n                     ' with invalid or unexpected arguments';\n    }\n);\n\n// ----------------- convenience -----------------\n\nvar MultipleErrors = makeCustomError(\n    'ohm.error.MultipleErrors',\n    function(errors) {\n      this.errors = errors;\n      var messages = errors.map(function(e) { return e.message; });\n      this.message = ['Errors:'].concat(messages).join('\\n- ');\n    }\n);\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = {\n  CannotExtendUndeclaredRule: CannotExtendUndeclaredRule,\n  CannotOverrideUndeclaredRule: CannotOverrideUndeclaredRule,\n  DuplicateGrammarDeclaration: DuplicateGrammarDeclaration,\n  DuplicateParameterNames: DuplicateParameterNames,\n  DuplicatePropertyNames: DuplicatePropertyNames,\n  DuplicateRuleDeclaration: DuplicateRuleDeclaration,\n  Error: OhmError,\n  InconsistentArity: InconsistentArity,\n  IntervalSourcesDontMatch: IntervalSourcesDontMatch,\n  InvalidConstructorCall: InvalidConstructorCall,\n  InvalidParameter: InvalidParameter,\n  GrammarSyntaxError: GrammarSyntaxError,\n  KleeneExprHasNullableOperand: KleeneExprHasNullableOperand,\n  MultipleErrors: MultipleErrors,\n  UndeclaredGrammar: UndeclaredGrammar,\n  UndeclaredRule: UndeclaredRule,\n  WrongNumberOfParameters: WrongNumberOfParameters,\n\n  throwErrors: function(errors) {\n    if (errors.length === 1) {\n      throw errors[0];\n    }\n    if (errors.length > 1) {\n      throw new MultipleErrors(errors);\n    }\n  }\n};\n","(function (Buffer){\n/* global document, Buffer, XMLHttpRequest */\n\n'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Builder = require('./Builder');\nvar Grammar = require('./Grammar');\nvar Namespace = require('./Namespace');\nvar UnicodeCategories = require('../third_party/unicode').UnicodeCategories;\nvar common = require('./common');\nvar errors = require('./errors');\nvar util = require('./util');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// The metagrammar, i.e. the grammar for Ohm grammars. Initialized at the\n// bottom of this file because loading the grammar requires Ohm itself.\nvar ohmGrammar;\n\n// An object which makes it possible to stub out the document API for testing.\nvar documentInterface = {\n  querySelector: function(sel) { return document.querySelector(sel); },\n  querySelectorAll: function(sel) { return document.querySelectorAll(sel); }\n};\n\n// Check if `obj` is a DOM element.\nfunction isElement(obj) {\n  return !!(obj && obj.nodeType === 1);\n}\n\nfunction isUndefined(obj) {\n  return obj === void 0;\n}\n\nvar MAX_ARRAY_INDEX = Math.pow(2, 53) - 1;\n\nfunction isArrayLike(obj) {\n  if (obj == null) {\n    return false;\n  }\n  var length = obj.length;\n  return typeof length === 'number' && length >= 0 && length <= MAX_ARRAY_INDEX;\n}\n\n// TODO: just use the jQuery thing\nfunction load(url) {\n  var req = new XMLHttpRequest();\n  req.open('GET', url, false);\n  try {\n    req.send();\n    if (req.status === 0 || req.status === 200) {\n      return req.responseText;\n    }\n  } catch (e) {}\n  throw new Error('unable to load url ' + url);\n}\n\n// Returns a Grammar instance (i.e., an object with a `match` method) for\n// `tree`, which is the concrete syntax tree of a user-written grammar.\n// The grammar will be assigned into `namespace` under the name of the grammar\n// as specified in the source.\nfunction buildGrammar(match, namespace, optOhmGrammarForTesting) {\n  var builder;\n  var decl;\n  var currentRuleName;\n  var currentRuleFormals;\n  var overriding = false;\n  var metaGrammar = optOhmGrammarForTesting || ohmGrammar;\n\n  // A visitor that produces a Grammar instance from the CST.\n  var helpers = metaGrammar.semantics().addOperation('visit', {\n    Grammar: function(n, s, open, rs, close) {\n      builder = new Builder();\n      var grammarName = n.visit();\n      decl = builder.newGrammar(grammarName, namespace);\n      s.visit();\n      rs.visit();\n      var g = decl.build();\n      if (grammarName in namespace) {\n        throw new errors.DuplicateGrammarDeclaration(grammarName, namespace);\n      }\n      g.definitionInterval = this.interval.trimmed();\n      namespace[grammarName] = g;\n      return g;\n    },\n\n    SuperGrammar: function(_, n) {\n      var superGrammarName = n.visit();\n      if (superGrammarName === 'null') {\n        decl.withSuperGrammar(null);\n      } else {\n        if (!namespace || !(superGrammarName in namespace)) {\n          throw new errors.UndeclaredGrammar(superGrammarName, namespace);\n        }\n        decl.withSuperGrammar(namespace[superGrammarName]);\n      }\n    },\n\n    Rule_define: function(n, fs, d, _, b) {\n      currentRuleName = n.visit();\n      currentRuleFormals = fs.visit()[0] || [];\n      // If there is no default start rule yet, set it now. This must be done before visiting\n      // the body, because it might contain an inline rule definition.\n      if (!decl.defaultStartRule && decl.ensureSuperGrammar() !== Grammar.ProtoBuiltInRules) {\n        decl.withDefaultStartRule(currentRuleName);\n      }\n      var body = b.visit();\n      body.definitionInterval = this.interval.trimmed();\n      var description = d.visit()[0];\n      return decl.define(currentRuleName, currentRuleFormals, body, description);\n    },\n    Rule_override: function(n, fs, _, b) {\n      currentRuleName = n.visit();\n      currentRuleFormals = fs.visit()[0] || [];\n      overriding = true;\n      var body = b.visit();\n      body.definitionInterval = this.interval.trimmed();\n      var ans = decl.override(currentRuleName, currentRuleFormals, body);\n      overriding = false;\n      return ans;\n    },\n    Rule_extend: function(n, fs, _, b) {\n      currentRuleName = n.visit();\n      currentRuleFormals = fs.visit()[0] || [];\n      var body = b.visit();\n      var ans = decl.extend(currentRuleName, currentRuleFormals, body);\n      decl.ruleDict[currentRuleName].definitionInterval = this.interval.trimmed();\n      return ans;\n    },\n\n    Formals: function(opointy, fs, cpointy) {\n      return fs.visit();\n    },\n\n    Params: function(opointy, ps, cpointy) {\n      return ps.visit();\n    },\n\n    Alt: function(term, _, terms) {\n      var args = [term.visit()].concat(terms.visit());\n      return builder.alt.apply(builder, args).withInterval(this.interval);\n    },\n\n    Term_inline: function(b, n) {\n      var inlineRuleName = currentRuleName + '_' + n.visit();\n      var body = b.visit();\n      body.definitionInterval = this.interval.trimmed();\n      var isNewRuleDeclaration = !(decl.superGrammar && decl.superGrammar.ruleDict[inlineRuleName]);\n      if (overriding && !isNewRuleDeclaration) {\n        decl.override(inlineRuleName, currentRuleFormals, body);\n      } else {\n        decl.define(inlineRuleName, currentRuleFormals, body);\n      }\n      var params = currentRuleFormals.map(function(formal) { return builder.app(formal); });\n      return builder.app(inlineRuleName, params).withInterval(body.interval);\n    },\n\n    Seq: function(expr) {\n      return builder.seq.apply(builder, expr.visit()).withInterval(this.interval);\n    },\n\n    Iter_star: function(x, _) {\n      return builder.star(x.visit()).withInterval(this.interval);\n    },\n    Iter_plus: function(x, _) {\n      return builder.plus(x.visit()).withInterval(this.interval);\n    },\n    Iter_opt: function(x, _) {\n      return builder.opt(x.visit()).withInterval(this.interval);\n    },\n\n    Pred_not: function(_, x) {\n      return builder.not(x.visit()).withInterval(this.interval);\n    },\n    Pred_lookahead: function(_, x) {\n      return builder.la(x.visit()).withInterval(this.interval);\n    },\n\n    Base_application: function(rule, ps) {\n      return builder.app(rule.visit(), ps.visit()[0] || []).withInterval(this.interval);\n    },\n    Base_prim: function(expr) {\n      return builder.prim(expr.visit()).withInterval(this.interval);\n    },\n    Base_paren: function(open, x, close) {\n      return x.visit();\n    },\n    Base_arr: function(open, x, close) {\n      return builder.arr(x.visit()).withInterval(this.interval);\n    },\n    Base_str: function(open, x, close) {\n      return builder.str(x.visit());\n    },\n    Base_obj: function(open, lenient, close) {\n      return builder.obj([], lenient.visit()[0]);\n    },\n\n    Base_objWithProps: function(open, ps, _, lenient, close) {\n      return builder.obj(ps.visit(), lenient.visit()[0]).withInterval(this.interval);\n    },\n\n    Props: function(p, _, ps) {\n      return [p.visit()].concat(ps.visit());\n    },\n    Prop: function(n, _, p) {\n      return {name: n.visit(), pattern: p.visit()};\n    },\n\n    ruleDescr: function(open, t, close) {\n      return t.visit();\n    },\n    ruleDescrText: function(_) {\n      return this.interval.contents.trim();\n    },\n\n    caseName: function(_, space1, n, space2, end) {\n      return n.visit();\n    },\n\n    name: function(first, rest) {\n      return this.interval.contents;\n    },\n    nameFirst: function(expr) {},\n    nameRest: function(expr) {},\n\n    keyword_null: function(_) {\n      return null;\n    },\n    keyword_true: function(_) {\n      return true;\n    },\n    keyword_false: function(_) {\n      return false;\n    },\n\n    string: function(open, cs, close) {\n      return cs.visit().map(function(c) { return common.unescapeChar(c); }).join('');\n    },\n\n    strChar: function(_) {\n      return this.interval.contents;\n    },\n\n    escapeChar: function(_) {\n      return this.interval.contents;\n    },\n\n    regExp: function(open, e, close) {\n      return e.visit();\n    },\n\n    reCharClass_unicode: function(open, unicodeClass, close) {\n      return UnicodeCategories[unicodeClass.visit().join('')];\n    },\n    reCharClass_ordinary: function(open, _, close) {\n      return new RegExp(this.interval.contents);\n    },\n\n    number: function(_, digits) {\n      return parseInt(this.interval.contents);\n    },\n\n    space: function(expr) {},\n    space_multiLine: function(start, _, end) {},\n    space_singleLine: function(start, _, end) {},\n\n    ListOf_some: function(x, _, xs) {\n      return [x.visit()].concat(xs.visit());\n    },\n    ListOf_none: function() {\n      return [];\n    }\n  });\n  return helpers(match).visit();\n}\n\nfunction compileAndLoad(source, namespace) {\n  var m = ohmGrammar.match(source, 'Grammars');\n  if (m.failed()) {\n    throw new errors.GrammarSyntaxError(m);\n  }\n  return buildGrammar(m, namespace);\n}\n\n// Return the contents of a script element, fetching it via XHR if necessary.\nfunction getScriptElementContents(el) {\n  if (!isElement(el)) {\n    throw new TypeError('Expected a DOM Node, got ' + common.unexpectedObjToString(el));\n  }\n  if (el.type !== 'text/ohm-js') {\n    throw new Error('Expected a script tag with type=\"text/ohm-js\", got ' + el);\n  }\n  return el.getAttribute('src') ? load(el.getAttribute('src')) : el.innerHTML;\n}\n\nfunction grammar(source, optNamespace) {\n  var ns = grammars(source, optNamespace);\n\n  // Ensure that the source contained no more than one grammar definition.\n  var grammarNames = Object.keys(ns);\n  if (grammarNames.length === 0) {\n    throw new Error('Missing grammar definition');\n  } else if (grammarNames.length > 1) {\n    var secondGrammar = ns[grammarNames[1]];\n    var interval = secondGrammar.definitionInterval;\n    throw new Error(\n        util.getLineAndColumnMessage(interval.inputStream.source, interval.startIdx) +\n        'Found more than one grammar definition -- use ohm.grammars() instead.');\n  }\n  return ns[grammarNames[0]];  // Return the one and only grammar.\n}\n\nfunction grammars(source, optNamespace) {\n  var ns = Namespace.extend(Namespace.asNamespace(optNamespace));\n  if (typeof source !== 'string') {\n    // For convenience, detect Node.js Buffer objects and automatically call toString().\n    if (Buffer && Buffer.isBuffer(source)) {\n      source = source.toString();\n    } else {\n      throw new TypeError(\n          'Expected string as first argument, got ' + common.unexpectedObjToString(source));\n    }\n  }\n  compileAndLoad(source, ns);\n  return ns;\n}\n\nfunction grammarFromScriptElement(optNode) {\n  var node = optNode;\n  if (isUndefined(node)) {\n    var nodeList = documentInterface.querySelectorAll('script[type=\"text/ohm-js\"]');\n    if (nodeList.length !== 1) {\n      throw new Error(\n          'Expected exactly one script tag with type=\"text/ohm-js\", found ' + nodeList.length);\n    }\n    node = nodeList[0];\n  }\n  return grammar(getScriptElementContents(node));\n}\n\nfunction grammarsFromScriptElements(optNodeOrNodeList) {\n  // Simple case: the argument is a DOM node.\n  if (isElement(optNodeOrNodeList)) {\n    return grammars(optNodeOrNodeList);\n  }\n  // Otherwise, it must be either undefined or a NodeList.\n  var nodeList = optNodeOrNodeList;\n  if (isUndefined(nodeList)) {\n    // Find all script elements with type=\"text/ohm-js\".\n    nodeList = documentInterface.querySelectorAll('script[type=\"text/ohm-js\"]');\n  } else if (typeof nodeList === 'string' || (!isElement(nodeList) && !isArrayLike(nodeList))) {\n    throw new TypeError('Expected a Node, NodeList, or Array, but got ' + nodeList);\n  }\n  var ns = Namespace.createNamespace();\n  for (var i = 0; i < nodeList.length; ++i) {\n    // Copy the new grammars into `ns` to keep the namespace flat.\n    common.extend(ns, grammars(getScriptElementContents(nodeList[i]), ns));\n  }\n  return ns;\n}\n\nfunction makeRecipe(recipeFn) {\n  return recipeFn.call(new Builder());\n}\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\n// Stuff that users should know about\n\nmodule.exports = {\n  createNamespace: Namespace.createNamespace,\n  error: errors,\n  grammar: grammar,\n  grammars: grammars,\n  grammarFromScriptElement: grammarFromScriptElement,\n  grammarsFromScriptElements: grammarsFromScriptElements,\n  makeRecipe: makeRecipe,\n  util: util\n};\n\n// Stuff that's only here for bootstrapping, testing, etc.\nGrammar.BuiltInRules = require('../dist/built-in-rules');\nohmGrammar = require('../dist/ohm-grammar');\nmodule.exports._buildGrammar = buildGrammar;\nmodule.exports._setDocumentInterfaceForTesting = function(doc) { documentInterface = doc; };\nmodule.exports.ohmGrammar = ohmGrammar;\n\n}).call(this,require(\"buffer\").Buffer)","'use strict';\n\nvar inherits = require('inherits');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction Node(grammar, ctorName, children, interval) {\n  this.grammar = grammar;\n  this.ctorName = ctorName;\n  this.children = children;\n  this.interval = interval;\n}\n\nNode.prototype.numChildren = function() {\n  return this.children.length;\n};\n\nNode.prototype.childAt = function(idx) {\n  return this.children[idx];\n};\n\nNode.prototype.indexOfChild = function(arg) {\n  return this.children.indexOf(arg);\n};\n\nNode.prototype.hasChildren = function() {\n  return this.children.length > 0;\n};\n\nNode.prototype.hasNoChildren = function() {\n  return !this.hasChildren();\n};\n\nNode.prototype.onlyChild = function() {\n  if (this.children.length !== 1) {\n    throw new Error(\n        'cannot get only child of a node of type ' + this.ctorName +\n        ' (it has ' + this.numChildren() + ' children)');\n  } else {\n    return this.firstChild();\n  }\n};\n\nNode.prototype.firstChild = function() {\n  if (this.hasNoChildren()) {\n    throw new Error(\n        'cannot get first child of a ' + this.ctorName + ' node, which has no children');\n  } else {\n    return this.childAt(0);\n  }\n};\n\nNode.prototype.lastChild = function() {\n  if (this.hasNoChildren()) {\n    throw new Error(\n        'cannot get last child of a ' + this.ctorName + ' node, which has no children');\n  } else {\n    return this.childAt(this.numChildren() - 1);\n  }\n};\n\nNode.prototype.childBefore = function(child) {\n  var childIdx = this.indexOfChild(child);\n  if (childIdx < 0) {\n    throw new Error('Node.childBefore() called w/ an argument that is not a child');\n  } else if (childIdx === 0) {\n    throw new Error('cannot get child before first child');\n  } else {\n    return this.childAt(childIdx - 1);\n  }\n};\n\nNode.prototype.childAfter = function(child) {\n  var childIdx = this.indexOfChild(child);\n  if (childIdx < 0) {\n    throw new Error('Node.childAfter() called w/ an argument that is not a child');\n  } else if (childIdx === this.numChildren() - 1) {\n    throw new Error('cannot get child after last child');\n  } else {\n    return this.childAt(childIdx + 1);\n  }\n};\n\nNode.prototype.isTerminal = function() {\n  return false;\n};\n\nNode.prototype.toJSON = function() {\n  var r = {};\n  r[this.ctorName] = this.children;\n  return r;\n};\n\nfunction TerminalNode(grammar, value, interval) {\n  Node.call(this, grammar, '_terminal', [], interval);\n  this.primitiveValue = value;\n}\ninherits(TerminalNode, Node);\n\nTerminalNode.prototype.isTerminal = function() {\n  return true;\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = {Node: Node, TerminalNode: TerminalNode};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\nvar errors = require('./errors');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.assertAllApplicationsAreValid = common.abstract;\n\npexprs.anything.assertAllApplicationsAreValid = function(grammar) {\n  // no-op\n};\n\npexprs.end.assertAllApplicationsAreValid = function(grammar) {\n  // no-op\n};\n\npexprs.Prim.prototype.assertAllApplicationsAreValid = function(grammar) {\n  // no-op\n};\n\npexprs.Param.prototype.assertAllApplicationsAreValid = function(grammar) {\n  // no-op\n};\n\npexprs.Alt.prototype.assertAllApplicationsAreValid = function(grammar) {\n  for (var idx = 0; idx < this.terms.length; idx++) {\n    this.terms[idx].assertAllApplicationsAreValid(grammar);\n  }\n};\n\npexprs.Seq.prototype.assertAllApplicationsAreValid = function(grammar) {\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    this.factors[idx].assertAllApplicationsAreValid(grammar);\n  }\n};\n\npexprs.Iter.prototype.assertAllApplicationsAreValid =\npexprs.Not.prototype.assertAllApplicationsAreValid =\npexprs.Lookahead.prototype.assertAllApplicationsAreValid =\npexprs.Arr.prototype.assertAllApplicationsAreValid =\npexprs.Str.prototype.assertAllApplicationsAreValid = function(grammar) {\n  this.expr.assertAllApplicationsAreValid(grammar);\n};\n\npexprs.Obj.prototype.assertAllApplicationsAreValid = function(grammar) {\n  for (var idx = 0; idx < this.properties.length; idx++) {\n    this.properties[idx].pattern.assertAllApplicationsAreValid(grammar);\n  }\n};\n\npexprs.Apply.prototype.assertAllApplicationsAreValid = function(grammar) {\n  var body = grammar.ruleDict[this.ruleName];\n\n  // Make sure that the rule exists\n  if (!body) {\n    throw new errors.UndeclaredRule(this.ruleName, grammar.name);\n  }\n\n  // ... and that this application has the correct number of parameters\n  var actual = this.params.length;\n  var expected = body.formals.length;\n  if (actual !== expected) {\n    throw new errors.WrongNumberOfParameters(this.ruleName, expected, actual);\n  }\n\n  // ... and that all of the parameter expressions only have valid applications and have arity 1\n  var self = this;\n  this.params.forEach(function(param) {\n    param.assertAllApplicationsAreValid(grammar);\n    if (param.getArity() !== 1) {\n      throw new errors.InvalidParameter(self.ruleName, param);\n    }\n  });\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\nvar errors = require('./errors');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.assertChoicesHaveUniformArity = common.abstract;\n\npexprs.anything.assertChoicesHaveUniformArity =\npexprs.end.assertChoicesHaveUniformArity =\npexprs.Prim.prototype.assertChoicesHaveUniformArity =\npexprs.Param.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  // no-op\n};\n\npexprs.Alt.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  if (this.terms.length === 0) {\n    return;\n  }\n  var arity = this.terms[0].getArity();\n  for (var idx = 0; idx < this.terms.length; idx++) {\n    var term = this.terms[idx];\n    term.assertChoicesHaveUniformArity();\n    var otherArity = term.getArity();\n    if (arity !== otherArity) {\n      throw new errors.InconsistentArity(ruleName, arity, otherArity);\n    }\n  }\n};\n\npexprs.Extend.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  // Extend is a special case of Alt that's guaranteed to have exactly two\n  // cases: [extensions, origBody].\n  var actualArity = this.terms[0].getArity();\n  var expectedArity = this.terms[1].getArity();\n  if (actualArity !== expectedArity) {\n    throw new errors.InconsistentArity(ruleName, expectedArity, actualArity);\n  }\n};\n\npexprs.Seq.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    this.factors[idx].assertChoicesHaveUniformArity(ruleName);\n  }\n};\n\npexprs.Iter.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  this.expr.assertChoicesHaveUniformArity(ruleName);\n};\n\npexprs.Not.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  // no-op (not required b/c the nested expr doesn't show up in the CST)\n};\n\npexprs.Lookahead.prototype.assertChoicesHaveUniformArity =\npexprs.Arr.prototype.assertChoicesHaveUniformArity =\npexprs.Str.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  this.expr.assertChoicesHaveUniformArity(ruleName);\n};\n\npexprs.Obj.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  for (var idx = 0; idx < this.properties.length; idx++) {\n    this.properties[idx].pattern.assertChoicesHaveUniformArity(ruleName);\n  }\n};\n\npexprs.Apply.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  // The arities of the parameter expressions is required to be 1 by\n  // `assertAllApplicationsAreValid()`.\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar pexprs = require('./pexprs');\nvar errors = require('./errors');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.assertIteratedExprsAreNotNullable = function(grammar, ruleName) {\n  // no-op\n};\n\npexprs.Alt.prototype.assertIteratedExprsAreNotNullable = function(grammar, ruleName) {\n  for (var idx = 0; idx < this.terms.length; idx++) {\n    this.terms[idx].assertIteratedExprsAreNotNullable(grammar, ruleName);\n  }\n};\n\npexprs.Seq.prototype.assertIteratedExprsAreNotNullable = function(grammar, ruleName) {\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    this.factors[idx].assertIteratedExprsAreNotNullable(grammar, ruleName);\n  }\n};\n\npexprs.Iter.prototype.assertIteratedExprsAreNotNullable = function(grammar, ruleName) {\n  // Note: this is the implementation of this method for `Star` and `Plus` expressions.\n  // It is overridden for `Opt` below.\n  this.expr.assertIteratedExprsAreNotNullable(grammar, ruleName);\n  if (this.expr.isNullable(grammar)) {\n    throw new errors.KleeneExprHasNullableOperand(this, ruleName);\n  }\n};\n\npexprs.Opt.prototype.assertIteratedExprsAreNotNullable =\npexprs.Not.prototype.assertIteratedExprsAreNotNullable =\npexprs.Lookahead.prototype.assertIteratedExprsAreNotNullable =\npexprs.Arr.prototype.assertIteratedExprsAreNotNullable =\npexprs.Str.prototype.assertIteratedExprsAreNotNullable = function(grammar, ruleName) {\n  this.expr.assertIteratedExprsAreNotNullable(grammar, ruleName);\n};\n\npexprs.Obj.prototype.assertIteratedExprsAreNotNullable = function(grammar, ruleName) {\n  for (var idx = 0; idx < this.properties.length; idx++) {\n    this.properties[idx].pattern.assertIteratedExprsAreNotNullable(grammar, ruleName);\n  }\n};\n\npexprs.Apply.prototype.assertIteratedExprsAreNotNullable = function(grammar, ruleName) {\n  this.params.forEach(function(param) {\n    param.assertIteratedExprsAreNotNullable(grammar, ruleName);\n  });\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar nodes = require('./nodes');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.check = common.abstract;\n\npexprs.anything.check = function(grammar, vals) {\n  return vals.length >= 1;\n};\n\npexprs.end.check = function(grammar, vals) {\n  return vals[0] instanceof nodes.Node &&\n         vals[0].isTerminal() &&\n         vals[0].primitiveValue === undefined;\n};\n\npexprs.Prim.prototype.check = function(grammar, vals) {\n  return vals[0] instanceof nodes.Node &&\n         vals[0].isTerminal() &&\n         vals[0].primitiveValue === this.obj;\n};\n\npexprs.Param.prototype.check = function(grammar, vals) {\n  return vals.length >= 1;\n};\n\npexprs.RegExpPrim.prototype.check = function(grammar, vals) {\n  // TODO: more efficient \"total match checker\" than the use of .replace here\n  return vals[0] instanceof nodes.Node &&\n         vals[0].isTerminal() &&\n         typeof vals[0].primitiveValue === 'string' &&\n         vals[0].primitiveValue.replace(this.obj, '') === '';\n};\n\npexprs.Alt.prototype.check = function(grammar, vals) {\n  for (var i = 0; i < this.terms.length; i++) {\n    var term = this.terms[i];\n    if (term.check(grammar, vals)) {\n      return true;\n    }\n  }\n  return false;\n};\n\npexprs.Seq.prototype.check = function(grammar, vals) {\n  var pos = 0;\n  for (var i = 0; i < this.factors.length; i++) {\n    var factor = this.factors[i];\n    if (factor.check(grammar, vals.slice(pos))) {\n      pos += factor.getArity();\n    } else {\n      return false;\n    }\n  }\n  return true;\n};\n\npexprs.Iter.prototype.check = function(grammar, vals) {\n  var arity = this.getArity();\n  var columns = vals.slice(0, arity);\n  if (columns.length !== arity) {\n    return false;\n  }\n  var rowCount = columns[0].length;\n  var i;\n  for (i = 1; i < arity; i++) {\n    if (columns[i].length !== rowCount) {\n      return false;\n    }\n  }\n\n  for (i = 0; i < rowCount; i++) {\n    var row = [];\n    for (var j = 0; j < arity; j++) {\n      row.push(columns[j][i]);\n    }\n    if (!this.expr.check(grammar, row)) {\n      return false;\n    }\n  }\n\n  return true;\n};\n\npexprs.Not.prototype.check = function(grammar, vals) {\n  return true;\n};\n\npexprs.Lookahead.prototype.check = function(grammar, vals) {\n  return this.expr.check(grammar, vals);\n};\n\npexprs.Arr.prototype.check = function(grammar, vals) {\n  return this.expr.check(grammar, vals);\n};\n\npexprs.Str.prototype.check = function(grammar, vals) {\n  return this.expr.check(grammar, vals);\n};\n\npexprs.Obj.prototype.check = function(grammar, vals) {\n  var fixedArity = this.getArity();\n  if (this.isLenient) {\n    fixedArity--;\n  }\n\n  var pos = 0;\n  for (var i = 0; i < fixedArity; i++) {\n    var pattern = this.properties[i].pattern;\n    if (pattern.check(grammar, vals.slice(pos))) {\n      pos += pattern.getArity();\n    } else {\n      return false;\n    }\n  }\n\n  return this.isLenient ? typeof vals[pos] === 'object' && vals[pos] : true;\n};\n\npexprs.Apply.prototype.check = function(grammar, vals) {\n  if (!(vals[0] instanceof nodes.Node &&\n        vals[0].grammar === grammar &&\n        vals[0].ctorName === this.ruleName)) {\n    return false;\n  }\n\n  // TODO: think about *not* doing the following checks, i.e., trusting that the rule\n  // was correctly constructed.\n  var ruleNode = vals[0];\n  var body = grammar.ruleDict[this.ruleName];\n  return body.check(grammar, ruleNode.children) && ruleNode.numChildren() === body.getArity();\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar InputStream = require('./InputStream');\nvar common = require('./common');\nvar nodes = require('./nodes');\nvar pexprs = require('./pexprs');\n\nvar Node = nodes.Node;\nvar TerminalNode = nodes.TerminalNode;\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\nvar applySpaces_ = new pexprs.Apply('spaces_');\n\nfunction skipSpacesIfAppropriate(state) {\n  var currentApplication = state.applicationStack[state.applicationStack.length - 1];\n  var ruleName = currentApplication.ruleName || '';\n  if (typeof state.inputStream.source === 'string' && common.isSyntactic(ruleName)) {\n    skipSpaces(state);\n  }\n}\n\nfunction skipSpaces(state) {\n  state.ignoreFailures();\n  applySpaces_.eval(state);\n  state.bindings.pop();\n  state.recordFailures();\n}\n\n// Evaluate the expression and return true if it succeeded, otherwise false.\n// On success, the bindings will have `this.arity` more elements than before,\n// and the position could be anywhere. On failure, the bindings and position\n// will be unchanged.\npexprs.PExpr.prototype.eval = function(state) {\n  var origPos = state.inputStream.pos;\n  var origNumBindings = state.bindings.length;\n  var origTrace = state.trace;\n  if (state.isTracing()) {\n    state.trace = [];\n  }\n\n  // Do the actual evaluation.\n  var ans = this._eval(state, state.inputStream, origPos);\n\n  if (state.isTracing()) {\n    var traceEntry = state.getTraceEntry(origPos, this, ans);\n    origTrace.push(traceEntry);\n    state.trace = origTrace;\n  }\n\n  if (!ans) {\n    this.maybeRecordFailure(state, origPos);\n\n    // Reset the position and the bindings.\n    state.inputStream.pos = origPos;\n    state.bindings.length = origNumBindings;\n  }\n  return ans;\n};\n\n// Evaluate the expression and return true if it succeeded, otherwise false.\n// This should not be called directly except by `eval`.\n//\n// The contract of this method is as follows:\n// * When the return value is true:\n//   -- bindings will have expr.arity more elements than before\n// * When the return value is false:\n//   -- bindings will have exactly the same number of elements as before\n//   -- position could be anywhere\n\npexprs.PExpr.prototype._eval = common.abstract;\n\npexprs.anything._eval = function(state, inputStream, origPos) {\n  var value = inputStream.next();\n  if (value === common.fail) {\n    return false;\n  } else {\n    var interval = inputStream.intervalFrom(origPos);\n    state.bindings.push(new TerminalNode(state.grammar, value, interval));\n    return true;\n  }\n};\n\npexprs.end._eval = function(state, inputStream, origPos) {\n  if (state.inputStream.atEnd()) {\n    var interval = inputStream.intervalFrom(inputStream.pos);\n    state.bindings.push(new TerminalNode(state.grammar, undefined, interval));\n    return true;\n  } else {\n    return false;\n  }\n};\n\npexprs.Prim.prototype._eval = function(state, inputStream, origPos) {\n  if (this.match(inputStream) === common.fail) {\n    return false;\n  } else {\n    var interval = inputStream.intervalFrom(origPos);\n    state.bindings.push(new TerminalNode(state.grammar, this.obj, interval));\n    return true;\n  }\n};\n\npexprs.Prim.prototype.match = function(inputStream) {\n  return inputStream.matchExactly(this.obj);\n};\n\npexprs.StringPrim.prototype.match = function(inputStream) {\n  return inputStream.matchString(this.obj);\n};\n\npexprs.RegExpPrim.prototype._eval = function(state, inputStream, origPos) {\n  if (inputStream.matchRegExp(this.obj) === common.fail) {\n    return false;\n  } else {\n    var interval = inputStream.intervalFrom(origPos);\n    state.bindings.push(\n        new TerminalNode(state.grammar, inputStream.source[origPos], interval));\n    return true;\n  }\n};\n\npexprs.Param.prototype._eval = function(state, inputStream, origPos) {\n  var currentApplication = state.applicationStack[state.applicationStack.length - 1];\n  return currentApplication.params[this.index].eval(state);\n};\n\npexprs.Alt.prototype._eval = function(state, inputStream, origPos) {\n  var bindings = state.bindings;\n  var origNumBindings = bindings.length;\n  for (var idx = 0; idx < this.terms.length; idx++) {\n    if (this.terms[idx].eval(state)) {\n      return true;\n    } else {\n      inputStream.pos = origPos;\n      bindings.length = origNumBindings;\n    }\n  }\n  return false;\n};\n\npexprs.Seq.prototype._eval = function(state, inputStream, origPos) {\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    skipSpacesIfAppropriate(state);\n    var factor = this.factors[idx];\n    if (!factor.eval(state)) {\n      return false;\n    }\n  }\n  return true;\n};\n\npexprs.Iter.prototype._eval = function(state, inputStream, origPos) {\n  var arity = this.getArity();\n  var columns = common.repeatFn(function() { return []; }, arity);\n  var numMatches = 0;\n  var idx;\n  while (numMatches < this.maxNumMatches) {\n    var backtrackPos = inputStream.pos;\n    skipSpacesIfAppropriate(state);\n    if (this.expr.eval(state)) {\n      numMatches++;\n      var row = state.bindings.splice(state.bindings.length - arity, arity);\n      for (idx = 0; idx < row.length; idx++) {\n        columns[idx].push(row[idx]);\n      }\n    } else {\n      inputStream.pos = backtrackPos;\n      break;\n    }\n  }\n  if (numMatches < this.minNumMatches) {\n    return false;\n  }\n  for (idx = 0; idx < columns.length; idx++) {\n    var interval = inputStream.intervalFrom(origPos);\n    state.bindings.push(new Node(state.grammar, '_iter', columns[idx], interval));\n  }\n  return true;\n};\n\npexprs.Not.prototype._eval = function(state, inputStream, origPos) {\n  // TODO:\n  // * Right now we're just throwing away all of the failures that happen inside a `not`,\n  //   and recording `this` as a failed expression.\n  // * Double negation should be equivalent to lookahead, but that's not the case right now wrt\n  //   failures. E.g., ~~'foo' produces a failure for ~~'foo', but maybe it should produce\n  //   a failure for 'foo' instead.\n\n  state.ignoreFailures();\n  var ans = this.expr.eval(state);\n  state.recordFailures();\n  if (ans) {\n    state.bindings.length -= this.getArity();\n    return false;\n  } else {\n    inputStream.pos = origPos;\n    return true;\n  }\n};\n\npexprs.Lookahead.prototype._eval = function(state, inputStream, origPos) {\n  if (this.expr.eval(state)) {\n    inputStream.pos = origPos;\n    return true;\n  } else {\n    return false;\n  }\n};\n\npexprs.Arr.prototype._eval = function(state, inputStream, origPos) {\n  var obj = inputStream.next();\n  if (Array.isArray(obj)) {\n    var objInputStream = InputStream.newFor(obj);\n    state.pushInputStream(objInputStream);\n    var ans = this.expr.eval(state) && state.inputStream.atEnd();\n    state.popInputStream();\n    return ans;\n  } else {\n    return false;\n  }\n};\n\npexprs.Str.prototype._eval = function(state, inputStream, origPos) {\n  var obj = inputStream.next();\n  if (typeof obj === 'string') {\n    var strInputStream = InputStream.newFor(obj);\n    state.pushInputStream(strInputStream);\n    var ans = this.expr.eval(state) && (skipSpacesIfAppropriate(state), state.inputStream.atEnd());\n    state.popInputStream();\n    return ans;\n  } else {\n    return false;\n  }\n};\n\npexprs.Obj.prototype._eval = function(state, inputStream, origPos) {\n  var obj = inputStream.next();\n  if (obj !== common.fail && obj && (typeof obj === 'object' || typeof obj === 'function')) {\n    var numOwnPropertiesMatched = 0;\n    for (var idx = 0; idx < this.properties.length; idx++) {\n      var property = this.properties[idx];\n      if (!obj.hasOwnProperty(property.name)) {\n        return false;\n      }\n      var value = obj[property.name];\n      var valueInputStream = InputStream.newFor([value]);\n      state.pushInputStream(valueInputStream);\n      var matched = property.pattern.eval(state) && state.inputStream.atEnd();\n      state.popInputStream();\n      if (!matched) {\n        return false;\n      }\n      numOwnPropertiesMatched++;\n    }\n    if (this.isLenient) {\n      var remainder = {};\n      for (var p in obj) {\n        if (obj.hasOwnProperty(p) && this.properties.indexOf(p) < 0) {\n          remainder[p] = obj[p];\n        }\n      }\n      var interval = inputStream.intervalFrom(origPos);\n      state.bindings.push(new TerminalNode(state.grammar, remainder, interval));\n      return true;\n    } else {\n      return numOwnPropertiesMatched === Object.keys(obj).length;\n    }\n  } else {\n    return false;\n  }\n};\n\npexprs.Apply.prototype._eval = function(state, inputStream) {\n  var self = this;\n  var grammar = state.grammar;\n  var bindings = state.bindings;\n\n  function useMemoizedResult(memoRecOrLR) {\n    inputStream.pos = memoRecOrLR.pos;\n    if (memoRecOrLR.failureDescriptor) {\n      state.recordFailures(memoRecOrLR.failureDescriptor, self);\n    }\n    if (state.isTracing()) {\n      state.trace.push(memoRecOrLR.traceEntry);\n    }\n    if (memoRecOrLR.value) {\n      bindings.push(memoRecOrLR.value);\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n  var actuals = state.applicationStack.length > 1 ?\n      state.applicationStack[state.applicationStack.length - 1].params :\n      [];\n  var app = this.substituteParams(actuals);\n  var ruleName = app.ruleName;\n  var memoKey = app.toMemoKey();\n\n  if (common.isSyntactic(ruleName)) {\n    skipSpaces(state);\n  }\n\n  var origPosInfo = state.getCurrentPosInfo();\n\n  var memoRec = origPosInfo.memo[memoKey];\n  var currentLR;\n  if (memoRec && origPosInfo.shouldUseMemoizedResult(memoRec)) {\n    return useMemoizedResult(memoRec);\n  } else if (origPosInfo.isActive(app)) {\n    currentLR = origPosInfo.getCurrentLeftRecursion();\n    if (currentLR && currentLR.memoKey === memoKey) {\n      origPosInfo.updateInvolvedApplications();\n      return useMemoizedResult(currentLR);\n    } else {\n      origPosInfo.startLeftRecursion(app);\n      return false;\n    }\n  } else {\n    var body = grammar.ruleDict[ruleName];\n    var origPos = inputStream.pos;\n    origPosInfo.enter(app);\n    if (body.description) {\n      state.ignoreFailures();\n    }\n    var value = app.evalOnce(body, state, inputStream, origPos);\n    currentLR = origPosInfo.getCurrentLeftRecursion();\n    if (currentLR) {\n      if (currentLR.memoKey === memoKey) {\n        value = app.handleLeftRecursion(body, state, origPos, currentLR, value);\n        origPosInfo.memo[memoKey] = {\n          pos: inputStream.pos,\n          value: value,\n          involvedApplications: currentLR.involvedApplications\n        };\n        origPosInfo.endLeftRecursion(app);\n      } else if (!currentLR.involvedApplications[memoKey]) {\n        // Only memoize if this application is not involved in the current left recursion\n        origPosInfo.memo[memoKey] = {pos: inputStream.pos, value: value};\n      }\n    } else {\n      origPosInfo.memo[memoKey] = {pos: inputStream.pos, value: value};\n    }\n    if (body.description) {\n      state.recordFailures();\n      if (!value) {\n        state.recordFailure(origPos, app);\n      }\n    }\n    // Record trace information in the memo table, so that it is\n    // available if the memoized result is used later.\n    if (state.isTracing() && origPosInfo.memo[memoKey]) {\n      var entry = state.getTraceEntry(origPos, app, value);\n      entry.setLeftRecursive(currentLR && (currentLR.memoKey === memoKey));\n      origPosInfo.memo[memoKey].traceEntry = entry;\n    }\n    var ans;\n    if (value) {\n      bindings.push(value);\n      if (state.applicationStack.length === 1) {\n        if (common.isSyntactic(ruleName)) {\n          skipSpaces(state);\n        }\n        ans = pexprs.end.eval(state);\n        bindings.pop();\n      } else {\n        ans = true;\n      }\n    } else {\n      ans = false;\n    }\n\n    origPosInfo.exit();\n    return ans;\n  }\n};\n\npexprs.Apply.prototype.evalOnce = function(expr, state, inputStream, origPos) {\n  if (expr.eval(state)) {\n    var arity = expr.getArity();\n    var bindings = state.bindings.splice(state.bindings.length - arity, arity);\n    var ans = new Node(state.grammar, this.ruleName, bindings, inputStream.intervalFrom(origPos));\n    return ans;\n  } else {\n    return false;\n  }\n};\n\npexprs.Apply.prototype.handleLeftRecursion = function(body, state, origPos, currentLR, seedValue) {\n  if (!seedValue) {\n    return seedValue;\n  }\n\n  var inputStream = state.inputStream;\n  var value = seedValue;\n  currentLR.value = seedValue;\n  currentLR.pos = inputStream.pos;\n\n  while (true) {\n    if (state.isTracing()) {\n      currentLR.traceEntry = common.clone(state.trace[state.trace.length - 1]);\n    }\n\n    inputStream.pos = origPos;\n    value = this.evalOnce(body, state, inputStream, origPos);\n    if (value && inputStream.pos > currentLR.pos) {\n      // The left-recursive result was expanded -- keep looping.\n      currentLR.value = value;\n      currentLR.pos = inputStream.pos;\n    } else {\n      // Failed to expand the result.\n      inputStream.pos = currentLR.pos;\n      if (state.isTracing()) {\n        state.trace.pop();  // Drop last trace entry since `value` was unused.\n      }\n      break;\n    }\n  }\n  return currentLR.value;\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.getArity = function() {\n  return 1;\n};\n\npexprs.Alt.prototype.getArity = function() {\n  // This is ok b/c all terms must have the same arity -- this property is\n  // checked by the Grammar constructor.\n  return this.terms.length === 0 ? 0 : this.terms[0].getArity();\n};\n\npexprs.Seq.prototype.getArity = function() {\n  var arity = 0;\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    arity += this.factors[idx].getArity();\n  }\n  return arity;\n};\n\npexprs.Iter.prototype.getArity = function() {\n  return this.expr.getArity();\n};\n\npexprs.Not.prototype.getArity = function() {\n  return 0;\n};\n\npexprs.Lookahead.prototype.getArity =\npexprs.Arr.prototype.getArity =\npexprs.Str.prototype.getArity = function() {\n  return this.expr.getArity();\n};\n\npexprs.Obj.prototype.getArity = function() {\n  var arity = this.isLenient ? 1 : 0;\n  for (var idx = 0; idx < this.properties.length; idx++) {\n    arity += this.properties[idx].pattern.getArity();\n  }\n  return arity;\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n// NOTE: the `introduceParams` method modifies the receiver in place.\n\npexprs.PExpr.prototype.introduceParams = function(formals) {\n  return this;\n};\n\npexprs.Alt.prototype.introduceParams = function(formals) {\n  this.terms.forEach(function(term, idx, terms) {\n    terms[idx] = term.introduceParams(formals);\n  });\n  return this;\n};\n\npexprs.Seq.prototype.introduceParams = function(formals) {\n  this.factors.forEach(function(factor, idx, factors) {\n    factors[idx] = factor.introduceParams(formals);\n  });\n  return this;\n};\n\npexprs.Iter.prototype.introduceParams =\npexprs.Not.prototype.introduceParams =\npexprs.Lookahead.prototype.introduceParams =\npexprs.Arr.prototype.introduceParams =\npexprs.Str.prototype.introduceParams = function(formals) {\n  this.expr = this.expr.introduceParams(formals);\n  return this;\n};\n\npexprs.Obj.prototype.introduceParams = function(formals) {\n  this.properties.forEach(function(property, idx) {\n    property.pattern = property.pattern.introduceParams(formals);\n  });\n  return this;\n};\n\npexprs.Apply.prototype.introduceParams = function(formals) {\n  var index = formals.indexOf(this.ruleName);\n  if (index >= 0) {\n    if (this.params.length > 0) {\n      throw new Error('FIXME: should catch this earlier');\n    }\n    return new pexprs.Param(index);\n  } else {\n    this.params.forEach(function(param, idx, params) {\n      params[idx] = param.introduceParams(formals);\n    });\n    return this;\n  }\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n// Returns `true` if this parsing expression may accept without consuming any input.\npexprs.PExpr.prototype.isNullable = function(grammar) {\n  return this._isNullable(grammar, Object.create(null));\n};\n\npexprs.PExpr.prototype._isNullable = function(grammar, memo) {\n  return false;\n};\n\npexprs.end._isNullable = function(grammar, memo) {\n  return true;\n};\n\npexprs.StringPrim.prototype._isNullable = function(grammar, memo) {\n  // This is an over-simplification: it's only correct if the input is a string. If it's an array\n  // or an object, then the empty string parsing expression is not nullable.\n  return this.obj === '';\n};\n\npexprs.Alt.prototype._isNullable = function(grammar, memo) {\n  return this.terms.length === 0 ||\n      this.terms.some(function(term) { return term._isNullable(grammar, memo); });\n};\n\npexprs.Seq.prototype._isNullable = function(grammar, memo) {\n  return this.factors.every(function(factor) { return factor._isNullable(grammar, memo); });\n};\n\npexprs.Star.prototype._isNullable =\npexprs.Opt.prototype._isNullable =\npexprs.Not.prototype._isNullable =\npexprs.Lookahead.prototype._isNullable = function(grammar, memo) {\n  return true;\n};\n\npexprs.Str.prototype._isNullable = function(grammar, memo) {\n  // This is also an over-simplification that is only correct when the input is a string.\n  return this.expr._isNullable(grammar, memo);\n};\n\npexprs.Apply.prototype._isNullable = function(grammar, memo) {\n  var key = this.toMemoKey();\n  if (!Object.prototype.hasOwnProperty.call(memo, key)) {\n    var body = grammar.ruleDict[this.ruleName];\n    var inlined = body.substituteParams(this.params);\n    memo[key] = false;\n    memo[key] = inlined._isNullable(grammar, memo);\n  }\n  return memo[key];\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n// Do nothing by default.\npexprs.PExpr.prototype.maybeRecordFailure = function(state, startPos) {\n};\n\n// For PExprs that directly consume input, record the failure in the state object.\npexprs.anything.maybeRecordFailure =\npexprs.end.maybeRecordFailure =\npexprs.Prim.prototype.maybeRecordFailure =\npexprs.Not.prototype.maybeRecordFailure = function(state, startPos) {\n  state.recordFailure(startPos, this);\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.outputRecipe = common.abstract;\n\npexprs.anything.outputRecipe = function(sb, formals) {\n  sb.append('this.anything()');\n};\n\npexprs.end.outputRecipe = function(sb, formals) {\n  sb.append('this.end()');\n};\n\npexprs.Prim.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.prim(');\n  sb.append(typeof this.obj === 'string' ? common.toStringLiteral(this.obj) : '' + this.obj);\n  sb.append(')');\n};\n\npexprs.Param.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.param(' + this.index + ')');\n};\n\npexprs.Alt.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.alt(');\n  for (var idx = 0; idx < this.terms.length; idx++) {\n    if (idx > 0) {\n      sb.append(', ');\n    }\n    this.terms[idx].outputRecipe(sb, formals);\n  }\n  sb.append(')');\n};\n\npexprs.Seq.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.seq(');\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    if (idx > 0) {\n      sb.append(', ');\n    }\n    this.factors[idx].outputRecipe(sb, formals);\n  }\n  sb.append(')');\n};\n\npexprs.Star.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.star(');\n  this.expr.outputRecipe(sb, formals);\n  sb.append(')');\n};\n\npexprs.Plus.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.plus(');\n  this.expr.outputRecipe(sb, formals);\n  sb.append(')');\n};\n\npexprs.Opt.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.opt(');\n  this.expr.outputRecipe(sb, formals);\n  sb.append(')');\n};\n\npexprs.Not.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.not(');\n  this.expr.outputRecipe(sb, formals);\n  sb.append(')');\n};\n\npexprs.Lookahead.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.la(');\n  this.expr.outputRecipe(sb, formals);\n  sb.append(')');\n};\n\npexprs.Arr.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.arr(');\n  this.expr.outputRecipe(sb, formals);\n  sb.append(')');\n};\n\npexprs.Str.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.str(');\n  this.expr.outputRecipe(sb, formals);\n  sb.append(')');\n};\n\npexprs.Obj.prototype.outputRecipe = function(sb, formals) {\n  function outputPropertyRecipe(prop) {\n    sb.append('{name: ');\n    sb.append(common.toStringLiteral(prop.name));\n    sb.append(', pattern: ');\n    prop.pattern.outputRecipe(sb, formals);\n    sb.append('}');\n  }\n\n  sb.append('this.obj([');\n  for (var idx = 0; idx < this.properties.length; idx++) {\n    if (idx > 0) {\n      sb.append(', ');\n    }\n    outputPropertyRecipe(this.properties[idx]);\n  }\n  sb.append('], ');\n  sb.append(!!this.isLenient);\n  sb.append(')');\n};\n\npexprs.Apply.prototype.outputRecipe = function(sb, formals) {\n  sb.append('this.app(');\n  sb.append(common.toStringLiteral(this.ruleName));\n  if (this.ruleName.indexOf('_') >= 0 && formals.length > 0) {\n    var apps = formals.\n        map(function(formal) { return 'this.app(' + common.toStringLiteral(formal) + ')'; });\n    sb.append(', [' + apps.join(', ') + ']');\n  } else if (this.params.length > 0) {\n    sb.append(', [');\n    this.params.forEach(function(param, idx) {\n      if (idx > 0) {\n        sb.append(', ');\n      }\n      param.outputRecipe(sb, formals);\n    });\n    sb.append(']');\n  }\n  sb.append(')');\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.substituteParams = function(actuals) {\n  return this;\n};\n\npexprs.Param.prototype.substituteParams = function(actuals) {\n  return actuals[this.index];\n};\n\npexprs.Alt.prototype.substituteParams = function(actuals) {\n  return new pexprs.Alt(\n      this.terms.map(function(term) { return term.substituteParams(actuals); }));\n};\n\npexprs.Seq.prototype.substituteParams = function(actuals) {\n  return new pexprs.Seq(\n      this.factors.map(function(factor) { return factor.substituteParams(actuals); }));\n};\n\npexprs.Iter.prototype.substituteParams =\npexprs.Not.prototype.substituteParams =\npexprs.Lookahead.prototype.substituteParams =\npexprs.Arr.prototype.substituteParams =\npexprs.Str.prototype.substituteParams = function(actuals) {\n  return new this.constructor(this.expr.substituteParams(actuals));\n};\n\npexprs.Obj.prototype.substituteParams = function(actuals) {\n  var properties = this.properties.map(function(property) {\n    return {\n      name: property.name,\n      pattern: property.pattern.substituteParams(actuals)\n    };\n  });\n  return new pexprs.Obj(properties, this.isLenient);\n};\n\npexprs.Apply.prototype.substituteParams = function(actuals) {\n  if (this.params.length === 0) {\n    // Avoid making a copy of this application, as an optimization\n    return this;\n  } else {\n    var params = this.params.map(function(param) { return param.substituteParams(actuals); });\n    return new pexprs.Apply(this.ruleName, params);\n  }\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n// Returns a string representing the PExpr, for use as a UI label, etc.\npexprs.PExpr.prototype.toDisplayString = function() {\n  if (this.interval) {\n    return this.interval.trimmed().contents;\n  }\n  return '[' + this.constructor.name + ']';\n};\n\npexprs.anything.toDisplayString = function() {\n  return '_';\n};\n\npexprs.end.toDisplayString = function() {\n  return 'end';\n};\n\npexprs.Prim.prototype.toDisplayString = function() {\n  return String(this.obj);\n};\n\npexprs.Param.prototype.toDisplayString = function() {\n  return '#' + this.index;\n};\n\npexprs.StringPrim.prototype.toDisplayString = function() {\n  return '\"' + this.obj + '\"';\n};\n\npexprs.Apply.prototype.toDisplayString = function() {\n  return this.ruleName;\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.toExpected = function(ruleDict) {\n  return undefined;\n};\n\npexprs.anything.toExpected = function(ruleDict) {\n  return 'any object';\n};\n\npexprs.end.toExpected = function(ruleDict) {\n  return 'end of input';\n};\n\npexprs.Prim.prototype.toExpected = function(ruleDict) {\n  return common.toStringLiteral(this.obj);\n};\n\npexprs.Not.prototype.toExpected = function(ruleDict) {\n  if (this.expr === pexprs.anything) {\n    return 'nothing';\n  } else {\n    return 'not ' + this.expr.toExpected(ruleDict);\n  }\n};\n\n// TODO: think about Arr, Str, and Obj\n\npexprs.Apply.prototype.toExpected = function(ruleDict) {\n  var description = ruleDict[this.ruleName].description;\n  if (description) {\n    return description;\n  } else {\n    var article = (/^[aeiouAEIOU]/.test(this.ruleName) ? 'an' : 'a');\n    return article + ' ' + this.ruleName;\n  }\n};\n\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n/*\n  e1.toString() === e2.toString() ==> e1 and e2 are semantically equivalent.\n  Note that this is not an iff (<==>): e.g.,\n  (~\"b\" \"a\").toString() !== (\"a\").toString(), even though\n  ~\"b\" \"a\" and \"a\" are interchangeable in any grammar,\n  both in terms of the languages they accept and their arities.\n*/\npexprs.PExpr.prototype.toString = common.abstract;\n\npexprs.anything.toString = function() {\n  return '_';\n};\n\npexprs.end.toString = function() {\n  return 'end';\n};\n\npexprs.Prim.prototype.toString = function() {\n  return JSON.stringify(this.obj);\n};\n\npexprs.Param.prototype.toString = function() {\n  return '#' + this.index;\n};\n\npexprs.RegExpPrim.prototype.toString = function() {\n  return this.obj.toString();\n};\n\npexprs.Alt.prototype.toString = function() {\n  return this.terms.length === 1 ?\n    this.terms[0].toString() :\n    '(' + this.terms.map(function(term) { return term.toString(); }).join(' | ') + ')';\n};\n\npexprs.Seq.prototype.toString = function() {\n  return this.factors.length === 1 ?\n    this.factors[0].toString() :\n    '(' + this.factors.map(function(factor) { return factor.toString(); }).join(' ') + ')';\n};\n\npexprs.Iter.prototype.toString = function() {\n  return this.expr + this.operator;\n};\n\npexprs.Not.prototype.toString = function() {\n  return '~' + this.expr;\n};\n\npexprs.Lookahead.prototype.toString = function() {\n  return '&' + this.expr;\n};\n\npexprs.Arr.prototype.toString = function() {\n  return '[' + this.expr.toString() + ']';\n};\n\npexprs.Str.prototype.toString = function() {\n  return '``' + this.expr.toString() + \"''\";\n};\n\npexprs.Obj.prototype.toString = function() {\n  var parts = ['{'];\n\n  var first = true;\n  function emit(part) {\n    if (first) {\n      first = false;\n    } else {\n      parts.push(', ');\n    }\n    parts.push(part);\n  }\n\n  this.properties.forEach(function(property) {\n    emit(JSON.stringify(property.name) + ': ' + property.pattern.toString());\n  });\n  if (this.isLenient) {\n    emit('...');\n  }\n\n  parts.push('}');\n  return parts.join('');\n};\n\npexprs.Apply.prototype.toString = function() {\n  if (this.params.length > 0) {\n    var ps = this.params.map(function(param) { return param.toString(); });\n    return this.ruleName + '<' + ps.join(',') + '>';\n  } else {\n    return this.ruleName;\n  }\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar errors = require('./errors');\nvar inherits = require('inherits');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// General stuff\n\nfunction PExpr() {\n  throw new Error(\"PExpr cannot be instantiated -- it's abstract\");\n}\n\nPExpr.prototype.withDescription = function(description) {\n  this.description = description;\n  return this;\n};\n\nPExpr.prototype.withInterval = function(interval) {\n  this.interval = interval.trimmed();\n  return this;\n};\n\nPExpr.prototype.withFormals = function(formals) {\n  this.formals = formals;\n  return this;\n};\n\n// Anything\n\nvar anything = Object.create(PExpr.prototype);\n\n// End\n\nvar end = Object.create(PExpr.prototype);\n\n// Primitives\n\nfunction Prim(obj) {\n  this.obj = obj;\n}\ninherits(Prim, PExpr);\n\nfunction StringPrim(obj) {\n  this.obj = obj;\n}\ninherits(StringPrim, Prim);\n\nfunction RegExpPrim(obj) {\n  this.obj = obj;\n}\ninherits(RegExpPrim, Prim);\n\n// Parameters\n\nfunction Param(index) {\n  this.index = index;\n}\ninherits(Param, PExpr);\n\n// Alternation\n\nfunction Alt(terms) {\n  this.terms = terms;\n}\ninherits(Alt, PExpr);\n\n// Extend is an implementation detail of rule extension\n\nfunction Extend(superGrammar, name, body) {\n  var origBody = superGrammar.ruleDict[name];\n  this.terms = [body, origBody];\n}\ninherits(Extend, Alt);\n\n// Sequences\n\nfunction Seq(factors) {\n  this.factors = factors;\n}\ninherits(Seq, PExpr);\n\n// Iterators and optionals\n\nfunction Iter(expr) {\n  this.expr = expr;\n}\ninherits(Iter, PExpr);\n\nfunction Star(expr) {\n  this.expr = expr;\n}\ninherits(Star, Iter);\n\nfunction Plus(expr) {\n  this.expr = expr;\n}\ninherits(Plus, Iter);\n\nfunction Opt(expr) {\n  this.expr = expr;\n}\ninherits(Opt, Iter);\n\nStar.prototype.operator = '*';\nPlus.prototype.operator = '+';\nOpt.prototype.operator = '?';\n\nStar.prototype.minNumMatches = 0;\nPlus.prototype.minNumMatches = 1;\nOpt.prototype.minNumMatches = 0;\n\nStar.prototype.maxNumMatches = Number.POSITIVE_INFINITY;\nPlus.prototype.maxNumMatches = Number.POSITIVE_INFINITY;\nOpt.prototype.maxNumMatches = 1;\n\n// Predicates\n\nfunction Not(expr) {\n  this.expr = expr;\n}\ninherits(Not, PExpr);\n\nfunction Lookahead(expr) {\n  this.expr = expr;\n}\ninherits(Lookahead, PExpr);\n\n// Array decomposition\n\nfunction Arr(expr) {\n  this.expr = expr;\n}\ninherits(Arr, PExpr);\n\n// String decomposition\n\nfunction Str(expr) {\n  this.expr = expr;\n}\ninherits(Str, PExpr);\n\n// Object decomposition\n\nfunction Obj(properties, isLenient) {\n  var names = properties.map(function(property) { return property.name; });\n  var duplicates = common.getDuplicates(names);\n  if (duplicates.length > 0) {\n    throw new errors.DuplicatePropertyNames(duplicates);\n  } else {\n    this.properties = properties;\n    this.isLenient = isLenient;\n  }\n}\ninherits(Obj, PExpr);\n\n// Rule application\n\nfunction Apply(ruleName, optParams) {\n  this.ruleName = ruleName;\n  this.params = optParams || [];\n}\ninherits(Apply, PExpr);\n\n// This method just caches the result of `this.toString()` in a non-enumerable property.\nApply.prototype.toMemoKey = function() {\n  if (!this._memoKey) {\n    Object.defineProperty(this, '_memoKey', {value: this.toString()});\n  }\n  return this._memoKey;\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nexports.makePrim = function(obj) {\n  if (typeof obj === 'string' && obj.length !== 1) {\n    return new StringPrim(obj);\n  } else if (obj instanceof RegExp) {\n    return new RegExpPrim(obj);\n  } else {\n    return new Prim(obj);\n  }\n};\n\nexports.PExpr = PExpr;\nexports.anything = anything;\nexports.end = end;\nexports.Prim = Prim;\nexports.StringPrim = StringPrim;\nexports.RegExpPrim = RegExpPrim;\nexports.Param = Param;\nexports.Alt = Alt;\nexports.Extend = Extend;\nexports.Seq = Seq;\nexports.Iter = Iter;\nexports.Star = Star;\nexports.Plus = Plus;\nexports.Opt = Opt;\nexports.Not = Not;\nexports.Lookahead = Lookahead;\nexports.Arr = Arr;\nexports.Str = Str;\nexports.Obj = Obj;\nexports.Apply = Apply;\n\n// --------------------------------------------------------------------\n// Extensions\n// --------------------------------------------------------------------\n\nrequire('./pexprs-assertAllApplicationsAreValid');\nrequire('./pexprs-assertChoicesHaveUniformArity');\nrequire('./pexprs-assertIteratedExprsAreNotNullable');\nrequire('./pexprs-check');\nrequire('./pexprs-eval');\nrequire('./pexprs-maybeRecordFailure');\nrequire('./pexprs-getArity');\nrequire('./pexprs-outputRecipe');\nrequire('./pexprs-introduceParams');\nrequire('./pexprs-isNullable');\nrequire('./pexprs-substituteParams');\nrequire('./pexprs-toDisplayString');\nrequire('./pexprs-toExpected');\nrequire('./pexprs-toString');\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// Given an array of numbers `arr`, return an array of the numbers as strings,\n// right-justified and padded to the same length.\nfunction padNumbersToEqualLength(arr) {\n  var maxLen = 0;\n  var strings = arr.map(function(n) {\n    var str = n.toString();\n    maxLen = Math.max(maxLen, str.length);\n    return str;\n  });\n  return strings.map(function(s) { return common.padLeft(s, maxLen); });\n}\n\n// Produce a new string that would be the result of copying the contents\n// of the string `src` onto `dest` at offset `offest`.\nfunction strcpy(dest, src, offset) {\n  var origDestLen = dest.length;\n  var start = dest.slice(0, offset);\n  var end = dest.slice(offset + src.length);\n  return (start + src + end).substr(0, origDestLen);\n}\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\n// Return an object with the line and column information for the given\n// offset in `str`.\nexports.getLineAndColumn = function(str, offset) {\n  var lineNum = 1;\n  var colNum = 1;\n\n  var currOffset = 0;\n  var lineStartOffset = 0;\n\n  var nextLine = null;\n  var prevLine = null;\n  var prevLineStartOffset = -1;\n\n  while (currOffset < offset) {\n    var c = str.charAt(currOffset++);\n    if (c === '\\n') {\n      lineNum++;\n      colNum = 1;\n      prevLineStartOffset = lineStartOffset;\n      lineStartOffset = currOffset;\n    } else if (c !== '\\r') {\n      colNum++;\n    }\n  }\n\n  // Find the end of the target line.\n  var lineEndOffset = str.indexOf('\\n', lineStartOffset);\n  if (lineEndOffset === -1) {\n    lineEndOffset = str.length;\n  } else {\n    // Get the next line.\n    var nextLineEndOffset = str.indexOf('\\n', lineEndOffset + 1);\n    nextLine = nextLineEndOffset === -1 ? str.slice(lineEndOffset)\n                                        : str.slice(lineEndOffset, nextLineEndOffset);\n    // Strip leading and trailing EOL char(s).\n    nextLine = nextLine.replace(/^\\r?\\n/, '').replace(/\\r$/, '');\n  }\n\n  // Get the previous line.\n  if (prevLineStartOffset >= 0) {\n    prevLine = str.slice(prevLineStartOffset, lineStartOffset)\n                  .replace(/\\r?\\n$/, '');  // Strip trailing EOL char(s).\n  }\n\n  // Get the target line, stripping a trailing carriage return if necessary.\n  var line = str.slice(lineStartOffset, lineEndOffset).replace(/\\r$/, '');\n\n  return {\n    lineNum: lineNum,\n    colNum: colNum,\n    line: line,\n    prevLine: prevLine,\n    nextLine: nextLine\n  };\n};\n\n// Return a nicely-formatted string describing the line and column for the\n// given offset in `str`.\nexports.getLineAndColumnMessage = function(str, offset /* ...ranges */) {\n  var repeatStr = common.repeatStr;\n\n  var lineAndCol = exports.getLineAndColumn(str, offset);\n  var sb = new common.StringBuffer();\n  sb.append('Line ' + lineAndCol.lineNum + ', col ' + lineAndCol.colNum + ':\\n');\n\n  // An array of the previous, current, and next line numbers as strings of equal length.\n  var lineNumbers = padNumbersToEqualLength([\n      lineAndCol.prevLine == null ? 0 : lineAndCol.lineNum - 1,\n      lineAndCol.lineNum,\n      lineAndCol.nextLine == null ? 0 : lineAndCol.lineNum + 1\n  ]);\n\n  // Helper for appending formatting input lines to the buffer.\n  function appendLine(num, content, prefix) {\n    sb.append(prefix + lineNumbers[num] + ' | ' + content + '\\n');\n  }\n\n  // Include the previous line for context if possible.\n  if (lineAndCol.prevLine != null) {\n    appendLine(0, lineAndCol.prevLine, '  ');\n  }\n  // Line that the error occurred on.\n  appendLine(1, lineAndCol.line, '> ');\n\n  // Build up the line that points to the offset and possible indicates one or more ranges.\n  // Start with a blank line, and indicate each range by overlaying a string of `~` chars.\n  var lineLen = lineAndCol.line.length;\n  var indicationLine = repeatStr(' ', lineLen + 1);\n  var ranges = Array.prototype.slice.call(arguments, 2);\n  for (var i = 0; i < ranges.length; ++i) {\n    var startIdx = ranges[i][0];\n    var endIdx = ranges[i][1];\n    common.assert(startIdx >= 0 && startIdx <= endIdx, 'range start must be >= 0 and <= end');\n\n    var lineStartOffset = offset - lineAndCol.colNum + 1;\n    startIdx = Math.max(0, startIdx - lineStartOffset);\n    endIdx = Math.min(endIdx - lineStartOffset, lineLen);\n\n    indicationLine = strcpy(indicationLine, repeatStr('~', endIdx - startIdx), startIdx);\n  }\n  var gutterWidth = 2 + lineNumbers[1].length + 3;\n  sb.append(repeatStr(' ', gutterWidth));\n  indicationLine = strcpy(indicationLine, '^', lineAndCol.colNum - 1);\n  sb.append(indicationLine.replace(/ +$/, '') + '\\n');\n\n  // Include the next line for context if possible.\n  if (lineAndCol.nextLine != null) {\n    appendLine(2, lineAndCol.nextLine, '  ');\n  }\n  return sb.contents();\n};\n","// From https://code.google.com/p/es-lab/source/browse/trunk/src/parser/unicode.js\nexports.UnicodeCategories = {\n  ZWNJ : /\\u200C/,\n  ZWJ  : /\\u200D/,\n  TAB  : /\\u0009/,\n  VT   : /\\u000B/,\n  FF   : /\\u000C/,\n  SP   : /\\u0020/,\n  NBSP : /\\u00A0/,\n  BOM  : /\\uFEFF/,\n  LF   : /\\u000A/,\n  CR   : /\\u000D/,\n  LS   : /\\u2028/,\n  PS   : /\\u2029/,\n  L    : /[\\u0041-\\u005A]|[\\u00C0-\\u00D6]|[\\u00D8-\\u00DE]|[\\u0100-\\u0100]|[\\u0102-\\u0102]|[\\u0104-\\u0104]|[\\u0106-\\u0106]|[\\u0108-\\u0108]|[\\u010A-\\u010A]|[\\u010C-\\u010C]|[\\u010E-\\u010E]|[\\u0110-\\u0110]|[\\u0112-\\u0112]|[\\u0114-\\u0114]|[\\u0116-\\u0116]|[\\u0118-\\u0118]|[\\u011A-\\u011A]|[\\u011C-\\u011C]|[\\u011E-\\u011E]|[\\u0120-\\u0120]|[\\u0122-\\u0122]|[\\u0124-\\u0124]|[\\u0126-\\u0126]|[\\u0128-\\u0128]|[\\u012A-\\u012A]|[\\u012C-\\u012C]|[\\u012E-\\u012E]|[\\u0130-\\u0130]|[\\u0132-\\u0132]|[\\u0134-\\u0134]|[\\u0136-\\u0136]|[\\u0139-\\u0139]|[\\u013B-\\u013B]|[\\u013D-\\u013D]|[\\u013F-\\u013F]|[\\u0141-\\u0141]|[\\u0143-\\u0143]|[\\u0145-\\u0145]|[\\u0147-\\u0147]|[\\u014A-\\u014A]|[\\u014C-\\u014C]|[\\u014E-\\u014E]|[\\u0150-\\u0150]|[\\u0152-\\u0152]|[\\u0154-\\u0154]|[\\u0156-\\u0156]|[\\u0158-\\u0158]|[\\u015A-\\u015A]|[\\u015C-\\u015C]|[\\u015E-\\u015E]|[\\u0160-\\u0160]|[\\u0162-\\u0162]|[\\u0164-\\u0164]|[\\u0166-\\u0166]|[\\u0168-\\u0168]|[\\u016A-\\u016A]|[\\u016C-\\u016C]|[\\u016E-\\u016E]|[\\u0170-\\u0170]|[\\u0172-\\u0172]|[\\u0174-\\u0174]|[\\u0176-\\u0176]|[\\u0178-\\u0179]|[\\u017B-\\u017B]|[\\u017D-\\u017D]|[\\u0181-\\u0182]|[\\u0184-\\u0184]|[\\u0186-\\u0187]|[\\u0189-\\u018B]|[\\u018E-\\u0191]|[\\u0193-\\u0194]|[\\u0196-\\u0198]|[\\u019C-\\u019D]|[\\u019F-\\u01A0]|[\\u01A2-\\u01A2]|[\\u01A4-\\u01A4]|[\\u01A6-\\u01A7]|[\\u01A9-\\u01A9]|[\\u01AC-\\u01AC]|[\\u01AE-\\u01AF]|[\\u01B1-\\u01B3]|[\\u01B5-\\u01B5]|[\\u01B7-\\u01B8]|[\\u01BC-\\u01BC]|[\\u01C4-\\u01C4]|[\\u01C7-\\u01C7]|[\\u01CA-\\u01CA]|[\\u01CD-\\u01CD]|[\\u01CF-\\u01CF]|[\\u01D1-\\u01D1]|[\\u01D3-\\u01D3]|[\\u01D5-\\u01D5]|[\\u01D7-\\u01D7]|[\\u01D9-\\u01D9]|[\\u01DB-\\u01DB]|[\\u01DE-\\u01DE]|[\\u01E0-\\u01E0]|[\\u01E2-\\u01E2]|[\\u01E4-\\u01E4]|[\\u01E6-\\u01E6]|[\\u01E8-\\u01E8]|[\\u01EA-\\u01EA]|[\\u01EC-\\u01EC]|[\\u01EE-\\u01EE]|[\\u01F1-\\u01F1]|[\\u01F4-\\u01F4]|[\\u01FA-\\u01FA]|[\\u01FC-\\u01FC]|[\\u01FE-\\u01FE]|[\\u0200-\\u0200]|[\\u0202-\\u0202]|[\\u0204-\\u0204]|[\\u0206-\\u0206]|[\\u0208-\\u0208]|[\\u020A-\\u020A]|[\\u020C-\\u020C]|[\\u020E-\\u020E]|[\\u0210-\\u0210]|[\\u0212-\\u0212]|[\\u0214-\\u0214]|[\\u0216-\\u0216]|[\\u0386-\\u0386]|[\\u0388-\\u038A]|[\\u038C-\\u038C]|[\\u038E-\\u038F]|[\\u0391-\\u03A1]|[\\u03A3-\\u03AB]|[\\u03D2-\\u03D4]|[\\u03DA-\\u03DA]|[\\u03DC-\\u03DC]|[\\u03DE-\\u03DE]|[\\u03E0-\\u03E0]|[\\u03E2-\\u03E2]|[\\u03E4-\\u03E4]|[\\u03E6-\\u03E6]|[\\u03E8-\\u03E8]|[\\u03EA-\\u03EA]|[\\u03EC-\\u03EC]|[\\u03EE-\\u03EE]|[\\u0401-\\u040C]|[\\u040E-\\u042F]|[\\u0460-\\u0460]|[\\u0462-\\u0462]|[\\u0464-\\u0464]|[\\u0466-\\u0466]|[\\u0468-\\u0468]|[\\u046A-\\u046A]|[\\u046C-\\u046C]|[\\u046E-\\u046E]|[\\u0470-\\u0470]|[\\u0472-\\u0472]|[\\u0474-\\u0474]|[\\u0476-\\u0476]|[\\u0478-\\u0478]|[\\u047A-\\u047A]|[\\u047C-\\u047C]|[\\u047E-\\u047E]|[\\u0480-\\u0480]|[\\u0490-\\u0490]|[\\u0492-\\u0492]|[\\u0494-\\u0494]|[\\u0496-\\u0496]|[\\u0498-\\u0498]|[\\u049A-\\u049A]|[\\u049C-\\u049C]|[\\u049E-\\u049E]|[\\u04A0-\\u04A0]|[\\u04A2-\\u04A2]|[\\u04A4-\\u04A4]|[\\u04A6-\\u04A6]|[\\u04A8-\\u04A8]|[\\u04AA-\\u04AA]|[\\u04AC-\\u04AC]|[\\u04AE-\\u04AE]|[\\u04B0-\\u04B0]|[\\u04B2-\\u04B2]|[\\u04B4-\\u04B4]|[\\u04B6-\\u04B6]|[\\u04B8-\\u04B8]|[\\u04BA-\\u04BA]|[\\u04BC-\\u04BC]|[\\u04BE-\\u04BE]|[\\u04C1-\\u04C1]|[\\u04C3-\\u04C3]|[\\u04C7-\\u04C7]|[\\u04CB-\\u04CB]|[\\u04D0-\\u04D0]|[\\u04D2-\\u04D2]|[\\u04D4-\\u04D4]|[\\u04D6-\\u04D6]|[\\u04D8-\\u04D8]|[\\u04DA-\\u04DA]|[\\u04DC-\\u04DC]|[\\u04DE-\\u04DE]|[\\u04E0-\\u04E0]|[\\u04E2-\\u04E2]|[\\u04E4-\\u04E4]|[\\u04E6-\\u04E6]|[\\u04E8-\\u04E8]|[\\u04EA-\\u04EA]|[\\u04EE-\\u04EE]|[\\u04F0-\\u04F0]|[\\u04F2-\\u04F2]|[\\u04F4-\\u04F4]|[\\u04F8-\\u04F8]|[\\u0531-\\u0556]|[\\u10A0-\\u10C5]|[\\u1E00-\\u1E00]|[\\u1E02-\\u1E02]|[\\u1E04-\\u1E04]|[\\u1E06-\\u1E06]|[\\u1E08-\\u1E08]|[\\u1E0A-\\u1E0A]|[\\u1E0C-\\u1E0C]|[\\u1E0E-\\u1E0E]|[\\u1E10-\\u1E10]|[\\u1E12-\\u1E12]|[\\u1E14-\\u1E14]|[\\u1E16-\\u1E16]|[\\u1E18-\\u1E18]|[\\u1E1A-\\u1E1A]|[\\u1E1C-\\u1E1C]|[\\u1E1E-\\u1E1E]|[\\u1E20-\\u1E20]|[\\u1E22-\\u1E22]|[\\u1E24-\\u1E24]|[\\u1E26-\\u1E26]|[\\u1E28-\\u1E28]|[\\u1E2A-\\u1E2A]|[\\u1E2C-\\u1E2C]|[\\u1E2E-\\u1E2E]|[\\u1E30-\\u1E30]|[\\u1E32-\\u1E32]|[\\u1E34-\\u1E34]|[\\u1E36-\\u1E36]|[\\u1E38-\\u1E38]|[\\u1E3A-\\u1E3A]|[\\u1E3C-\\u1E3C]|[\\u1E3E-\\u1E3E]|[\\u1E40-\\u1E40]|[\\u1E42-\\u1E42]|[\\u1E44-\\u1E44]|[\\u1E46-\\u1E46]|[\\u1E48-\\u1E48]|[\\u1E4A-\\u1E4A]|[\\u1E4C-\\u1E4C]|[\\u1E4E-\\u1E4E]|[\\u1E50-\\u1E50]|[\\u1E52-\\u1E52]|[\\u1E54-\\u1E54]|[\\u1E56-\\u1E56]|[\\u1E58-\\u1E58]|[\\u1E5A-\\u1E5A]|[\\u1E5C-\\u1E5C]|[\\u1E5E-\\u1E5E]|[\\u1E60-\\u1E60]|[\\u1E62-\\u1E62]|[\\u1E64-\\u1E64]|[\\u1E66-\\u1E66]|[\\u1E68-\\u1E68]|[\\u1E6A-\\u1E6A]|[\\u1E6C-\\u1E6C]|[\\u1E6E-\\u1E6E]|[\\u1E70-\\u1E70]|[\\u1E72-\\u1E72]|[\\u1E74-\\u1E74]|[\\u1E76-\\u1E76]|[\\u1E78-\\u1E78]|[\\u1E7A-\\u1E7A]|[\\u1E7C-\\u1E7C]|[\\u1E7E-\\u1E7E]|[\\u1E80-\\u1E80]|[\\u1E82-\\u1E82]|[\\u1E84-\\u1E84]|[\\u1E86-\\u1E86]|[\\u1E88-\\u1E88]|[\\u1E8A-\\u1E8A]|[\\u1E8C-\\u1E8C]|[\\u1E8E-\\u1E8E]|[\\u1E90-\\u1E90]|[\\u1E92-\\u1E92]|[\\u1E94-\\u1E94]|[\\u1EA0-\\u1EA0]|[\\u1EA2-\\u1EA2]|[\\u1EA4-\\u1EA4]|[\\u1EA6-\\u1EA6]|[\\u1EA8-\\u1EA8]|[\\u1EAA-\\u1EAA]|[\\u1EAC-\\u1EAC]|[\\u1EAE-\\u1EAE]|[\\u1EB0-\\u1EB0]|[\\u1EB2-\\u1EB2]|[\\u1EB4-\\u1EB4]|[\\u1EB6-\\u1EB6]|[\\u1EB8-\\u1EB8]|[\\u1EBA-\\u1EBA]|[\\u1EBC-\\u1EBC]|[\\u1EBE-\\u1EBE]|[\\u1EC0-\\u1EC0]|[\\u1EC2-\\u1EC2]|[\\u1EC4-\\u1EC4]|[\\u1EC6-\\u1EC6]|[\\u1EC8-\\u1EC8]|[\\u1ECA-\\u1ECA]|[\\u1ECC-\\u1ECC]|[\\u1ECE-\\u1ECE]|[\\u1ED0-\\u1ED0]|[\\u1ED2-\\u1ED2]|[\\u1ED4-\\u1ED4]|[\\u1ED6-\\u1ED6]|[\\u1ED8-\\u1ED8]|[\\u1EDA-\\u1EDA]|[\\u1EDC-\\u1EDC]|[\\u1EDE-\\u1EDE]|[\\u1EE0-\\u1EE0]|[\\u1EE2-\\u1EE2]|[\\u1EE4-\\u1EE4]|[\\u1EE6-\\u1EE6]|[\\u1EE8-\\u1EE8]|[\\u1EEA-\\u1EEA]|[\\u1EEC-\\u1EEC]|[\\u1EEE-\\u1EEE]|[\\u1EF0-\\u1EF0]|[\\u1EF2-\\u1EF2]|[\\u1EF4-\\u1EF4]|[\\u1EF6-\\u1EF6]|[\\u1EF8-\\u1EF8]|[\\u1F08-\\u1F0F]|[\\u1F18-\\u1F1D]|[\\u1F28-\\u1F2F]|[\\u1F38-\\u1F3F]|[\\u1F48-\\u1F4D]|[\\u1F59-\\u1F59]|[\\u1F5B-\\u1F5B]|[\\u1F5D-\\u1F5D]|[\\u1F5F-\\u1F5F]|[\\u1F68-\\u1F6F]|[\\u1F88-\\u1F8F]|[\\u1F98-\\u1F9F]|[\\u1FA8-\\u1FAF]|[\\u1FB8-\\u1FBC]|[\\u1FC8-\\u1FCC]|[\\u1FD8-\\u1FDB]|[\\u1FE8-\\u1FEC]|[\\u1FF8-\\u1FFC]|[\\u2102-\\u2102]|[\\u2107-\\u2107]|[\\u210B-\\u210D]|[\\u2110-\\u2112]|[\\u2115-\\u2115]|[\\u2119-\\u211D]|[\\u2124-\\u2124]|[\\u2126-\\u2126]|[\\u2128-\\u2128]|[\\u212A-\\u212D]|[\\u2130-\\u2131]|[\\u2133-\\u2133]|[\\uFF21-\\uFF3A]|[\\u0061-\\u007A]|[\\u00AA-\\u00AA]|[\\u00B5-\\u00B5]|[\\u00BA-\\u00BA]|[\\u00DF-\\u00F6]|[\\u00F8-\\u00FF]|[\\u0101-\\u0101]|[\\u0103-\\u0103]|[\\u0105-\\u0105]|[\\u0107-\\u0107]|[\\u0109-\\u0109]|[\\u010B-\\u010B]|[\\u010D-\\u010D]|[\\u010F-\\u010F]|[\\u0111-\\u0111]|[\\u0113-\\u0113]|[\\u0115-\\u0115]|[\\u0117-\\u0117]|[\\u0119-\\u0119]|[\\u011B-\\u011B]|[\\u011D-\\u011D]|[\\u011F-\\u011F]|[\\u0121-\\u0121]|[\\u0123-\\u0123]|[\\u0125-\\u0125]|[\\u0127-\\u0127]|[\\u0129-\\u0129]|[\\u012B-\\u012B]|[\\u012D-\\u012D]|[\\u012F-\\u012F]|[\\u0131-\\u0131]|[\\u0133-\\u0133]|[\\u0135-\\u0135]|[\\u0137-\\u0138]|[\\u013A-\\u013A]|[\\u013C-\\u013C]|[\\u013E-\\u013E]|[\\u0140-\\u0140]|[\\u0142-\\u0142]|[\\u0144-\\u0144]|[\\u0146-\\u0146]|[\\u0148-\\u0149]|[\\u014B-\\u014B]|[\\u014D-\\u014D]|[\\u014F-\\u014F]|[\\u0151-\\u0151]|[\\u0153-\\u0153]|[\\u0155-\\u0155]|[\\u0157-\\u0157]|[\\u0159-\\u0159]|[\\u015B-\\u015B]|[\\u015D-\\u015D]|[\\u015F-\\u015F]|[\\u0161-\\u0161]|[\\u0163-\\u0163]|[\\u0165-\\u0165]|[\\u0167-\\u0167]|[\\u0169-\\u0169]|[\\u016B-\\u016B]|[\\u016D-\\u016D]|[\\u016F-\\u016F]|[\\u0171-\\u0171]|[\\u0173-\\u0173]|[\\u0175-\\u0175]|[\\u0177-\\u0177]|[\\u017A-\\u017A]|[\\u017C-\\u017C]|[\\u017E-\\u0180]|[\\u0183-\\u0183]|[\\u0185-\\u0185]|[\\u0188-\\u0188]|[\\u018C-\\u018D]|[\\u0192-\\u0192]|[\\u0195-\\u0195]|[\\u0199-\\u019B]|[\\u019E-\\u019E]|[\\u01A1-\\u01A1]|[\\u01A3-\\u01A3]|[\\u01A5-\\u01A5]|[\\u01A8-\\u01A8]|[\\u01AB-\\u01AB]|[\\u01AD-\\u01AD]|[\\u01B0-\\u01B0]|[\\u01B4-\\u01B4]|[\\u01B6-\\u01B6]|[\\u01B9-\\u01BA]|[\\u01BD-\\u01BD]|[\\u01C6-\\u01C6]|[\\u01C9-\\u01C9]|[\\u01CC-\\u01CC]|[\\u01CE-\\u01CE]|[\\u01D0-\\u01D0]|[\\u01D2-\\u01D2]|[\\u01D4-\\u01D4]|[\\u01D6-\\u01D6]|[\\u01D8-\\u01D8]|[\\u01DA-\\u01DA]|[\\u01DC-\\u01DD]|[\\u01DF-\\u01DF]|[\\u01E1-\\u01E1]|[\\u01E3-\\u01E3]|[\\u01E5-\\u01E5]|[\\u01E7-\\u01E7]|[\\u01E9-\\u01E9]|[\\u01EB-\\u01EB]|[\\u01ED-\\u01ED]|[\\u01EF-\\u01F0]|[\\u01F3-\\u01F3]|[\\u01F5-\\u01F5]|[\\u01FB-\\u01FB]|[\\u01FD-\\u01FD]|[\\u01FF-\\u01FF]|[\\u0201-\\u0201]|[\\u0203-\\u0203]|[\\u0205-\\u0205]|[\\u0207-\\u0207]|[\\u0209-\\u0209]|[\\u020B-\\u020B]|[\\u020D-\\u020D]|[\\u020F-\\u020F]|[\\u0211-\\u0211]|[\\u0213-\\u0213]|[\\u0215-\\u0215]|[\\u0217-\\u0217]|[\\u0250-\\u02A8]|[\\u0390-\\u0390]|[\\u03AC-\\u03CE]|[\\u03D0-\\u03D1]|[\\u03D5-\\u03D6]|[\\u03E3-\\u03E3]|[\\u03E5-\\u03E5]|[\\u03E7-\\u03E7]|[\\u03E9-\\u03E9]|[\\u03EB-\\u03EB]|[\\u03ED-\\u03ED]|[\\u03EF-\\u03F2]|[\\u0430-\\u044F]|[\\u0451-\\u045C]|[\\u045E-\\u045F]|[\\u0461-\\u0461]|[\\u0463-\\u0463]|[\\u0465-\\u0465]|[\\u0467-\\u0467]|[\\u0469-\\u0469]|[\\u046B-\\u046B]|[\\u046D-\\u046D]|[\\u046F-\\u046F]|[\\u0471-\\u0471]|[\\u0473-\\u0473]|[\\u0475-\\u0475]|[\\u0477-\\u0477]|[\\u0479-\\u0479]|[\\u047B-\\u047B]|[\\u047D-\\u047D]|[\\u047F-\\u047F]|[\\u0481-\\u0481]|[\\u0491-\\u0491]|[\\u0493-\\u0493]|[\\u0495-\\u0495]|[\\u0497-\\u0497]|[\\u0499-\\u0499]|[\\u049B-\\u049B]|[\\u049D-\\u049D]|[\\u049F-\\u049F]|[\\u04A1-\\u04A1]|[\\u04A3-\\u04A3]|[\\u04A5-\\u04A5]|[\\u04A7-\\u04A7]|[\\u04A9-\\u04A9]|[\\u04AB-\\u04AB]|[\\u04AD-\\u04AD]|[\\u04AF-\\u04AF]|[\\u04B1-\\u04B1]|[\\u04B3-\\u04B3]|[\\u04B5-\\u04B5]|[\\u04B7-\\u04B7]|[\\u04B9-\\u04B9]|[\\u04BB-\\u04BB]|[\\u04BD-\\u04BD]|[\\u04BF-\\u04BF]|[\\u04C2-\\u04C2]|[\\u04C4-\\u04C4]|[\\u04C8-\\u04C8]|[\\u04CC-\\u04CC]|[\\u04D1-\\u04D1]|[\\u04D3-\\u04D3]|[\\u04D5-\\u04D5]|[\\u04D7-\\u04D7]|[\\u04D9-\\u04D9]|[\\u04DB-\\u04DB]|[\\u04DD-\\u04DD]|[\\u04DF-\\u04DF]|[\\u04E1-\\u04E1]|[\\u04E3-\\u04E3]|[\\u04E5-\\u04E5]|[\\u04E7-\\u04E7]|[\\u04E9-\\u04E9]|[\\u04EB-\\u04EB]|[\\u04EF-\\u04EF]|[\\u04F1-\\u04F1]|[\\u04F3-\\u04F3]|[\\u04F5-\\u04F5]|[\\u04F9-\\u04F9]|[\\u0561-\\u0587]|[\\u10D0-\\u10F6]|[\\u1E01-\\u1E01]|[\\u1E03-\\u1E03]|[\\u1E05-\\u1E05]|[\\u1E07-\\u1E07]|[\\u1E09-\\u1E09]|[\\u1E0B-\\u1E0B]|[\\u1E0D-\\u1E0D]|[\\u1E0F-\\u1E0F]|[\\u1E11-\\u1E11]|[\\u1E13-\\u1E13]|[\\u1E15-\\u1E15]|[\\u1E17-\\u1E17]|[\\u1E19-\\u1E19]|[\\u1E1B-\\u1E1B]|[\\u1E1D-\\u1E1D]|[\\u1E1F-\\u1E1F]|[\\u1E21-\\u1E21]|[\\u1E23-\\u1E23]|[\\u1E25-\\u1E25]|[\\u1E27-\\u1E27]|[\\u1E29-\\u1E29]|[\\u1E2B-\\u1E2B]|[\\u1E2D-\\u1E2D]|[\\u1E2F-\\u1E2F]|[\\u1E31-\\u1E31]|[\\u1E33-\\u1E33]|[\\u1E35-\\u1E35]|[\\u1E37-\\u1E37]|[\\u1E39-\\u1E39]|[\\u1E3B-\\u1E3B]|[\\u1E3D-\\u1E3D]|[\\u1E3F-\\u1E3F]|[\\u1E41-\\u1E41]|[\\u1E43-\\u1E43]|[\\u1E45-\\u1E45]|[\\u1E47-\\u1E47]|[\\u1E49-\\u1E49]|[\\u1E4B-\\u1E4B]|[\\u1E4D-\\u1E4D]|[\\u1E4F-\\u1E4F]|[\\u1E51-\\u1E51]|[\\u1E53-\\u1E53]|[\\u1E55-\\u1E55]|[\\u1E57-\\u1E57]|[\\u1E59-\\u1E59]|[\\u1E5B-\\u1E5B]|[\\u1E5D-\\u1E5D]|[\\u1E5F-\\u1E5F]|[\\u1E61-\\u1E61]|[\\u1E63-\\u1E63]|[\\u1E65-\\u1E65]|[\\u1E67-\\u1E67]|[\\u1E69-\\u1E69]|[\\u1E6B-\\u1E6B]|[\\u1E6D-\\u1E6D]|[\\u1E6F-\\u1E6F]|[\\u1E71-\\u1E71]|[\\u1E73-\\u1E73]|[\\u1E75-\\u1E75]|[\\u1E77-\\u1E77]|[\\u1E79-\\u1E79]|[\\u1E7B-\\u1E7B]|[\\u1E7D-\\u1E7D]|[\\u1E7F-\\u1E7F]|[\\u1E81-\\u1E81]|[\\u1E83-\\u1E83]|[\\u1E85-\\u1E85]|[\\u1E87-\\u1E87]|[\\u1E89-\\u1E89]|[\\u1E8B-\\u1E8B]|[\\u1E8D-\\u1E8D]|[\\u1E8F-\\u1E8F]|[\\u1E91-\\u1E91]|[\\u1E93-\\u1E93]|[\\u1E95-\\u1E9B]|[\\u1EA1-\\u1EA1]|[\\u1EA3-\\u1EA3]|[\\u1EA5-\\u1EA5]|[\\u1EA7-\\u1EA7]|[\\u1EA9-\\u1EA9]|[\\u1EAB-\\u1EAB]|[\\u1EAD-\\u1EAD]|[\\u1EAF-\\u1EAF]|[\\u1EB1-\\u1EB1]|[\\u1EB3-\\u1EB3]|[\\u1EB5-\\u1EB5]|[\\u1EB7-\\u1EB7]|[\\u1EB9-\\u1EB9]|[\\u1EBB-\\u1EBB]|[\\u1EBD-\\u1EBD]|[\\u1EBF-\\u1EBF]|[\\u1EC1-\\u1EC1]|[\\u1EC3-\\u1EC3]|[\\u1EC5-\\u1EC5]|[\\u1EC7-\\u1EC7]|[\\u1EC9-\\u1EC9]|[\\u1ECB-\\u1ECB]|[\\u1ECD-\\u1ECD]|[\\u1ECF-\\u1ECF]|[\\u1ED1-\\u1ED1]|[\\u1ED3-\\u1ED3]|[\\u1ED5-\\u1ED5]|[\\u1ED7-\\u1ED7]|[\\u1ED9-\\u1ED9]|[\\u1EDB-\\u1EDB]|[\\u1EDD-\\u1EDD]|[\\u1EDF-\\u1EDF]|[\\u1EE1-\\u1EE1]|[\\u1EE3-\\u1EE3]|[\\u1EE5-\\u1EE5]|[\\u1EE7-\\u1EE7]|[\\u1EE9-\\u1EE9]|[\\u1EEB-\\u1EEB]|[\\u1EED-\\u1EED]|[\\u1EEF-\\u1EEF]|[\\u1EF1-\\u1EF1]|[\\u1EF3-\\u1EF3]|[\\u1EF5-\\u1EF5]|[\\u1EF7-\\u1EF7]|[\\u1EF9-\\u1EF9]|[\\u1F00-\\u1F07]|[\\u1F10-\\u1F15]|[\\u1F20-\\u1F27]|[\\u1F30-\\u1F37]|[\\u1F40-\\u1F45]|[\\u1F50-\\u1F57]|[\\u1F60-\\u1F67]|[\\u1F70-\\u1F7D]|[\\u1F80-\\u1F87]|[\\u1F90-\\u1F97]|[\\u1FA0-\\u1FA7]|[\\u1FB0-\\u1FB4]|[\\u1FB6-\\u1FB7]|[\\u1FBE-\\u1FBE]|[\\u1FC2-\\u1FC4]|[\\u1FC6-\\u1FC7]|[\\u1FD0-\\u1FD3]|[\\u1FD6-\\u1FD7]|[\\u1FE0-\\u1FE7]|[\\u1FF2-\\u1FF4]|[\\u1FF6-\\u1FF7]|[\\u207F-\\u207F]|[\\u210A-\\u210A]|[\\u210E-\\u210F]|[\\u2113-\\u2113]|[\\u2118-\\u2118]|[\\u212E-\\u212F]|[\\u2134-\\u2134]|[\\uFB00-\\uFB06]|[\\uFB13-\\uFB17]|[\\uFF41-\\uFF5A]|[\\u01C5-\\u01C5]|[\\u01C8-\\u01C8]|[\\u01CB-\\u01CB]|[\\u01F2-\\u01F2]|[\\u02B0-\\u02B8]|[\\u02BB-\\u02C1]|[\\u02D0-\\u02D1]|[\\u02E0-\\u02E4]|[\\u037A-\\u037A]|[\\u0559-\\u0559]|[\\u0640-\\u0640]|[\\u06E5-\\u06E6]|[\\u0E46-\\u0E46]|[\\u0EC6-\\u0EC6]|[\\u3005-\\u3005]|[\\u3031-\\u3035]|[\\u309D-\\u309E]|[\\u30FC-\\u30FE]|[\\uFF70-\\uFF70]|[\\uFF9E-\\uFF9F]|[\\u01AA-\\u01AA]|[\\u01BB-\\u01BB]|[\\u01BE-\\u01C3]|[\\u03F3-\\u03F3]|[\\u04C0-\\u04C0]|[\\u05D0-\\u05EA]|[\\u05F0-\\u05F2]|[\\u0621-\\u063A]|[\\u0641-\\u064A]|[\\u0671-\\u06B7]|[\\u06BA-\\u06BE]|[\\u06C0-\\u06CE]|[\\u06D0-\\u06D3]|[\\u06D5-\\u06D5]|[\\u0905-\\u0939]|[\\u093D-\\u093D]|[\\u0950-\\u0950]|[\\u0958-\\u0961]|[\\u0985-\\u098C]|[\\u098F-\\u0990]|[\\u0993-\\u09A8]|[\\u09AA-\\u09B0]|[\\u09B2-\\u09B2]|[\\u09B6-\\u09B9]|[\\u09DC-\\u09DD]|[\\u09DF-\\u09E1]|[\\u09F0-\\u09F1]|[\\u0A05-\\u0A0A]|[\\u0A0F-\\u0A10]|[\\u0A13-\\u0A28]|[\\u0A2A-\\u0A30]|[\\u0A32-\\u0A33]|[\\u0A35-\\u0A36]|[\\u0A38-\\u0A39]|[\\u0A59-\\u0A5C]|[\\u0A5E-\\u0A5E]|[\\u0A72-\\u0A74]|[\\u0A85-\\u0A8B]|[\\u0A8D-\\u0A8D]|[\\u0A8F-\\u0A91]|[\\u0A93-\\u0AA8]|[\\u0AAA-\\u0AB0]|[\\u0AB2-\\u0AB3]|[\\u0AB5-\\u0AB9]|[\\u0ABD-\\u0ABD]|[\\u0AD0-\\u0AD0]|[\\u0AE0-\\u0AE0]|[\\u0B05-\\u0B0C]|[\\u0B0F-\\u0B10]|[\\u0B13-\\u0B28]|[\\u0B2A-\\u0B30]|[\\u0B32-\\u0B33]|[\\u0B36-\\u0B39]|[\\u0B3D-\\u0B3D]|[\\u0B5C-\\u0B5D]|[\\u0B5F-\\u0B61]|[\\u0B85-\\u0B8A]|[\\u0B8E-\\u0B90]|[\\u0B92-\\u0B95]|[\\u0B99-\\u0B9A]|[\\u0B9C-\\u0B9C]|[\\u0B9E-\\u0B9F]|[\\u0BA3-\\u0BA4]|[\\u0BA8-\\u0BAA]|[\\u0BAE-\\u0BB5]|[\\u0BB7-\\u0BB9]|[\\u0C05-\\u0C0C]|[\\u0C0E-\\u0C10]|[\\u0C12-\\u0C28]|[\\u0C2A-\\u0C33]|[\\u0C35-\\u0C39]|[\\u0C60-\\u0C61]|[\\u0C85-\\u0C8C]|[\\u0C8E-\\u0C90]|[\\u0C92-\\u0CA8]|[\\u0CAA-\\u0CB3]|[\\u0CB5-\\u0CB9]|[\\u0CDE-\\u0CDE]|[\\u0CE0-\\u0CE1]|[\\u0D05-\\u0D0C]|[\\u0D0E-\\u0D10]|[\\u0D12-\\u0D28]|[\\u0D2A-\\u0D39]|[\\u0D60-\\u0D61]|[\\u0E01-\\u0E30]|[\\u0E32-\\u0E33]|[\\u0E40-\\u0E45]|[\\u0E81-\\u0E82]|[\\u0E84-\\u0E84]|[\\u0E87-\\u0E88]|[\\u0E8A-\\u0E8A]|[\\u0E8D-\\u0E8D]|[\\u0E94-\\u0E97]|[\\u0E99-\\u0E9F]|[\\u0EA1-\\u0EA3]|[\\u0EA5-\\u0EA5]|[\\u0EA7-\\u0EA7]|[\\u0EAA-\\u0EAB]|[\\u0EAD-\\u0EB0]|[\\u0EB2-\\u0EB3]|[\\u0EBD-\\u0EBD]|[\\u0EC0-\\u0EC4]|[\\u0EDC-\\u0EDD]|[\\u0F00-\\u0F00]|[\\u0F40-\\u0F47]|[\\u0F49-\\u0F69]|[\\u0F88-\\u0F8B]|[\\u1100-\\u1159]|[\\u115F-\\u11A2]|[\\u11A8-\\u11F9]|[\\u2135-\\u2138]|[\\u3006-\\u3006]|[\\u3041-\\u3094]|[\\u30A1-\\u30FA]|[\\u3105-\\u312C]|[\\u3131-\\u318E]|[\\u4E00-\\u9FA5]|[\\uAC00-\\uD7A3]|[\\uF900-\\uFA2D]|[\\uFB1F-\\uFB28]|[\\uFB2A-\\uFB36]|[\\uFB38-\\uFB3C]|[\\uFB3E-\\uFB3E]|[\\uFB40-\\uFB41]|[\\uFB43-\\uFB44]|[\\uFB46-\\uFBB1]|[\\uFBD3-\\uFD3D]|[\\uFD50-\\uFD8F]|[\\uFD92-\\uFDC7]|[\\uFDF0-\\uFDFB]|[\\uFE70-\\uFE72]|[\\uFE74-\\uFE74]|[\\uFE76-\\uFEFC]|[\\uFF66-\\uFF6F]|[\\uFF71-\\uFF9D]|[\\uFFA0-\\uFFBE]|[\\uFFC2-\\uFFC7]|[\\uFFCA-\\uFFCF]|[\\uFFD2-\\uFFD7]|[\\uFFDA-\\uFFDC]/,\n\n/* L = union of the below Unicode categories */\n  Lu   : /[\\u0041-\\u005A]|[\\u00C0-\\u00D6]|[\\u00D8-\\u00DE]|[\\u0100-\\u0100]|[\\u0102-\\u0102]|[\\u0104-\\u0104]|[\\u0106-\\u0106]|[\\u0108-\\u0108]|[\\u010A-\\u010A]|[\\u010C-\\u010C]|[\\u010E-\\u010E]|[\\u0110-\\u0110]|[\\u0112-\\u0112]|[\\u0114-\\u0114]|[\\u0116-\\u0116]|[\\u0118-\\u0118]|[\\u011A-\\u011A]|[\\u011C-\\u011C]|[\\u011E-\\u011E]|[\\u0120-\\u0120]|[\\u0122-\\u0122]|[\\u0124-\\u0124]|[\\u0126-\\u0126]|[\\u0128-\\u0128]|[\\u012A-\\u012A]|[\\u012C-\\u012C]|[\\u012E-\\u012E]|[\\u0130-\\u0130]|[\\u0132-\\u0132]|[\\u0134-\\u0134]|[\\u0136-\\u0136]|[\\u0139-\\u0139]|[\\u013B-\\u013B]|[\\u013D-\\u013D]|[\\u013F-\\u013F]|[\\u0141-\\u0141]|[\\u0143-\\u0143]|[\\u0145-\\u0145]|[\\u0147-\\u0147]|[\\u014A-\\u014A]|[\\u014C-\\u014C]|[\\u014E-\\u014E]|[\\u0150-\\u0150]|[\\u0152-\\u0152]|[\\u0154-\\u0154]|[\\u0156-\\u0156]|[\\u0158-\\u0158]|[\\u015A-\\u015A]|[\\u015C-\\u015C]|[\\u015E-\\u015E]|[\\u0160-\\u0160]|[\\u0162-\\u0162]|[\\u0164-\\u0164]|[\\u0166-\\u0166]|[\\u0168-\\u0168]|[\\u016A-\\u016A]|[\\u016C-\\u016C]|[\\u016E-\\u016E]|[\\u0170-\\u0170]|[\\u0172-\\u0172]|[\\u0174-\\u0174]|[\\u0176-\\u0176]|[\\u0178-\\u0179]|[\\u017B-\\u017B]|[\\u017D-\\u017D]|[\\u0181-\\u0182]|[\\u0184-\\u0184]|[\\u0186-\\u0187]|[\\u0189-\\u018B]|[\\u018E-\\u0191]|[\\u0193-\\u0194]|[\\u0196-\\u0198]|[\\u019C-\\u019D]|[\\u019F-\\u01A0]|[\\u01A2-\\u01A2]|[\\u01A4-\\u01A4]|[\\u01A6-\\u01A7]|[\\u01A9-\\u01A9]|[\\u01AC-\\u01AC]|[\\u01AE-\\u01AF]|[\\u01B1-\\u01B3]|[\\u01B5-\\u01B5]|[\\u01B7-\\u01B8]|[\\u01BC-\\u01BC]|[\\u01C4-\\u01C4]|[\\u01C7-\\u01C7]|[\\u01CA-\\u01CA]|[\\u01CD-\\u01CD]|[\\u01CF-\\u01CF]|[\\u01D1-\\u01D1]|[\\u01D3-\\u01D3]|[\\u01D5-\\u01D5]|[\\u01D7-\\u01D7]|[\\u01D9-\\u01D9]|[\\u01DB-\\u01DB]|[\\u01DE-\\u01DE]|[\\u01E0-\\u01E0]|[\\u01E2-\\u01E2]|[\\u01E4-\\u01E4]|[\\u01E6-\\u01E6]|[\\u01E8-\\u01E8]|[\\u01EA-\\u01EA]|[\\u01EC-\\u01EC]|[\\u01EE-\\u01EE]|[\\u01F1-\\u01F1]|[\\u01F4-\\u01F4]|[\\u01FA-\\u01FA]|[\\u01FC-\\u01FC]|[\\u01FE-\\u01FE]|[\\u0200-\\u0200]|[\\u0202-\\u0202]|[\\u0204-\\u0204]|[\\u0206-\\u0206]|[\\u0208-\\u0208]|[\\u020A-\\u020A]|[\\u020C-\\u020C]|[\\u020E-\\u020E]|[\\u0210-\\u0210]|[\\u0212-\\u0212]|[\\u0214-\\u0214]|[\\u0216-\\u0216]|[\\u0386-\\u0386]|[\\u0388-\\u038A]|[\\u038C-\\u038C]|[\\u038E-\\u038F]|[\\u0391-\\u03A1]|[\\u03A3-\\u03AB]|[\\u03D2-\\u03D4]|[\\u03DA-\\u03DA]|[\\u03DC-\\u03DC]|[\\u03DE-\\u03DE]|[\\u03E0-\\u03E0]|[\\u03E2-\\u03E2]|[\\u03E4-\\u03E4]|[\\u03E6-\\u03E6]|[\\u03E8-\\u03E8]|[\\u03EA-\\u03EA]|[\\u03EC-\\u03EC]|[\\u03EE-\\u03EE]|[\\u0401-\\u040C]|[\\u040E-\\u042F]|[\\u0460-\\u0460]|[\\u0462-\\u0462]|[\\u0464-\\u0464]|[\\u0466-\\u0466]|[\\u0468-\\u0468]|[\\u046A-\\u046A]|[\\u046C-\\u046C]|[\\u046E-\\u046E]|[\\u0470-\\u0470]|[\\u0472-\\u0472]|[\\u0474-\\u0474]|[\\u0476-\\u0476]|[\\u0478-\\u0478]|[\\u047A-\\u047A]|[\\u047C-\\u047C]|[\\u047E-\\u047E]|[\\u0480-\\u0480]|[\\u0490-\\u0490]|[\\u0492-\\u0492]|[\\u0494-\\u0494]|[\\u0496-\\u0496]|[\\u0498-\\u0498]|[\\u049A-\\u049A]|[\\u049C-\\u049C]|[\\u049E-\\u049E]|[\\u04A0-\\u04A0]|[\\u04A2-\\u04A2]|[\\u04A4-\\u04A4]|[\\u04A6-\\u04A6]|[\\u04A8-\\u04A8]|[\\u04AA-\\u04AA]|[\\u04AC-\\u04AC]|[\\u04AE-\\u04AE]|[\\u04B0-\\u04B0]|[\\u04B2-\\u04B2]|[\\u04B4-\\u04B4]|[\\u04B6-\\u04B6]|[\\u04B8-\\u04B8]|[\\u04BA-\\u04BA]|[\\u04BC-\\u04BC]|[\\u04BE-\\u04BE]|[\\u04C1-\\u04C1]|[\\u04C3-\\u04C3]|[\\u04C7-\\u04C7]|[\\u04CB-\\u04CB]|[\\u04D0-\\u04D0]|[\\u04D2-\\u04D2]|[\\u04D4-\\u04D4]|[\\u04D6-\\u04D6]|[\\u04D8-\\u04D8]|[\\u04DA-\\u04DA]|[\\u04DC-\\u04DC]|[\\u04DE-\\u04DE]|[\\u04E0-\\u04E0]|[\\u04E2-\\u04E2]|[\\u04E4-\\u04E4]|[\\u04E6-\\u04E6]|[\\u04E8-\\u04E8]|[\\u04EA-\\u04EA]|[\\u04EE-\\u04EE]|[\\u04F0-\\u04F0]|[\\u04F2-\\u04F2]|[\\u04F4-\\u04F4]|[\\u04F8-\\u04F8]|[\\u0531-\\u0556]|[\\u10A0-\\u10C5]|[\\u1E00-\\u1E00]|[\\u1E02-\\u1E02]|[\\u1E04-\\u1E04]|[\\u1E06-\\u1E06]|[\\u1E08-\\u1E08]|[\\u1E0A-\\u1E0A]|[\\u1E0C-\\u1E0C]|[\\u1E0E-\\u1E0E]|[\\u1E10-\\u1E10]|[\\u1E12-\\u1E12]|[\\u1E14-\\u1E14]|[\\u1E16-\\u1E16]|[\\u1E18-\\u1E18]|[\\u1E1A-\\u1E1A]|[\\u1E1C-\\u1E1C]|[\\u1E1E-\\u1E1E]|[\\u1E20-\\u1E20]|[\\u1E22-\\u1E22]|[\\u1E24-\\u1E24]|[\\u1E26-\\u1E26]|[\\u1E28-\\u1E28]|[\\u1E2A-\\u1E2A]|[\\u1E2C-\\u1E2C]|[\\u1E2E-\\u1E2E]|[\\u1E30-\\u1E30]|[\\u1E32-\\u1E32]|[\\u1E34-\\u1E34]|[\\u1E36-\\u1E36]|[\\u1E38-\\u1E38]|[\\u1E3A-\\u1E3A]|[\\u1E3C-\\u1E3C]|[\\u1E3E-\\u1E3E]|[\\u1E40-\\u1E40]|[\\u1E42-\\u1E42]|[\\u1E44-\\u1E44]|[\\u1E46-\\u1E46]|[\\u1E48-\\u1E48]|[\\u1E4A-\\u1E4A]|[\\u1E4C-\\u1E4C]|[\\u1E4E-\\u1E4E]|[\\u1E50-\\u1E50]|[\\u1E52-\\u1E52]|[\\u1E54-\\u1E54]|[\\u1E56-\\u1E56]|[\\u1E58-\\u1E58]|[\\u1E5A-\\u1E5A]|[\\u1E5C-\\u1E5C]|[\\u1E5E-\\u1E5E]|[\\u1E60-\\u1E60]|[\\u1E62-\\u1E62]|[\\u1E64-\\u1E64]|[\\u1E66-\\u1E66]|[\\u1E68-\\u1E68]|[\\u1E6A-\\u1E6A]|[\\u1E6C-\\u1E6C]|[\\u1E6E-\\u1E6E]|[\\u1E70-\\u1E70]|[\\u1E72-\\u1E72]|[\\u1E74-\\u1E74]|[\\u1E76-\\u1E76]|[\\u1E78-\\u1E78]|[\\u1E7A-\\u1E7A]|[\\u1E7C-\\u1E7C]|[\\u1E7E-\\u1E7E]|[\\u1E80-\\u1E80]|[\\u1E82-\\u1E82]|[\\u1E84-\\u1E84]|[\\u1E86-\\u1E86]|[\\u1E88-\\u1E88]|[\\u1E8A-\\u1E8A]|[\\u1E8C-\\u1E8C]|[\\u1E8E-\\u1E8E]|[\\u1E90-\\u1E90]|[\\u1E92-\\u1E92]|[\\u1E94-\\u1E94]|[\\u1EA0-\\u1EA0]|[\\u1EA2-\\u1EA2]|[\\u1EA4-\\u1EA4]|[\\u1EA6-\\u1EA6]|[\\u1EA8-\\u1EA8]|[\\u1EAA-\\u1EAA]|[\\u1EAC-\\u1EAC]|[\\u1EAE-\\u1EAE]|[\\u1EB0-\\u1EB0]|[\\u1EB2-\\u1EB2]|[\\u1EB4-\\u1EB4]|[\\u1EB6-\\u1EB6]|[\\u1EB8-\\u1EB8]|[\\u1EBA-\\u1EBA]|[\\u1EBC-\\u1EBC]|[\\u1EBE-\\u1EBE]|[\\u1EC0-\\u1EC0]|[\\u1EC2-\\u1EC2]|[\\u1EC4-\\u1EC4]|[\\u1EC6-\\u1EC6]|[\\u1EC8-\\u1EC8]|[\\u1ECA-\\u1ECA]|[\\u1ECC-\\u1ECC]|[\\u1ECE-\\u1ECE]|[\\u1ED0-\\u1ED0]|[\\u1ED2-\\u1ED2]|[\\u1ED4-\\u1ED4]|[\\u1ED6-\\u1ED6]|[\\u1ED8-\\u1ED8]|[\\u1EDA-\\u1EDA]|[\\u1EDC-\\u1EDC]|[\\u1EDE-\\u1EDE]|[\\u1EE0-\\u1EE0]|[\\u1EE2-\\u1EE2]|[\\u1EE4-\\u1EE4]|[\\u1EE6-\\u1EE6]|[\\u1EE8-\\u1EE8]|[\\u1EEA-\\u1EEA]|[\\u1EEC-\\u1EEC]|[\\u1EEE-\\u1EEE]|[\\u1EF0-\\u1EF0]|[\\u1EF2-\\u1EF2]|[\\u1EF4-\\u1EF4]|[\\u1EF6-\\u1EF6]|[\\u1EF8-\\u1EF8]|[\\u1F08-\\u1F0F]|[\\u1F18-\\u1F1D]|[\\u1F28-\\u1F2F]|[\\u1F38-\\u1F3F]|[\\u1F48-\\u1F4D]|[\\u1F59-\\u1F59]|[\\u1F5B-\\u1F5B]|[\\u1F5D-\\u1F5D]|[\\u1F5F-\\u1F5F]|[\\u1F68-\\u1F6F]|[\\u1F88-\\u1F8F]|[\\u1F98-\\u1F9F]|[\\u1FA8-\\u1FAF]|[\\u1FB8-\\u1FBC]|[\\u1FC8-\\u1FCC]|[\\u1FD8-\\u1FDB]|[\\u1FE8-\\u1FEC]|[\\u1FF8-\\u1FFC]|[\\u2102-\\u2102]|[\\u2107-\\u2107]|[\\u210B-\\u210D]|[\\u2110-\\u2112]|[\\u2115-\\u2115]|[\\u2119-\\u211D]|[\\u2124-\\u2124]|[\\u2126-\\u2126]|[\\u2128-\\u2128]|[\\u212A-\\u212D]|[\\u2130-\\u2131]|[\\u2133-\\u2133]|[\\uFF21-\\uFF3A]/,\n  Ll   : /[\\u0061-\\u007A]|[\\u00AA-\\u00AA]|[\\u00B5-\\u00B5]|[\\u00BA-\\u00BA]|[\\u00DF-\\u00F6]|[\\u00F8-\\u00FF]|[\\u0101-\\u0101]|[\\u0103-\\u0103]|[\\u0105-\\u0105]|[\\u0107-\\u0107]|[\\u0109-\\u0109]|[\\u010B-\\u010B]|[\\u010D-\\u010D]|[\\u010F-\\u010F]|[\\u0111-\\u0111]|[\\u0113-\\u0113]|[\\u0115-\\u0115]|[\\u0117-\\u0117]|[\\u0119-\\u0119]|[\\u011B-\\u011B]|[\\u011D-\\u011D]|[\\u011F-\\u011F]|[\\u0121-\\u0121]|[\\u0123-\\u0123]|[\\u0125-\\u0125]|[\\u0127-\\u0127]|[\\u0129-\\u0129]|[\\u012B-\\u012B]|[\\u012D-\\u012D]|[\\u012F-\\u012F]|[\\u0131-\\u0131]|[\\u0133-\\u0133]|[\\u0135-\\u0135]|[\\u0137-\\u0138]|[\\u013A-\\u013A]|[\\u013C-\\u013C]|[\\u013E-\\u013E]|[\\u0140-\\u0140]|[\\u0142-\\u0142]|[\\u0144-\\u0144]|[\\u0146-\\u0146]|[\\u0148-\\u0149]|[\\u014B-\\u014B]|[\\u014D-\\u014D]|[\\u014F-\\u014F]|[\\u0151-\\u0151]|[\\u0153-\\u0153]|[\\u0155-\\u0155]|[\\u0157-\\u0157]|[\\u0159-\\u0159]|[\\u015B-\\u015B]|[\\u015D-\\u015D]|[\\u015F-\\u015F]|[\\u0161-\\u0161]|[\\u0163-\\u0163]|[\\u0165-\\u0165]|[\\u0167-\\u0167]|[\\u0169-\\u0169]|[\\u016B-\\u016B]|[\\u016D-\\u016D]|[\\u016F-\\u016F]|[\\u0171-\\u0171]|[\\u0173-\\u0173]|[\\u0175-\\u0175]|[\\u0177-\\u0177]|[\\u017A-\\u017A]|[\\u017C-\\u017C]|[\\u017E-\\u0180]|[\\u0183-\\u0183]|[\\u0185-\\u0185]|[\\u0188-\\u0188]|[\\u018C-\\u018D]|[\\u0192-\\u0192]|[\\u0195-\\u0195]|[\\u0199-\\u019B]|[\\u019E-\\u019E]|[\\u01A1-\\u01A1]|[\\u01A3-\\u01A3]|[\\u01A5-\\u01A5]|[\\u01A8-\\u01A8]|[\\u01AB-\\u01AB]|[\\u01AD-\\u01AD]|[\\u01B0-\\u01B0]|[\\u01B4-\\u01B4]|[\\u01B6-\\u01B6]|[\\u01B9-\\u01BA]|[\\u01BD-\\u01BD]|[\\u01C6-\\u01C6]|[\\u01C9-\\u01C9]|[\\u01CC-\\u01CC]|[\\u01CE-\\u01CE]|[\\u01D0-\\u01D0]|[\\u01D2-\\u01D2]|[\\u01D4-\\u01D4]|[\\u01D6-\\u01D6]|[\\u01D8-\\u01D8]|[\\u01DA-\\u01DA]|[\\u01DC-\\u01DD]|[\\u01DF-\\u01DF]|[\\u01E1-\\u01E1]|[\\u01E3-\\u01E3]|[\\u01E5-\\u01E5]|[\\u01E7-\\u01E7]|[\\u01E9-\\u01E9]|[\\u01EB-\\u01EB]|[\\u01ED-\\u01ED]|[\\u01EF-\\u01F0]|[\\u01F3-\\u01F3]|[\\u01F5-\\u01F5]|[\\u01FB-\\u01FB]|[\\u01FD-\\u01FD]|[\\u01FF-\\u01FF]|[\\u0201-\\u0201]|[\\u0203-\\u0203]|[\\u0205-\\u0205]|[\\u0207-\\u0207]|[\\u0209-\\u0209]|[\\u020B-\\u020B]|[\\u020D-\\u020D]|[\\u020F-\\u020F]|[\\u0211-\\u0211]|[\\u0213-\\u0213]|[\\u0215-\\u0215]|[\\u0217-\\u0217]|[\\u0250-\\u02A8]|[\\u0390-\\u0390]|[\\u03AC-\\u03CE]|[\\u03D0-\\u03D1]|[\\u03D5-\\u03D6]|[\\u03E3-\\u03E3]|[\\u03E5-\\u03E5]|[\\u03E7-\\u03E7]|[\\u03E9-\\u03E9]|[\\u03EB-\\u03EB]|[\\u03ED-\\u03ED]|[\\u03EF-\\u03F2]|[\\u0430-\\u044F]|[\\u0451-\\u045C]|[\\u045E-\\u045F]|[\\u0461-\\u0461]|[\\u0463-\\u0463]|[\\u0465-\\u0465]|[\\u0467-\\u0467]|[\\u0469-\\u0469]|[\\u046B-\\u046B]|[\\u046D-\\u046D]|[\\u046F-\\u046F]|[\\u0471-\\u0471]|[\\u0473-\\u0473]|[\\u0475-\\u0475]|[\\u0477-\\u0477]|[\\u0479-\\u0479]|[\\u047B-\\u047B]|[\\u047D-\\u047D]|[\\u047F-\\u047F]|[\\u0481-\\u0481]|[\\u0491-\\u0491]|[\\u0493-\\u0493]|[\\u0495-\\u0495]|[\\u0497-\\u0497]|[\\u0499-\\u0499]|[\\u049B-\\u049B]|[\\u049D-\\u049D]|[\\u049F-\\u049F]|[\\u04A1-\\u04A1]|[\\u04A3-\\u04A3]|[\\u04A5-\\u04A5]|[\\u04A7-\\u04A7]|[\\u04A9-\\u04A9]|[\\u04AB-\\u04AB]|[\\u04AD-\\u04AD]|[\\u04AF-\\u04AF]|[\\u04B1-\\u04B1]|[\\u04B3-\\u04B3]|[\\u04B5-\\u04B5]|[\\u04B7-\\u04B7]|[\\u04B9-\\u04B9]|[\\u04BB-\\u04BB]|[\\u04BD-\\u04BD]|[\\u04BF-\\u04BF]|[\\u04C2-\\u04C2]|[\\u04C4-\\u04C4]|[\\u04C8-\\u04C8]|[\\u04CC-\\u04CC]|[\\u04D1-\\u04D1]|[\\u04D3-\\u04D3]|[\\u04D5-\\u04D5]|[\\u04D7-\\u04D7]|[\\u04D9-\\u04D9]|[\\u04DB-\\u04DB]|[\\u04DD-\\u04DD]|[\\u04DF-\\u04DF]|[\\u04E1-\\u04E1]|[\\u04E3-\\u04E3]|[\\u04E5-\\u04E5]|[\\u04E7-\\u04E7]|[\\u04E9-\\u04E9]|[\\u04EB-\\u04EB]|[\\u04EF-\\u04EF]|[\\u04F1-\\u04F1]|[\\u04F3-\\u04F3]|[\\u04F5-\\u04F5]|[\\u04F9-\\u04F9]|[\\u0561-\\u0587]|[\\u10D0-\\u10F6]|[\\u1E01-\\u1E01]|[\\u1E03-\\u1E03]|[\\u1E05-\\u1E05]|[\\u1E07-\\u1E07]|[\\u1E09-\\u1E09]|[\\u1E0B-\\u1E0B]|[\\u1E0D-\\u1E0D]|[\\u1E0F-\\u1E0F]|[\\u1E11-\\u1E11]|[\\u1E13-\\u1E13]|[\\u1E15-\\u1E15]|[\\u1E17-\\u1E17]|[\\u1E19-\\u1E19]|[\\u1E1B-\\u1E1B]|[\\u1E1D-\\u1E1D]|[\\u1E1F-\\u1E1F]|[\\u1E21-\\u1E21]|[\\u1E23-\\u1E23]|[\\u1E25-\\u1E25]|[\\u1E27-\\u1E27]|[\\u1E29-\\u1E29]|[\\u1E2B-\\u1E2B]|[\\u1E2D-\\u1E2D]|[\\u1E2F-\\u1E2F]|[\\u1E31-\\u1E31]|[\\u1E33-\\u1E33]|[\\u1E35-\\u1E35]|[\\u1E37-\\u1E37]|[\\u1E39-\\u1E39]|[\\u1E3B-\\u1E3B]|[\\u1E3D-\\u1E3D]|[\\u1E3F-\\u1E3F]|[\\u1E41-\\u1E41]|[\\u1E43-\\u1E43]|[\\u1E45-\\u1E45]|[\\u1E47-\\u1E47]|[\\u1E49-\\u1E49]|[\\u1E4B-\\u1E4B]|[\\u1E4D-\\u1E4D]|[\\u1E4F-\\u1E4F]|[\\u1E51-\\u1E51]|[\\u1E53-\\u1E53]|[\\u1E55-\\u1E55]|[\\u1E57-\\u1E57]|[\\u1E59-\\u1E59]|[\\u1E5B-\\u1E5B]|[\\u1E5D-\\u1E5D]|[\\u1E5F-\\u1E5F]|[\\u1E61-\\u1E61]|[\\u1E63-\\u1E63]|[\\u1E65-\\u1E65]|[\\u1E67-\\u1E67]|[\\u1E69-\\u1E69]|[\\u1E6B-\\u1E6B]|[\\u1E6D-\\u1E6D]|[\\u1E6F-\\u1E6F]|[\\u1E71-\\u1E71]|[\\u1E73-\\u1E73]|[\\u1E75-\\u1E75]|[\\u1E77-\\u1E77]|[\\u1E79-\\u1E79]|[\\u1E7B-\\u1E7B]|[\\u1E7D-\\u1E7D]|[\\u1E7F-\\u1E7F]|[\\u1E81-\\u1E81]|[\\u1E83-\\u1E83]|[\\u1E85-\\u1E85]|[\\u1E87-\\u1E87]|[\\u1E89-\\u1E89]|[\\u1E8B-\\u1E8B]|[\\u1E8D-\\u1E8D]|[\\u1E8F-\\u1E8F]|[\\u1E91-\\u1E91]|[\\u1E93-\\u1E93]|[\\u1E95-\\u1E9B]|[\\u1EA1-\\u1EA1]|[\\u1EA3-\\u1EA3]|[\\u1EA5-\\u1EA5]|[\\u1EA7-\\u1EA7]|[\\u1EA9-\\u1EA9]|[\\u1EAB-\\u1EAB]|[\\u1EAD-\\u1EAD]|[\\u1EAF-\\u1EAF]|[\\u1EB1-\\u1EB1]|[\\u1EB3-\\u1EB3]|[\\u1EB5-\\u1EB5]|[\\u1EB7-\\u1EB7]|[\\u1EB9-\\u1EB9]|[\\u1EBB-\\u1EBB]|[\\u1EBD-\\u1EBD]|[\\u1EBF-\\u1EBF]|[\\u1EC1-\\u1EC1]|[\\u1EC3-\\u1EC3]|[\\u1EC5-\\u1EC5]|[\\u1EC7-\\u1EC7]|[\\u1EC9-\\u1EC9]|[\\u1ECB-\\u1ECB]|[\\u1ECD-\\u1ECD]|[\\u1ECF-\\u1ECF]|[\\u1ED1-\\u1ED1]|[\\u1ED3-\\u1ED3]|[\\u1ED5-\\u1ED5]|[\\u1ED7-\\u1ED7]|[\\u1ED9-\\u1ED9]|[\\u1EDB-\\u1EDB]|[\\u1EDD-\\u1EDD]|[\\u1EDF-\\u1EDF]|[\\u1EE1-\\u1EE1]|[\\u1EE3-\\u1EE3]|[\\u1EE5-\\u1EE5]|[\\u1EE7-\\u1EE7]|[\\u1EE9-\\u1EE9]|[\\u1EEB-\\u1EEB]|[\\u1EED-\\u1EED]|[\\u1EEF-\\u1EEF]|[\\u1EF1-\\u1EF1]|[\\u1EF3-\\u1EF3]|[\\u1EF5-\\u1EF5]|[\\u1EF7-\\u1EF7]|[\\u1EF9-\\u1EF9]|[\\u1F00-\\u1F07]|[\\u1F10-\\u1F15]|[\\u1F20-\\u1F27]|[\\u1F30-\\u1F37]|[\\u1F40-\\u1F45]|[\\u1F50-\\u1F57]|[\\u1F60-\\u1F67]|[\\u1F70-\\u1F7D]|[\\u1F80-\\u1F87]|[\\u1F90-\\u1F97]|[\\u1FA0-\\u1FA7]|[\\u1FB0-\\u1FB4]|[\\u1FB6-\\u1FB7]|[\\u1FBE-\\u1FBE]|[\\u1FC2-\\u1FC4]|[\\u1FC6-\\u1FC7]|[\\u1FD0-\\u1FD3]|[\\u1FD6-\\u1FD7]|[\\u1FE0-\\u1FE7]|[\\u1FF2-\\u1FF4]|[\\u1FF6-\\u1FF7]|[\\u207F-\\u207F]|[\\u210A-\\u210A]|[\\u210E-\\u210F]|[\\u2113-\\u2113]|[\\u2118-\\u2118]|[\\u212E-\\u212F]|[\\u2134-\\u2134]|[\\uFB00-\\uFB06]|[\\uFB13-\\uFB17]|[\\uFF41-\\uFF5A]/,\n  Lt   : /[\\u01C5-\\u01C5]|[\\u01C8-\\u01C8]|[\\u01CB-\\u01CB]|[\\u01F2-\\u01F2]/,\n  Lm   : /[\\u02B0-\\u02B8]|[\\u02BB-\\u02C1]|[\\u02D0-\\u02D1]|[\\u02E0-\\u02E4]|[\\u037A-\\u037A]|[\\u0559-\\u0559]|[\\u0640-\\u0640]|[\\u06E5-\\u06E6]|[\\u0E46-\\u0E46]|[\\u0EC6-\\u0EC6]|[\\u3005-\\u3005]|[\\u3031-\\u3035]|[\\u309D-\\u309E]|[\\u30FC-\\u30FE]|[\\uFF70-\\uFF70]|[\\uFF9E-\\uFF9F]/,\n  Lo   : /[\\u01AA-\\u01AA]|[\\u01BB-\\u01BB]|[\\u01BE-\\u01C3]|[\\u03F3-\\u03F3]|[\\u04C0-\\u04C0]|[\\u05D0-\\u05EA]|[\\u05F0-\\u05F2]|[\\u0621-\\u063A]|[\\u0641-\\u064A]|[\\u0671-\\u06B7]|[\\u06BA-\\u06BE]|[\\u06C0-\\u06CE]|[\\u06D0-\\u06D3]|[\\u06D5-\\u06D5]|[\\u0905-\\u0939]|[\\u093D-\\u093D]|[\\u0950-\\u0950]|[\\u0958-\\u0961]|[\\u0985-\\u098C]|[\\u098F-\\u0990]|[\\u0993-\\u09A8]|[\\u09AA-\\u09B0]|[\\u09B2-\\u09B2]|[\\u09B6-\\u09B9]|[\\u09DC-\\u09DD]|[\\u09DF-\\u09E1]|[\\u09F0-\\u09F1]|[\\u0A05-\\u0A0A]|[\\u0A0F-\\u0A10]|[\\u0A13-\\u0A28]|[\\u0A2A-\\u0A30]|[\\u0A32-\\u0A33]|[\\u0A35-\\u0A36]|[\\u0A38-\\u0A39]|[\\u0A59-\\u0A5C]|[\\u0A5E-\\u0A5E]|[\\u0A72-\\u0A74]|[\\u0A85-\\u0A8B]|[\\u0A8D-\\u0A8D]|[\\u0A8F-\\u0A91]|[\\u0A93-\\u0AA8]|[\\u0AAA-\\u0AB0]|[\\u0AB2-\\u0AB3]|[\\u0AB5-\\u0AB9]|[\\u0ABD-\\u0ABD]|[\\u0AD0-\\u0AD0]|[\\u0AE0-\\u0AE0]|[\\u0B05-\\u0B0C]|[\\u0B0F-\\u0B10]|[\\u0B13-\\u0B28]|[\\u0B2A-\\u0B30]|[\\u0B32-\\u0B33]|[\\u0B36-\\u0B39]|[\\u0B3D-\\u0B3D]|[\\u0B5C-\\u0B5D]|[\\u0B5F-\\u0B61]|[\\u0B85-\\u0B8A]|[\\u0B8E-\\u0B90]|[\\u0B92-\\u0B95]|[\\u0B99-\\u0B9A]|[\\u0B9C-\\u0B9C]|[\\u0B9E-\\u0B9F]|[\\u0BA3-\\u0BA4]|[\\u0BA8-\\u0BAA]|[\\u0BAE-\\u0BB5]|[\\u0BB7-\\u0BB9]|[\\u0C05-\\u0C0C]|[\\u0C0E-\\u0C10]|[\\u0C12-\\u0C28]|[\\u0C2A-\\u0C33]|[\\u0C35-\\u0C39]|[\\u0C60-\\u0C61]|[\\u0C85-\\u0C8C]|[\\u0C8E-\\u0C90]|[\\u0C92-\\u0CA8]|[\\u0CAA-\\u0CB3]|[\\u0CB5-\\u0CB9]|[\\u0CDE-\\u0CDE]|[\\u0CE0-\\u0CE1]|[\\u0D05-\\u0D0C]|[\\u0D0E-\\u0D10]|[\\u0D12-\\u0D28]|[\\u0D2A-\\u0D39]|[\\u0D60-\\u0D61]|[\\u0E01-\\u0E30]|[\\u0E32-\\u0E33]|[\\u0E40-\\u0E45]|[\\u0E81-\\u0E82]|[\\u0E84-\\u0E84]|[\\u0E87-\\u0E88]|[\\u0E8A-\\u0E8A]|[\\u0E8D-\\u0E8D]|[\\u0E94-\\u0E97]|[\\u0E99-\\u0E9F]|[\\u0EA1-\\u0EA3]|[\\u0EA5-\\u0EA5]|[\\u0EA7-\\u0EA7]|[\\u0EAA-\\u0EAB]|[\\u0EAD-\\u0EB0]|[\\u0EB2-\\u0EB3]|[\\u0EBD-\\u0EBD]|[\\u0EC0-\\u0EC4]|[\\u0EDC-\\u0EDD]|[\\u0F00-\\u0F00]|[\\u0F40-\\u0F47]|[\\u0F49-\\u0F69]|[\\u0F88-\\u0F8B]|[\\u1100-\\u1159]|[\\u115F-\\u11A2]|[\\u11A8-\\u11F9]|[\\u2135-\\u2138]|[\\u3006-\\u3006]|[\\u3041-\\u3094]|[\\u30A1-\\u30FA]|[\\u3105-\\u312C]|[\\u3131-\\u318E]|[\\u4E00-\\u9FA5]|[\\uAC00-\\uD7A3]|[\\uF900-\\uFA2D]|[\\uFB1F-\\uFB28]|[\\uFB2A-\\uFB36]|[\\uFB38-\\uFB3C]|[\\uFB3E-\\uFB3E]|[\\uFB40-\\uFB41]|[\\uFB43-\\uFB44]|[\\uFB46-\\uFBB1]|[\\uFBD3-\\uFD3D]|[\\uFD50-\\uFD8F]|[\\uFD92-\\uFDC7]|[\\uFDF0-\\uFDFB]|[\\uFE70-\\uFE72]|[\\uFE74-\\uFE74]|[\\uFE76-\\uFEFC]|[\\uFF66-\\uFF6F]|[\\uFF71-\\uFF9D]|[\\uFFA0-\\uFFBE]|[\\uFFC2-\\uFFC7]|[\\uFFCA-\\uFFCF]|[\\uFFD2-\\uFFD7]|[\\uFFDA-\\uFFDC]/,\n/* --- */\n\n  Nl   : /[\\u2160-\\u2182]|[\\u3007-\\u3007]|[\\u3021-\\u3029]/,\n  Mn   : /[\\u0300-\\u0345]|[\\u0360-\\u0361]|[\\u0483-\\u0486]|[\\u0591-\\u05A1]|[\\u05A3-\\u05B9]|[\\u05BB-\\u05BD]|[\\u05BF-\\u05BF]|[\\u05C1-\\u05C2]|[\\u05C4-\\u05C4]|[\\u064B-\\u0652]|[\\u0670-\\u0670]|[\\u06D6-\\u06DC]|[\\u06DF-\\u06E4]|[\\u06E7-\\u06E8]|[\\u06EA-\\u06ED]|[\\u0901-\\u0902]|[\\u093C-\\u093C]|[\\u0941-\\u0948]|[\\u094D-\\u094D]|[\\u0951-\\u0954]|[\\u0962-\\u0963]|[\\u0981-\\u0981]|[\\u09BC-\\u09BC]|[\\u09C1-\\u09C4]|[\\u09CD-\\u09CD]|[\\u09E2-\\u09E3]|[\\u0A02-\\u0A02]|[\\u0A3C-\\u0A3C]|[\\u0A41-\\u0A42]|[\\u0A47-\\u0A48]|[\\u0A4B-\\u0A4D]|[\\u0A70-\\u0A71]|[\\u0A81-\\u0A82]|[\\u0ABC-\\u0ABC]|[\\u0AC1-\\u0AC5]|[\\u0AC7-\\u0AC8]|[\\u0ACD-\\u0ACD]|[\\u0B01-\\u0B01]|[\\u0B3C-\\u0B3C]|[\\u0B3F-\\u0B3F]|[\\u0B41-\\u0B43]|[\\u0B4D-\\u0B4D]|[\\u0B56-\\u0B56]|[\\u0B82-\\u0B82]|[\\u0BC0-\\u0BC0]|[\\u0BCD-\\u0BCD]|[\\u0C3E-\\u0C40]|[\\u0C46-\\u0C48]|[\\u0C4A-\\u0C4D]|[\\u0C55-\\u0C56]|[\\u0CBF-\\u0CBF]|[\\u0CC6-\\u0CC6]|[\\u0CCC-\\u0CCD]|[\\u0D41-\\u0D43]|[\\u0D4D-\\u0D4D]|[\\u0E31-\\u0E31]|[\\u0E34-\\u0E3A]|[\\u0E47-\\u0E4E]|[\\u0EB1-\\u0EB1]|[\\u0EB4-\\u0EB9]|[\\u0EBB-\\u0EBC]|[\\u0EC8-\\u0ECD]|[\\u0F18-\\u0F19]|[\\u0F35-\\u0F35]|[\\u0F37-\\u0F37]|[\\u0F39-\\u0F39]|[\\u0F71-\\u0F7E]|[\\u0F80-\\u0F84]|[\\u0F86-\\u0F87]|[\\u0F90-\\u0F95]|[\\u0F97-\\u0F97]|[\\u0F99-\\u0FAD]|[\\u0FB1-\\u0FB7]|[\\u0FB9-\\u0FB9]|[\\u20D0-\\u20DC]|[\\u20E1-\\u20E1]|[\\u302A-\\u302F]|[\\u3099-\\u309A]|[\\uFB1E-\\uFB1E]|[\\uFE20-\\uFE23]/,\n  Mc   : /[\\u0903-\\u0903]|[\\u093E-\\u0940]|[\\u0949-\\u094C]|[\\u0982-\\u0983]|[\\u09BE-\\u09C0]|[\\u09C7-\\u09C8]|[\\u09CB-\\u09CC]|[\\u09D7-\\u09D7]|[\\u0A3E-\\u0A40]|[\\u0A83-\\u0A83]|[\\u0ABE-\\u0AC0]|[\\u0AC9-\\u0AC9]|[\\u0ACB-\\u0ACC]|[\\u0B02-\\u0B03]|[\\u0B3E-\\u0B3E]|[\\u0B40-\\u0B40]|[\\u0B47-\\u0B48]|[\\u0B4B-\\u0B4C]|[\\u0B57-\\u0B57]|[\\u0B83-\\u0B83]|[\\u0BBE-\\u0BBF]|[\\u0BC1-\\u0BC2]|[\\u0BC6-\\u0BC8]|[\\u0BCA-\\u0BCC]|[\\u0BD7-\\u0BD7]|[\\u0C01-\\u0C03]|[\\u0C41-\\u0C44]|[\\u0C82-\\u0C83]|[\\u0CBE-\\u0CBE]|[\\u0CC0-\\u0CC4]|[\\u0CC7-\\u0CC8]|[\\u0CCA-\\u0CCB]|[\\u0CD5-\\u0CD6]|[\\u0D02-\\u0D03]|[\\u0D3E-\\u0D40]|[\\u0D46-\\u0D48]|[\\u0D4A-\\u0D4C]|[\\u0D57-\\u0D57]|[\\u0F3E-\\u0F3F]|[\\u0F7F-\\u0F7F]/,\n  Nd   : /[\\u0030-\\u0039]|[\\u0660-\\u0669]|[\\u06F0-\\u06F9]|[\\u0966-\\u096F]|[\\u09E6-\\u09EF]|[\\u0A66-\\u0A6F]|[\\u0AE6-\\u0AEF]|[\\u0B66-\\u0B6F]|[\\u0BE7-\\u0BEF]|[\\u0C66-\\u0C6F]|[\\u0CE6-\\u0CEF]|[\\u0D66-\\u0D6F]|[\\u0E50-\\u0E59]|[\\u0ED0-\\u0ED9]|[\\u0F20-\\u0F29]|[\\uFF10-\\uFF19]/,\n  Pc   : /[\\u005F-\\u005F]|[\\u203F-\\u2040]|[\\u30FB-\\u30FB]|[\\uFE33-\\uFE34]|[\\uFE4D-\\uFE4F]|[\\uFF3F-\\uFF3F]|[\\uFF65-\\uFF65]/,\n  Zs   : /[\\u2000-\\u200B]|[\\u3000-\\u3000]/,\n};\n"]} (28) }); diff --git a/dist/ohm.min.js b/dist/ohm.min.js index 6e7b194c..901029e4 100644 --- a/dist/ohm.min.js +++ b/dist/ohm.min.js @@ -1,6 +1,6 @@ !function(e){if("object"==typeof exports)module.exports=e();else if("function"==typeof define&&define.amd)define(e);else{var f;"undefined"!=typeof window?f=window:"undefined"!=typeof global?f=global:"undefined"!=typeof self&&(f=self),f.ohm=e()}}(function(){var define,module,exports;return function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);throw new Error("Cannot find module '"+o+"'")}var f=n[o]={exports:{}};t[o][0].call(f.exports,function(e){var n=t[o][1][e];return s(n?n:e)},f,f.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o"))).define("Params",[],this.seq(this.prim("<"),this.app("ListOf",[this.app("Seq"),this.prim(",")]),this.prim(">"))).define("Alt",[],this.seq(this.app("Term"),this.star(this.seq(this.prim("|"),this.app("Term"))))).define("Term_inline",[],this.seq(this.app("Seq"),this.app("caseName"))).define("Term",[],this.alt(this.app("Term_inline"),this.app("Seq"))).define("Seq",[],this.star(this.app("Iter"))).define("Iter_star",[],this.seq(this.app("Pred"),this.prim("*"))).define("Iter_plus",[],this.seq(this.app("Pred"),this.prim("+"))).define("Iter_opt",[],this.seq(this.app("Pred"),this.prim("?"))).define("Iter",[],this.alt(this.app("Iter_star"),this.app("Iter_plus"),this.app("Iter_opt"),this.app("Pred"))).define("Pred_not",[],this.seq(this.prim("~"),this.app("Base"))).define("Pred_lookahead",[],this.seq(this.prim("&"),this.app("Base"))).define("Pred",[],this.alt(this.app("Pred_not"),this.app("Pred_lookahead"),this.app("Base"))).define("Base_application",[],this.seq(this.app("ident"),this.opt(this.app("Params")),this.not(this.alt(this.seq(this.opt(this.app("ruleDescr")),this.prim("=")),this.prim(":="),this.prim("+="))))).define("Base_prim",[],this.alt(this.app("keyword"),this.app("string"),this.app("regExp"),this.app("number"))).define("Base_paren",[],this.seq(this.prim("("),this.app("Alt"),this.prim(")"))).define("Base_arr",[],this.seq(this.prim("["),this.app("Alt"),this.prim("]"))).define("Base_str",[],this.seq(this.prim("``"),this.app("Alt"),this.prim("''"))).define("Base_obj",[],this.seq(this.prim("{"),this.opt(this.prim("...")),this.prim("}"))).define("Base_objWithProps",[],this.seq(this.prim("{"),this.app("Props"),this.opt(this.seq(this.prim(","),this.prim("..."))),this.prim("}"))).define("Base",[],this.alt(this.app("Base_application"),this.app("Base_prim"),this.app("Base_paren"),this.app("Base_arr"),this.app("Base_str"),this.app("Base_obj"),this.app("Base_objWithProps"))).define("Props",[],this.seq(this.app("Prop"),this.star(this.seq(this.prim(","),this.app("Prop"))))).define("Prop",[],this.seq(this.alt(this.app("name"),this.app("string")),this.prim(":"),this.app("Alt"))).define("ruleDescr",[],this.seq(this.prim("("),this.app("ruleDescrText"),this.prim(")")),"a rule description").define("ruleDescrText",[],this.star(this.seq(this.not(this.prim(")")),this.app("_")))).define("caseName",[],this.seq(this.prim("--"),this.star(this.seq(this.not(this.prim("\n")),this.app("space"))),this.app("name"),this.star(this.seq(this.not(this.prim("\n")),this.app("space"))),this.alt(this.prim("\n"),this.la(this.prim("}"))))).define("name",[],this.seq(this.app("nameFirst"),this.star(this.app("nameRest"))),"a name").define("nameFirst",[],this.alt(this.prim("_"),this.app("letter"))).define("nameRest",[],this.alt(this.prim("_"),this.app("alnum"))).define("ident",[],this.seq(this.not(this.app("keyword")),this.app("name")),"an identifier").define("keyword_null",[],this.seq(this.prim("null"),this.not(this.app("nameRest")))).define("keyword_true",[],this.seq(this.prim("true"),this.not(this.app("nameRest")))).define("keyword_false",[],this.seq(this.prim("false"),this.not(this.app("nameRest")))).define("keyword",[],this.alt(this.app("keyword_null"),this.app("keyword_true"),this.app("keyword_false"))).define("string",[],this.seq(this.prim('"'),this.star(this.app("strChar")),this.prim('"')),"a string literal").define("strChar",[],this.alt(this.app("escapeChar"),this.seq(this.not(this.prim("\\")),this.not(this.prim('"')),this.not(this.prim("\n")),this.app("_")))).define("escapeChar_backslash",[],this.prim("\\\\")).define("escapeChar_doubleQuote",[],this.prim('\\"')).define("escapeChar_singleQuote",[],this.prim("\\'")).define("escapeChar_backspace",[],this.prim("\\b")).define("escapeChar_lineFeed",[],this.prim("\\n")).define("escapeChar_carriageReturn",[],this.prim("\\r")).define("escapeChar_tab",[],this.prim("\\t")).define("escapeChar_unicodeEscape",[],this.seq(this.prim("\\u"),this.app("hexDigit"),this.app("hexDigit"),this.app("hexDigit"),this.app("hexDigit"))).define("escapeChar_hexEscape",[],this.seq(this.prim("\\x"),this.app("hexDigit"),this.app("hexDigit"))).define("escapeChar",[],this.alt(this.app("escapeChar_backslash"),this.app("escapeChar_doubleQuote"),this.app("escapeChar_singleQuote"),this.app("escapeChar_backspace"),this.app("escapeChar_lineFeed"),this.app("escapeChar_carriageReturn"),this.app("escapeChar_tab"),this.app("escapeChar_unicodeEscape"),this.app("escapeChar_hexEscape"))).define("regExp",[],this.seq(this.prim("/"),this.app("reCharClass"),this.prim("/")),"a regular expression").define("reCharClass_unicode",[],this.seq(this.prim("\\p{"),this.plus(this.prim(/[A-Za-z]/)),this.prim("}"))).define("reCharClass_ordinary",[],this.seq(this.prim("["),this.star(this.alt(this.prim("\\]"),this.seq(this.not(this.prim("]")),this.app("_")))),this.prim("]"))).define("reCharClass",[],this.alt(this.app("reCharClass_unicode"),this.app("reCharClass_ordinary"))).define("number",[],this.seq(this.opt(this.prim("-")),this.plus(this.app("digit"))),"a number").define("space_singleLine",[],this.seq(this.prim("//"),this.star(this.seq(this.not(this.prim("\n")),this.app("_"))),this.prim("\n"))).define("space_multiLine",[],this.seq(this.prim("/*"),this.star(this.seq(this.not(this.prim("*/")),this.app("_"))),this.prim("*/"))).extend("space",[],this.alt(this.alt(this.app("space_singleLine"),this.app("space_multiLine")),this.prim(/[\s]/)),"a space").build()})},{"..":28}],3:[function(_dereq_,module,exports){var base64=_dereq_("base64-js");var ieee754=_dereq_("ieee754");exports.Buffer=Buffer;exports.SlowBuffer=Buffer;exports.INSPECT_MAX_BYTES=50;Buffer.poolSize=8192;Buffer._useTypedArrays=function(){try{var buf=new ArrayBuffer(0);var arr=new Uint8Array(buf);arr.foo=function(){return 42};return 42===arr.foo()&&typeof arr.subarray==="function"}catch(e){return false}}();function Buffer(subject,encoding,noZero){if(!(this instanceof Buffer))return new Buffer(subject,encoding,noZero);var type=typeof subject;if(encoding==="base64"&&type==="string"){subject=stringtrim(subject);while(subject.length%4!==0){subject=subject+"="}}var length;if(type==="number")length=coerce(subject);else if(type==="string")length=Buffer.byteLength(subject,encoding);else if(type==="object")length=coerce(subject.length);else throw new Error("First argument needs to be a number, array or string.");var buf;if(Buffer._useTypedArrays){buf=Buffer._augment(new Uint8Array(length))}else{buf=this;buf.length=length;buf._isBuffer=true}var i;if(Buffer._useTypedArrays&&typeof subject.byteLength==="number"){buf._set(subject)}else if(isArrayish(subject)){for(i=0;iremaining){length=remaining}}var strLen=string.length;assert(strLen%2===0,"Invalid hex string");if(length>strLen/2){length=strLen/2}for(var i=0;iremaining){length=remaining}}encoding=String(encoding||"utf8").toLowerCase();var ret;switch(encoding){case"hex":ret=_hexWrite(this,string,offset,length);break;case"utf8":case"utf-8":ret=_utf8Write(this,string,offset,length);break;case"ascii":ret=_asciiWrite(this,string,offset,length);break;case"binary":ret=_binaryWrite(this,string,offset,length);break;case"base64":ret=_base64Write(this,string,offset,length);break;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":ret=_utf16leWrite(this,string,offset,length);break;default:throw new Error("Unknown encoding")}return ret};Buffer.prototype.toString=function(encoding,start,end){var self=this;encoding=String(encoding||"utf8").toLowerCase();start=Number(start)||0;end=end!==undefined?Number(end):end=self.length;if(end===start)return"";var ret;switch(encoding){case"hex":ret=_hexSlice(self,start,end);break;case"utf8":case"utf-8":ret=_utf8Slice(self,start,end);break;case"ascii":ret=_asciiSlice(self,start,end);break;case"binary":ret=_binarySlice(self,start,end);break;case"base64":ret=_base64Slice(self,start,end);break;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":ret=_utf16leSlice(self,start,end);break;default:throw new Error("Unknown encoding")}return ret};Buffer.prototype.toJSON=function(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}};Buffer.prototype.copy=function(target,target_start,start,end){var source=this;if(!start)start=0;if(!end&&end!==0)end=this.length;if(!target_start)target_start=0;if(end===start)return;if(target.length===0||source.length===0)return;assert(end>=start,"sourceEnd < sourceStart");assert(target_start>=0&&target_start=0&&start=0&&end<=source.length,"sourceEnd out of bounds");if(end>this.length)end=this.length;if(target.length-target_startlen)end=len;var out="";for(var i=start;i=this.length)return;return this[offset]};function _readUInt16(buf,offset,littleEndian,noAssert){if(!noAssert){assert(typeof littleEndian==="boolean","missing or invalid endian");assert(offset!==undefined&&offset!==null,"missing offset");assert(offset+1=len)return;var val;if(littleEndian){val=buf[offset];if(offset+1=len)return;var val;if(littleEndian){if(offset+2>>0)}else{if(offset+1>>0)}return val}Buffer.prototype.readUInt32LE=function(offset,noAssert){return _readUInt32(this,offset,true,noAssert)};Buffer.prototype.readUInt32BE=function(offset,noAssert){return _readUInt32(this,offset,false,noAssert)};Buffer.prototype.readInt8=function(offset,noAssert){if(!noAssert){assert(offset!==undefined&&offset!==null,"missing offset");assert(offset=this.length)return;var neg=this[offset]&128;if(neg)return(255-this[offset]+1)*-1;else return this[offset]};function _readInt16(buf,offset,littleEndian,noAssert){if(!noAssert){assert(typeof littleEndian==="boolean","missing or invalid endian");assert(offset!==undefined&&offset!==null,"missing offset");assert(offset+1=len)return;var val=_readUInt16(buf,offset,littleEndian,true);var neg=val&32768;if(neg)return(65535-val+1)*-1;else return val}Buffer.prototype.readInt16LE=function(offset,noAssert){return _readInt16(this,offset,true,noAssert)};Buffer.prototype.readInt16BE=function(offset,noAssert){return _readInt16(this,offset,false,noAssert)};function _readInt32(buf,offset,littleEndian,noAssert){if(!noAssert){assert(typeof littleEndian==="boolean","missing or invalid endian");assert(offset!==undefined&&offset!==null,"missing offset");assert(offset+3=len)return;var val=_readUInt32(buf,offset,littleEndian,true);var neg=val&2147483648;if(neg)return(4294967295-val+1)*-1;else return val}Buffer.prototype.readInt32LE=function(offset,noAssert){return _readInt32(this,offset,true,noAssert)};Buffer.prototype.readInt32BE=function(offset,noAssert){return _readInt32(this,offset,false,noAssert)};function _readFloat(buf,offset,littleEndian,noAssert){if(!noAssert){assert(typeof littleEndian==="boolean","missing or invalid endian");assert(offset+3=this.length)return;this[offset]=value};function _writeUInt16(buf,value,offset,littleEndian,noAssert){if(!noAssert){assert(value!==undefined&&value!==null,"missing value");assert(typeof littleEndian==="boolean","missing or invalid endian");assert(offset!==undefined&&offset!==null,"missing offset");assert(offset+1=len)return;for(var i=0,j=Math.min(len-offset,2);i>>(littleEndian?i:1-i)*8}}Buffer.prototype.writeUInt16LE=function(value,offset,noAssert){_writeUInt16(this,value,offset,true,noAssert)};Buffer.prototype.writeUInt16BE=function(value,offset,noAssert){_writeUInt16(this,value,offset,false,noAssert)};function _writeUInt32(buf,value,offset,littleEndian,noAssert){if(!noAssert){assert(value!==undefined&&value!==null,"missing value");assert(typeof littleEndian==="boolean","missing or invalid endian");assert(offset!==undefined&&offset!==null,"missing offset");assert(offset+3=len)return;for(var i=0,j=Math.min(len-offset,4);i>>(littleEndian?i:3-i)*8&255}}Buffer.prototype.writeUInt32LE=function(value,offset,noAssert){_writeUInt32(this,value,offset,true,noAssert)};Buffer.prototype.writeUInt32BE=function(value,offset,noAssert){_writeUInt32(this,value,offset,false,noAssert)};Buffer.prototype.writeInt8=function(value,offset,noAssert){if(!noAssert){assert(value!==undefined&&value!==null,"missing value");assert(offset!==undefined&&offset!==null,"missing offset");assert(offset=this.length)return;if(value>=0)this.writeUInt8(value,offset,noAssert);else this.writeUInt8(255+value+1,offset,noAssert)};function _writeInt16(buf,value,offset,littleEndian,noAssert){if(!noAssert){assert(value!==undefined&&value!==null,"missing value");assert(typeof littleEndian==="boolean","missing or invalid endian");assert(offset!==undefined&&offset!==null,"missing offset");assert(offset+1=len)return;if(value>=0)_writeUInt16(buf,value,offset,littleEndian,noAssert);else _writeUInt16(buf,65535+value+1,offset,littleEndian,noAssert)}Buffer.prototype.writeInt16LE=function(value,offset,noAssert){_writeInt16(this,value,offset,true,noAssert)};Buffer.prototype.writeInt16BE=function(value,offset,noAssert){_writeInt16(this,value,offset,false,noAssert)};function _writeInt32(buf,value,offset,littleEndian,noAssert){if(!noAssert){assert(value!==undefined&&value!==null,"missing value");assert(typeof littleEndian==="boolean","missing or invalid endian");assert(offset!==undefined&&offset!==null,"missing offset");assert(offset+3=len)return;if(value>=0)_writeUInt32(buf,value,offset,littleEndian,noAssert);else _writeUInt32(buf,4294967295+value+1,offset,littleEndian,noAssert)}Buffer.prototype.writeInt32LE=function(value,offset,noAssert){_writeInt32(this,value,offset,true,noAssert)};Buffer.prototype.writeInt32BE=function(value,offset,noAssert){_writeInt32(this,value,offset,false,noAssert)};function _writeFloat(buf,value,offset,littleEndian,noAssert){if(!noAssert){assert(value!==undefined&&value!==null,"missing value");assert(typeof littleEndian==="boolean","missing or invalid endian");assert(offset!==undefined&&offset!==null,"missing offset");assert(offset+3=len)return;ieee754.write(buf,value,offset,littleEndian,23,4)}Buffer.prototype.writeFloatLE=function(value,offset,noAssert){_writeFloat(this,value,offset,true,noAssert)};Buffer.prototype.writeFloatBE=function(value,offset,noAssert){_writeFloat(this,value,offset,false,noAssert)};function _writeDouble(buf,value,offset,littleEndian,noAssert){if(!noAssert){assert(value!==undefined&&value!==null,"missing value");assert(typeof littleEndian==="boolean","missing or invalid endian");assert(offset!==undefined&&offset!==null,"missing offset");assert(offset+7=len)return;ieee754.write(buf,value,offset,littleEndian,52,8)}Buffer.prototype.writeDoubleLE=function(value,offset,noAssert){_writeDouble(this,value,offset,true,noAssert)};Buffer.prototype.writeDoubleBE=function(value,offset,noAssert){_writeDouble(this,value,offset,false,noAssert)};Buffer.prototype.fill=function(value,start,end){if(!value)value=0;if(!start)start=0;if(!end)end=this.length;if(typeof value==="string"){value=value.charCodeAt(0)}assert(typeof value==="number"&&!isNaN(value),"value is not a number");assert(end>=start,"end < start");if(end===start)return;if(this.length===0)return;assert(start>=0&&start=0&&end<=this.length,"end out of bounds");for(var i=start;i"};Buffer.prototype.toArrayBuffer=function(){if(typeof Uint8Array!=="undefined"){if(Buffer._useTypedArrays){return new Buffer(this).buffer}else{var buf=new Uint8Array(this.length);for(var i=0,len=buf.length;i=len)return len;if(index>=0)return index;index+=len;if(index>=0)return index;return 0}function coerce(length){length=~~Math.ceil(+length);return length<0?0:length}function isArray(subject){return(Array.isArray||function(subject){return Object.prototype.toString.call(subject)==="[object Array]"})(subject)}function isArrayish(subject){return isArray(subject)||Buffer.isBuffer(subject)||subject&&typeof subject==="object"&&typeof subject.length==="number"}function toHex(n){if(n<16)return"0"+n.toString(16);return n.toString(16)}function utf8ToBytes(str){var byteArray=[];for(var i=0;i=55296&&b<=57343)i++;var h=encodeURIComponent(str.slice(start,i+1)).substr(1).split("%");for(var j=0;j>8;lo=c%256;byteArray.push(lo);byteArray.push(hi)}return byteArray}function base64ToBytes(str){return base64.toByteArray(str)}function blitBuffer(src,dst,offset,length){var pos;for(var i=0;i=dst.length||i>=src.length)break;dst[i+offset]=src[i]}return i}function decodeUtf8Char(str){try{return decodeURIComponent(str)}catch(err){return String.fromCharCode(65533)}}function verifuint(value,max){assert(typeof value==="number","cannot write a non-number as a number");assert(value>=0,"specified a negative value for writing an unsigned value");assert(value<=max,"value is larger than maximum value for type");assert(Math.floor(value)===value,"value has a fractional component")}function verifsint(value,max,min){assert(typeof value==="number","cannot write a non-number as a number");assert(value<=max,"value larger than maximum allowed value");assert(value>=min,"value smaller than minimum allowed value");assert(Math.floor(value)===value,"value has a fractional component")}function verifIEEE754(value,max,min){assert(typeof value==="number","cannot write a non-number as a number");assert(value<=max,"value larger than maximum allowed value");assert(value>=min,"value smaller than minimum allowed value")}function assert(test,message){if(!test)throw new Error(message||"Failed assertion")}},{"base64-js":4,ieee754:5}],4:[function(_dereq_,module,exports){var lookup="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";(function(exports){"use strict";var Arr=typeof Uint8Array!=="undefined"?Uint8Array:Array;var PLUS="+".charCodeAt(0);var SLASH="/".charCodeAt(0);var NUMBER="0".charCodeAt(0);var LOWER="a".charCodeAt(0);var UPPER="A".charCodeAt(0);var PLUS_URL_SAFE="-".charCodeAt(0);var SLASH_URL_SAFE="_".charCodeAt(0);function decode(elt){var code=elt.charCodeAt(0);if(code===PLUS||code===PLUS_URL_SAFE)return 62;if(code===SLASH||code===SLASH_URL_SAFE)return 63;if(code0){throw new Error("Invalid string. Length must be a multiple of 4")}var len=b64.length;placeHolders="="===b64.charAt(len-2)?2:"="===b64.charAt(len-1)?1:0;arr=new Arr(b64.length*3/4-placeHolders);l=placeHolders>0?b64.length-4:b64.length;var L=0;function push(v){arr[L++]=v}for(i=0,j=0;i>16);push((tmp&65280)>>8);push(tmp&255)}if(placeHolders===2){tmp=decode(b64.charAt(i))<<2|decode(b64.charAt(i+1))>>4;push(tmp&255)}else if(placeHolders===1){tmp=decode(b64.charAt(i))<<10|decode(b64.charAt(i+1))<<4|decode(b64.charAt(i+2))>>2;push(tmp>>8&255);push(tmp&255)}return arr}function uint8ToBase64(uint8){var i,extraBytes=uint8.length%3,output="",temp,length;function encode(num){return lookup.charAt(num)}function tripletToBase64(num){return encode(num>>18&63)+encode(num>>12&63)+encode(num>>6&63)+encode(num&63)}for(i=0,length=uint8.length-extraBytes;i>2);output+=encode(temp<<4&63);output+="==";break;case 2:temp=(uint8[uint8.length-2]<<8)+uint8[uint8.length-1]; -output+=encode(temp>>10);output+=encode(temp>>4&63);output+=encode(temp<<2&63);output+="=";break}return output}exports.toByteArray=b64ToByteArray;exports.fromByteArray=uint8ToBase64})(typeof exports==="undefined"?this.base64js={}:exports)},{}],5:[function(_dereq_,module,exports){exports.read=function(buffer,offset,isLE,mLen,nBytes){var e,m,eLen=nBytes*8-mLen-1,eMax=(1<>1,nBits=-7,i=isLE?nBytes-1:0,d=isLE?-1:1,s=buffer[offset+i];i+=d;e=s&(1<<-nBits)-1;s>>=-nBits;nBits+=eLen;for(;nBits>0;e=e*256+buffer[offset+i],i+=d,nBits-=8){}m=e&(1<<-nBits)-1;e>>=-nBits;nBits+=mLen;for(;nBits>0;m=m*256+buffer[offset+i],i+=d,nBits-=8){}if(e===0){e=1-eBias}else if(e===eMax){return m?NaN:(s?-1:1)*Infinity}else{m=m+Math.pow(2,mLen);e=e-eBias}return(s?-1:1)*m*Math.pow(2,e-mLen)};exports.write=function(buffer,value,offset,isLE,mLen,nBytes){var e,m,c,eLen=nBytes*8-mLen-1,eMax=(1<>1,rt=mLen===23?Math.pow(2,-24)-Math.pow(2,-77):0,i=isLE?0:nBytes-1,d=isLE?1:-1,s=value<0||value===0&&1/value<0?1:0;value=Math.abs(value);if(isNaN(value)||value===Infinity){m=isNaN(value)?1:0;e=eMax}else{e=Math.floor(Math.log(value)/Math.LN2);if(value*(c=Math.pow(2,-e))<1){e--;c*=2}if(e+eBias>=1){value+=rt/c}else{value+=rt*Math.pow(2,1-eBias)}if(value*c>=2){e++;c/=2}if(e+eBias>=eMax){m=0;e=eMax}else if(e+eBias>=1){m=(value*c-1)*Math.pow(2,mLen);e=e+eBias}else{m=value*Math.pow(2,eBias-1)*Math.pow(2,mLen);e=0}}for(;mLen>=8;buffer[offset+i]=m&255,i+=d,m/=256,mLen-=8){}e=e<0;buffer[offset+i]=e&255,i+=d,e/=256,eLen-=8){}buffer[offset+i-d]|=s*128}},{}],6:[function(_dereq_,module,exports){var Buffer=_dereq_("buffer").Buffer;var intSize=4;var zeroBuffer=new Buffer(intSize);zeroBuffer.fill(0);var chrsz=8;function toArray(buf,bigEndian){if(buf.length%intSize!==0){var len=buf.length+(intSize-buf.length%intSize);buf=Buffer.concat([buf,zeroBuffer],len)}var arr=[];var fn=bigEndian?buf.readInt32BE:buf.readInt32LE;for(var i=0;iblocksize){key=fn(key)}else if(key.length>5]|=128<>>9<<4)+14]=len;var a=1732584193;var b=-271733879;var c=-1732584194;var d=271733878;for(var i=0;i>16)+(y>>16)+(lsw>>16);return msw<<16|lsw&65535}function bit_rol(num,cnt){return num<>>32-cnt}module.exports=function md5(buf){return helpers.hash(buf,core_md5,16)}},{"./helpers":6}],9:[function(_dereq_,module,exports){(function(){var _global=this;var mathRNG,whatwgRNG;mathRNG=function(size){var bytes=new Array(size);var r;for(var i=0,r;i>>((i&3)<<3)&255}return bytes};if(_global.crypto&&crypto.getRandomValues){whatwgRNG=function(size){var bytes=new Uint8Array(size);crypto.getRandomValues(bytes);return bytes}}module.exports=whatwgRNG||mathRNG})()},{}],10:[function(_dereq_,module,exports){var helpers=_dereq_("./helpers");function core_sha1(x,len){x[len>>5]|=128<<24-len%32;x[(len+64>>9<<4)+15]=len;var w=Array(80);var a=1732584193;var b=-271733879;var c=-1732584194;var d=271733878;var e=-1009589776;for(var i=0;i>16)+(y>>16)+(lsw>>16);return msw<<16|lsw&65535}function rol(num,cnt){return num<>>32-cnt}module.exports=function sha1(buf){return helpers.hash(buf,core_sha1,20,true)}},{"./helpers":6}],11:[function(_dereq_,module,exports){var helpers=_dereq_("./helpers");var safe_add=function(x,y){var lsw=(x&65535)+(y&65535);var msw=(x>>16)+(y>>16)+(lsw>>16);return msw<<16|lsw&65535};var S=function(X,n){return X>>>n|X<<32-n};var R=function(X,n){return X>>>n};var Ch=function(x,y,z){return x&y^~x&z};var Maj=function(x,y,z){return x&y^x&z^y&z};var Sigma0256=function(x){return S(x,2)^S(x,13)^S(x,22)};var Sigma1256=function(x){return S(x,6)^S(x,11)^S(x,25)};var Gamma0256=function(x){return S(x,7)^S(x,18)^R(x,3)};var Gamma1256=function(x){return S(x,17)^S(x,19)^R(x,10)};var core_sha256=function(m,l){var K=new Array(1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298);var HASH=new Array(1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225);var W=new Array(64);var a,b,c,d,e,f,g,h,i,j;var T1,T2;m[l>>5]|=128<<24-l%32;m[(l+64>>9<<4)+15]=l;for(var i=0;i0){var prettyProblems=problems.map(function(problem){return"- "+problem});var error=new Error("Found errors in the action dictionary of the '"+name+"' "+what+":\n"+prettyProblems.join("\n"));error.problems=problems;throw error}},_topDownActionArity:function(actionName){if(actionName==="_default"){return 1}else if(actionName==="_terminal"){return 0}return this.ruleDict[actionName].getArity()},_inheritsFrom:function(grammar){var g=this.superGrammar;while(g){if(g===grammar){return true}g=g.superGrammar}return false},toRecipe:function(optVarName){if(this.isBuiltIn()){throw new Error("Why would anyone want to generate a recipe for the "+this.name+" grammar?!?!")}var sb=new common.StringBuffer;if(optVarName){sb.append("var "+optVarName+" = ")}sb.append("(function() {\n");var superGrammarDecl="";if(!this.superGrammar.isBuiltIn()){sb.append(this.superGrammar.toRecipe("buildSuperGrammar"));superGrammarDecl=" .withSuperGrammar(buildSuperGrammar.call(this))\n"}sb.append(" return new this.newGrammar("+common.toStringLiteral(this.name)+")\n");sb.append(superGrammarDecl);if(this.defaultStartRule){sb.append(" .withDefaultStartRule('"+this.defaultStartRule+"')\n")}var self=this;Object.keys(this.ruleDict).forEach(function(ruleName){var body=self.ruleDict[ruleName];sb.append(" .");if(self.superGrammar.ruleDict[ruleName]){sb.append(body instanceof pexprs.Extend?"extend":"override")}else{sb.append("define")}var formals="["+body.formals.map(common.toStringLiteral).join(", ")+"]";sb.append("("+common.toStringLiteral(ruleName)+", "+formals+", ");body.outputRecipe(sb,body.formals);if(body.description){sb.append(", "+common.toStringLiteral(body.description))}sb.append(")\n")});sb.append(" .build();\n});\n");return sb.contents()},toOperationActionDictionaryTemplate:function(){return this._toOperationOrAttributeActionDictionaryTemplate()},toAttributeActionDictionaryTemplate:function(){return this._toOperationOrAttributeActionDictionaryTemplate()},_toOperationOrAttributeActionDictionaryTemplate:function(){var self=this;var sb=new common.StringBuffer;sb.append("{");var first=true;for(var ruleName in this.ruleDict){if(ruleName==="spaces_"){continue}var body=this.ruleDict[ruleName];if(first){first=false}else{sb.append(",")}sb.append("\n");sb.append(" ");this.addSemanticActionTemplate(ruleName,body,sb)}sb.append("\n}");return sb.contents()},addSemanticActionTemplate:function(ruleName,body,sb){sb.append(ruleName);sb.append(": function(");var arity=this._topDownActionArity(ruleName);sb.append(common.repeat("_",arity).join(", "));sb.append(") {\n");sb.append(" }")}};Grammar.ProtoBuiltInRules=new Grammar("ProtoBuiltInRules",undefined,{_:pexprs.anything.withFormals([]),end:pexprs.end.withFormals([]),spaces_:new pexprs.Star(new pexprs.Apply("space")).withFormals([]),space:pexprs.makePrim(/[\s]/).withFormals([]).withDescription("a space")});module.exports=Grammar},{"./InputStream":18,"./Interval":19,"./MatchResult":20,"./Semantics":23,"./State":24,"./common":26,"./errors":27,"./nodes":29,"./pexprs":44}],17:[function(_dereq_,module,exports){"use strict";var Grammar=_dereq_("./Grammar");var common=_dereq_("./common");var errors=_dereq_("./errors");var pexprs=_dereq_("./pexprs");function GrammarDecl(name){this.name=name}function onOhmError(doFn,onErrorFn){try{doFn()}catch(e){if(e instanceof errors.Error){onErrorFn(e)}else{throw e}}}GrammarDecl.prototype.ensureSuperGrammar=function(){if(!this.superGrammar){this.withSuperGrammar(this.name==="BuiltInRules"?Grammar.ProtoBuiltInRules:Grammar.BuiltInRules)}return this.superGrammar};GrammarDecl.prototype.installOverriddenOrExtendedRule=function(name,formals,body){var duplicateParameterNames=common.getDuplicates(formals);if(duplicateParameterNames.length>0){throw new errors.DuplicateParameterNames(name,duplicateParameterNames)}var baseRule=this.ensureSuperGrammar().ruleDict[name];if(formals.length!==baseRule.formals.length){throw new errors.WrongNumberOfParameters(name,baseRule.formals.length,formals.length)}return this.install(name,formals,baseRule.description,body)};GrammarDecl.prototype.install=function(name,formals,description,body){body=body.introduceParams(formals);body.formals=formals;body.description=description;this.ruleDict[name]=body;return this};GrammarDecl.prototype.withSuperGrammar=function(superGrammar){if(this.superGrammar){throw new Error("the super grammar of a GrammarDecl cannot be set more than once")}this.superGrammar=superGrammar;this.ruleDict=Object.create(superGrammar.ruleDict);if(!superGrammar.isBuiltIn()){this.defaultStartRule=superGrammar.defaultStartRule}return this};GrammarDecl.prototype.withDefaultStartRule=function(ruleName){this.defaultStartRule=ruleName;return this};GrammarDecl.prototype.build=function(){var grammar=new Grammar(this.name,this.ensureSuperGrammar(),this.ruleDict,this.defaultStartRule);var grammarErrors=[];var grammarHasInvalidApplications=false;Object.keys(grammar.ruleDict).forEach(function(ruleName){var body=grammar.ruleDict[ruleName];onOhmError(function(){body.assertChoicesHaveUniformArity(ruleName)},function(e){grammarErrors.push(e)});onOhmError(function(){body.assertAllApplicationsAreValid(grammar)},function(e){grammarErrors.push(e);grammarHasInvalidApplications=true})});if(!grammarHasInvalidApplications){Object.keys(grammar.ruleDict).forEach(function(ruleName){var body=grammar.ruleDict[ruleName];onOhmError(function(){body.assertIteratedExprsAreNotNullable(grammar,ruleName)},function(e){grammarErrors.push(e)})})}if(grammarErrors.length>0){errors.throwErrors(grammarErrors)}return grammar};GrammarDecl.prototype.define=function(name,formals,body,optDescr){this.ensureSuperGrammar();if(this.superGrammar.ruleDict[name]){throw new errors.DuplicateRuleDeclaration(name,this.name,this.superGrammar.name)}else if(this.ruleDict[name]){throw new errors.DuplicateRuleDeclaration(name,this.name,this.name)}var duplicateParameterNames=common.getDuplicates(formals);if(duplicateParameterNames.length>0){throw new errors.DuplicateParameterNames(name,duplicateParameterNames)}return this.install(name,formals,optDescr,body)};GrammarDecl.prototype.override=function(name,formals,body){var baseRule=this.ensureSuperGrammar().ruleDict[name];if(!baseRule){throw new errors.CannotOverrideUndeclaredRule(name,this.superGrammar.name)}this.installOverriddenOrExtendedRule(name,formals,body);return this};GrammarDecl.prototype.extend=function(name,formals,body){var baseRule=this.ensureSuperGrammar().ruleDict[name];if(!baseRule){throw new errors.CannotExtendUndeclaredRule(name,this.superGrammar.name)}this.installOverriddenOrExtendedRule(name,formals,new pexprs.Extend(this.superGrammar,name,body));return this};module.exports=GrammarDecl},{"./Grammar":16,"./common":26,"./errors":27,"./pexprs":44}],18:[function(_dereq_,module,exports){"use strict";var common=_dereq_("./common");var Interval=_dereq_("./Interval");function InputStream(){throw new Error("InputStream cannot be instantiated -- it's abstract")}InputStream.newFor=function(obj){if(typeof obj==="string"){return new StringInputStream(obj)}else if(Array.isArray(obj)){return new ListInputStream(obj)}else if(obj instanceof InputStream){return obj}else{throw new Error("cannot make input stream for "+obj)}};InputStream.prototype={init:function(source){this.source=source;this.pos=0;this.posInfos=[]},atEnd:function(){return this.pos===this.source.length},next:function(){if(this.atEnd()){return common.fail}else{return this.source[this.pos++]}},matchExactly:function(x){return this.next()===x?true:common.fail},sourceSlice:function(startIdx,endIdx){return this.source.slice(startIdx,endIdx)},intervalFrom:function(startIdx){return new Interval(this,startIdx,this.pos)}};function StringInputStream(source){this.init(source)}StringInputStream.prototype=Object.create(InputStream.prototype,{matchString:{value:function(s){for(var idx=0;idx0){if(idx===expected.length-1){sb.append(expected.length>2?", or ":" or ")}else{sb.append(", ")}}sb.append(expected[idx])}return sb.contents()};MatchFailure.prototype.getExpected=function(){var expected={};var ruleDict=this.state.grammar.ruleDict;this._exprsAndStacks.forEach(function(obj){expected[obj.expr.toExpected(ruleDict)]=true});return Object.keys(expected)};module.exports=MatchResult},{"./common":26,"./util":45,inherits:12}],21:[function(_dereq_,module,exports){"use strict";var extend=_dereq_("util-extend");function Namespace(){}Namespace.prototype=Object.create(null);Namespace.asNamespace=function(objOrNamespace){if(objOrNamespace instanceof Namespace){return objOrNamespace}return Namespace.createNamespace(objOrNamespace)};Namespace.createNamespace=function(optProps){return Namespace.extend(Namespace.prototype,optProps)};Namespace.extend=function(namespace,optProps){if(namespace!==Namespace.prototype&&!(namespace instanceof Namespace)){throw new TypeError("not a Namespace object: "+namespace)}var ns=Object.create(namespace,{constructor:{value:Namespace,enumerable:false,writable:true,configurable:true}});return extend(ns,optProps)};Namespace.toString=function(ns){return Object.prototype.toString.call(ns)};module.exports=Namespace},{"util-extend":14}],22:[function(_dereq_,module,exports){"use strict";function PosInfo(globalApplicationStack){this.globalApplicationStack=globalApplicationStack;this.applicationStack=[];this.activeApplications={};this.memo={}}PosInfo.prototype={isActive:function(application){return this.activeApplications[application.toMemoKey()]},enter:function(application){this.globalApplicationStack.push(application);this.applicationStack.push(application);this.activeApplications[application.toMemoKey()]=true},exit:function(){var application=this.globalApplicationStack.pop(); -this.applicationStack.pop();this.activeApplications[application.toMemoKey()]=false},shouldUseMemoizedResult:function(memoRec){var involvedApplications=memoRec.involvedApplications;for(var memoKey in involvedApplications){if(involvedApplications[memoKey]&&this.activeApplications[memoKey]){return false}}return true},getCurrentLeftRecursion:function(){if(this.leftRecursionStack){return this.leftRecursionStack[this.leftRecursionStack.length-1]}},startLeftRecursion:function(application){if(!this.leftRecursionStack){this.leftRecursionStack=[]}this.leftRecursionStack.push({memoKey:application.toMemoKey(),value:false,pos:-1,involvedApplications:{}});this.updateInvolvedApplications()},endLeftRecursion:function(application){this.leftRecursionStack.pop()},updateInvolvedApplications:function(){var currentLeftRecursion=this.getCurrentLeftRecursion();var involvedApplications=currentLeftRecursion.involvedApplications;var lrApplicationMemoKey=currentLeftRecursion.memoKey;var idx=this.applicationStack.length-1;while(true){var memoKey=this.applicationStack[idx--].toMemoKey();if(memoKey===lrApplicationMemoKey){break}involvedApplications[memoKey]=true}}};module.exports=PosInfo},{}],23:[function(_dereq_,module,exports){"use strict";var Symbol=_dereq_("symbol");var inherits=_dereq_("inherits");var MatchResult=_dereq_("./MatchResult");var common=_dereq_("./common");function Wrapper(){}Wrapper.prototype.toString=function(){return"[semantics wrapper for "+this._node.grammar.name+"]"};Wrapper.prototype.child=function(idx){if(!(0<=idx&&idx0){return}if(posthis.rightmostFailPos){this.rightmostFailPos=pos}if(!this.failures){return}function addStack(stack,stacks){for(var idx=0;idx0){arr.push(fn())}return arr};exports.repeat=function(x,n){return exports.repeatFn(function(){return x},n)};exports.getDuplicates=function(array){var duplicates=[];for(var idx=0;idx=0;var hasDoubleQuotes=str.indexOf('"')>=0;var delim=hasSingleQuotes&&!hasDoubleQuotes?'"':"'";var sb=new exports.StringBuffer;sb.append(delim);for(var idx=0;idx1){throw new MultipleErrors(errors)}}}},{"./Namespace":21}],28:[function(_dereq_,module,exports){(function(Buffer){"use strict";var Builder=_dereq_("./Builder");var Grammar=_dereq_("./Grammar");var Namespace=_dereq_("./Namespace");var Semantics=_dereq_("./Semantics");var UnicodeCategories=_dereq_("../third_party/unicode").UnicodeCategories;var common=_dereq_("./common");var errors=_dereq_("./errors");var util=_dereq_("./util");var ohmGrammar;var documentInterface={querySelector:function(sel){return document.querySelector(sel)},querySelectorAll:function(sel){return document.querySelectorAll(sel)}};function isElement(obj){return!!(obj&&obj.nodeType===1)}function isUndefined(obj){return obj===void 0}var MAX_ARRAY_INDEX=Math.pow(2,53)-1;function isArrayLike(obj){if(obj==null){return false}var length=obj.length;return typeof length==="number"&&length>=0&&length<=MAX_ARRAY_INDEX}function load(url){var req=new XMLHttpRequest;req.open("GET",url,false);try{req.send();if(req.status===0||req.status===200){return req.responseText}}catch(e){}throw new Error("unable to load url "+url)}function buildGrammar(match,namespace,optOhmGrammarForTesting){var builder;var decl;var currentRuleName;var currentRuleFormals;var overriding=false;var metaGrammar=optOhmGrammarForTesting||ohmGrammar;var helpers=metaGrammar.semantics().addOperation("visit",{Grammar:function(n,s,open,rs,close){builder=new Builder;var grammarName=n.visit();decl=builder.newGrammar(grammarName,namespace);s.visit();rs.visit();var g=decl.build();if(grammarName in namespace){throw new errors.DuplicateGrammarDeclaration(grammarName,namespace)}g.definitionInterval=this.interval.trimmed();namespace[grammarName]=g;return g},SuperGrammar:function(_,n){var superGrammarName=n.visit();if(superGrammarName==="null"){decl.withSuperGrammar(null)}else{if(!namespace||!(superGrammarName in namespace)){throw new errors.UndeclaredGrammar(superGrammarName,namespace)}decl.withSuperGrammar(namespace[superGrammarName])}},Rule_define:function(n,fs,d,_,b){currentRuleName=n.visit();currentRuleFormals=fs.visit()[0]||[];if(!decl.defaultStartRule&&decl.ensureSuperGrammar()!==Grammar.ProtoBuiltInRules){decl.withDefaultStartRule(currentRuleName)}var body=b.visit();body.definitionInterval=this.interval.trimmed();var description=d.visit()[0];return decl.define(currentRuleName,currentRuleFormals,body,description)},Rule_override:function(n,fs,_,b){currentRuleName=n.visit();currentRuleFormals=fs.visit()[0]||[];overriding=true;var body=b.visit();body.definitionInterval=this.interval.trimmed();var ans=decl.override(currentRuleName,currentRuleFormals,body);overriding=false;return ans},Rule_extend:function(n,fs,_,b){currentRuleName=n.visit();currentRuleFormals=fs.visit()[0]||[];var body=b.visit();var ans=decl.extend(currentRuleName,currentRuleFormals,body);decl.ruleDict[currentRuleName].definitionInterval=this.interval.trimmed();return ans},Formals:function(opointy,fs,cpointy){return fs.visit()},Params:function(opointy,ps,cpointy){return ps.visit()},Alt:function(term,_,terms){var args=[term.visit()].concat(terms.visit());return builder.alt.apply(builder,args).withInterval(this.interval)},Term_inline:function(b,n){var inlineRuleName=currentRuleName+"_"+n.visit();var body=b.visit();body.definitionInterval=this.interval.trimmed();var isNewRuleDeclaration=!(decl.superGrammar&&decl.superGrammar.ruleDict[inlineRuleName]);if(overriding&&!isNewRuleDeclaration){decl.override(inlineRuleName,currentRuleFormals,body)}else{decl.define(inlineRuleName,currentRuleFormals,body)}var params=currentRuleFormals.map(function(formal){return builder.app(formal)});return builder.app(inlineRuleName,params).withInterval(body.interval)},Seq:function(expr){return builder.seq.apply(builder,expr.visit()).withInterval(this.interval)},Iter_star:function(x,_){return builder.star(x.visit()).withInterval(this.interval)},Iter_plus:function(x,_){return builder.plus(x.visit()).withInterval(this.interval)},Iter_opt:function(x,_){return builder.opt(x.visit()).withInterval(this.interval)},Pred_not:function(_,x){return builder.not(x.visit()).withInterval(this.interval)},Pred_lookahead:function(_,x){return builder.la(x.visit()).withInterval(this.interval)},Base_application:function(rule,ps){return builder.app(rule.visit(),ps.visit()[0]||[]).withInterval(this.interval)},Base_prim:function(expr){return builder.prim(expr.visit()).withInterval(this.interval)},Base_paren:function(open,x,close){return x.visit()},Base_arr:function(open,x,close){return builder.arr(x.visit()).withInterval(this.interval)},Base_str:function(open,x,close){return builder.str(x.visit())},Base_obj:function(open,lenient,close){return builder.obj([],lenient.visit()[0])},Base_objWithProps:function(open,ps,_,lenient,close){return builder.obj(ps.visit(),lenient.visit()[0]).withInterval(this.interval)},Props:function(p,_,ps){return[p.visit()].concat(ps.visit())},Prop:function(n,_,p){return{name:n.visit(),pattern:p.visit()}},ruleDescr:function(open,t,close){return t.visit()},ruleDescrText:function(_){return this.interval.contents.trim()},caseName:function(_,space1,n,space2,end){return n.visit()},name:function(first,rest){return this.interval.contents},nameFirst:function(expr){},nameRest:function(expr){},keyword_null:function(_){return null},keyword_true:function(_){return true},keyword_false:function(_){return false},string:function(open,cs,close){return cs.visit().map(function(c){return common.unescapeChar(c)}).join("")},strChar:function(_){return this.interval.contents},escapeChar:function(_){return this.interval.contents},regExp:function(open,e,close){return e.visit()},reCharClass_unicode:function(open,unicodeClass,close){return UnicodeCategories[unicodeClass.visit().join("")]},reCharClass_ordinary:function(open,_,close){return new RegExp(this.interval.contents)},number:function(_,digits){return parseInt(this.interval.contents)},space:function(expr){},space_multiLine:function(start,_,end){},space_singleLine:function(start,_,end){},ListOf_some:function(x,_,xs){return[x.visit()].concat(xs.visit())},ListOf_none:function(){return[]},_terminal:Semantics.actions.getPrimitiveValue,_default:Semantics.actions.passThrough});return helpers(match).visit()}function compileAndLoad(source,namespace){var m=ohmGrammar.match(source,"Grammars");if(m.failed()){throw new errors.GrammarSyntaxError(m)}return buildGrammar(m,namespace)}function getScriptElementContents(el){if(!isElement(el)){throw new TypeError("Expected a DOM Node, got "+common.unexpectedObjToString(el))}if(el.type!=="text/ohm-js"){throw new Error('Expected a script tag with type="text/ohm-js", got '+el)}return el.getAttribute("src")?load(el.getAttribute("src")):el.innerHTML}function grammar(source,optNamespace){var ns=grammars(source,optNamespace);var grammarNames=Object.keys(ns);if(grammarNames.length===0){throw new Error("Missing grammar definition")}else if(grammarNames.length>1){var secondGrammar=ns[grammarNames[1]];var interval=secondGrammar.definitionInterval;throw new Error(util.getLineAndColumnMessage(interval.inputStream.source,interval.startIdx)+"Found more than one grammar definition -- use ohm.grammars() instead.")}return ns[grammarNames[0]]}function grammars(source,optNamespace){var ns=Namespace.extend(Namespace.asNamespace(optNamespace));if(typeof source!=="string"){if(Buffer&&Buffer.isBuffer(source)){source=source.toString()}else{throw new TypeError("Expected string as first argument, got "+common.unexpectedObjToString(source))}}compileAndLoad(source,ns);return ns}function grammarFromScriptElement(optNode){var node=optNode;if(isUndefined(node)){var nodeList=documentInterface.querySelectorAll('script[type="text/ohm-js"]');if(nodeList.length!==1){throw new Error('Expected exactly one script tag with type="text/ohm-js", found '+nodeList.length)}node=nodeList[0]}return grammar(getScriptElementContents(node))}function grammarsFromScriptElements(optNodeOrNodeList){if(isElement(optNodeOrNodeList)){return grammars(optNodeOrNodeList)}var nodeList=optNodeOrNodeList;if(isUndefined(nodeList)){nodeList=documentInterface.querySelectorAll('script[type="text/ohm-js"]')}else if(typeof nodeList==="string"||!isElement(nodeList)&&!isArrayLike(nodeList)){throw new TypeError("Expected a Node, NodeList, or Array, but got "+nodeList)}var ns=Namespace.createNamespace();for(var i=0;i0};Node.prototype.hasNoChildren=function(){return!this.hasChildren()};Node.prototype.onlyChild=function(){if(this.children.length!==1){throw new Error("cannot get only child of a node of type "+this.ctorName+" (it has "+this.numChildren()+" children)")}else{return this.firstChild()}};Node.prototype.firstChild=function(){if(this.hasNoChildren()){throw new Error("cannot get first child of a "+this.ctorName+" node, which has no children")}else{return this.childAt(0)}};Node.prototype.lastChild=function(){if(this.hasNoChildren()){throw new Error("cannot get last child of a "+this.ctorName+" node, which has no children")}else{return this.childAt(this.numChildren()-1)}};Node.prototype.childBefore=function(child){var childIdx=this.indexOfChild(child);if(childIdx<0){throw new Error("Node.childBefore() called w/ an argument that is not a child")}else if(childIdx===0){throw new Error("cannot get child before first child")}else{return this.childAt(childIdx-1)}};Node.prototype.childAfter=function(child){var childIdx=this.indexOfChild(child);if(childIdx<0){throw new Error("Node.childAfter() called w/ an argument that is not a child")}else if(childIdx===this.numChildren()-1){throw new Error("cannot get child after last child")}else{return this.childAt(childIdx+1)}};Node.prototype.isTerminal=function(){return false};Node.prototype.toJSON=function(){var r={};r[this.ctorName]=this.children;return r};function TerminalNode(grammar,value,interval){Node.call(this,grammar,"_terminal",[],interval);this.primitiveValue=value}inherits(TerminalNode,Node);TerminalNode.prototype.isTerminal=function(){return true};module.exports={Node:Node,TerminalNode:TerminalNode}},{inherits:12}],30:[function(_dereq_,module,exports){"use strict";var common=_dereq_("./common");var pexprs=_dereq_("./pexprs");var errors=_dereq_("./errors");pexprs.PExpr.prototype.assertAllApplicationsAreValid=common.abstract;pexprs.anything.assertAllApplicationsAreValid=function(grammar){};pexprs.end.assertAllApplicationsAreValid=function(grammar){};pexprs.Prim.prototype.assertAllApplicationsAreValid=function(grammar){};pexprs.Param.prototype.assertAllApplicationsAreValid=function(grammar){};pexprs.Alt.prototype.assertAllApplicationsAreValid=function(grammar){for(var idx=0;idx=1};pexprs.end.check=function(grammar,vals){return vals[0]instanceof nodes.Node&&vals[0].isTerminal()&&vals[0].primitiveValue===undefined};pexprs.Prim.prototype.check=function(grammar,vals){return vals[0]instanceof nodes.Node&&vals[0].isTerminal()&&vals[0].primitiveValue===this.obj};pexprs.Param.prototype.check=function(grammar,vals){return vals.length>=1};pexprs.RegExpPrim.prototype.check=function(grammar,vals){return vals[0]instanceof nodes.Node&&vals[0].isTerminal()&&typeof vals[0].primitiveValue==="string"&&vals[0].primitiveValue.replace(this.obj,"")===""};pexprs.Alt.prototype.check=function(grammar,vals){for(var i=0;i1?state.applicationStack[state.applicationStack.length-1].params:[];var app=this.substituteParams(actuals);var ruleName=app.ruleName;var memoKey=app.toMemoKey();if(common.isSyntactic(ruleName)){skipSpaces(state)}var origPosInfo=state.getCurrentPosInfo();var memoRec=origPosInfo.memo[memoKey];var currentLR;if(memoRec&&origPosInfo.shouldUseMemoizedResult(memoRec)){return useMemoizedResult(memoRec)}else if(origPosInfo.isActive(app)){currentLR=origPosInfo.getCurrentLeftRecursion();if(currentLR&¤tLR.memoKey===memoKey){origPosInfo.updateInvolvedApplications();return useMemoizedResult(currentLR)}else{origPosInfo.startLeftRecursion(app);return false}}else{var body=grammar.ruleDict[ruleName];var origPos=inputStream.pos;origPosInfo.enter(app);if(body.description){state.ignoreFailures()}var value=app.evalOnce(body,state,inputStream,origPos);currentLR=origPosInfo.getCurrentLeftRecursion();if(currentLR){if(currentLR.memoKey===memoKey){value=app.handleLeftRecursion(body,state,origPos,currentLR,value);origPosInfo.memo[memoKey]={pos:inputStream.pos,value:value,involvedApplications:currentLR.involvedApplications};origPosInfo.endLeftRecursion(app)}else if(!currentLR.involvedApplications[memoKey]){origPosInfo.memo[memoKey]={pos:inputStream.pos,value:value}}}else{origPosInfo.memo[memoKey]={pos:inputStream.pos,value:value}}if(body.description){state.recordFailures();if(!value){state.recordFailure(origPos,app)}}if(state.isTracing()&&origPosInfo.memo[memoKey]){var entry=state.getTraceEntry(origPos,app,value);entry.setLeftRecursive(currentLR&¤tLR.memoKey===memoKey);origPosInfo.memo[memoKey].traceEntry=entry}var ans;if(value){bindings.push(value);if(state.applicationStack.length===1){if(common.isSyntactic(ruleName)){skipSpaces(state)}ans=pexprs.end.eval(state);bindings.pop()}else{ans=true}}else{ans=false}origPosInfo.exit();return ans}};pexprs.Apply.prototype.evalOnce=function(expr,state,inputStream,origPos){if(expr.eval(state)){var arity=expr.getArity();var bindings=state.bindings.splice(state.bindings.length-arity,arity);var ans=new Node(state.grammar,this.ruleName,bindings,inputStream.intervalFrom(origPos));return ans}else{return false}};pexprs.Apply.prototype.handleLeftRecursion=function(body,state,origPos,currentLR,seedValue){if(!seedValue){return seedValue}var inputStream=state.inputStream;var value=seedValue;currentLR.value=seedValue;currentLR.pos=inputStream.pos;while(true){if(state.isTracing()){currentLR.traceEntry=common.clone(state.trace[state.trace.length-1])}inputStream.pos=origPos;value=this.evalOnce(body,state,inputStream,origPos);if(value&&inputStream.pos>currentLR.pos){currentLR.value=value;currentLR.pos=inputStream.pos}else{inputStream.pos=currentLR.pos;if(state.isTracing()){state.trace.pop()}break}}return currentLR.value}},{"./InputStream":18,"./common":26,"./nodes":29,"./pexprs":44}],35:[function(_dereq_,module,exports){"use strict";var pexprs=_dereq_("./pexprs");pexprs.PExpr.prototype.getArity=function(){return 1};pexprs.Alt.prototype.getArity=function(){return this.terms.length===0?0:this.terms[0].getArity()};pexprs.Seq.prototype.getArity=function(){var arity=0;for(var idx=0;idx=0){if(this.params.length>0){throw new Error("FIXME: should catch this earlier")}return new pexprs.Param(index)}else{this.params.forEach(function(param,idx,params){params[idx]=param.introduceParams(formals)});return this}}},{"./pexprs":44}],37:[function(_dereq_,module,exports){"use strict";var pexprs=_dereq_("./pexprs");pexprs.PExpr.prototype.isNullable=function(grammar){return this._isNullable(grammar,Object.create(null))};pexprs.PExpr.prototype._isNullable=function(grammar,memo){return false};pexprs.end._isNullable=function(grammar,memo){return true};pexprs.StringPrim.prototype._isNullable=function(grammar,memo){return this.obj===""};pexprs.Alt.prototype._isNullable=function(grammar,memo){return this.terms.length===0||this.terms.some(function(term){return term._isNullable(grammar,memo)})};pexprs.Seq.prototype._isNullable=function(grammar,memo){return this.factors.every(function(factor){return factor._isNullable(grammar,memo)})};pexprs.Star.prototype._isNullable=pexprs.Opt.prototype._isNullable=pexprs.Not.prototype._isNullable=pexprs.Lookahead.prototype._isNullable=function(grammar,memo){return true};pexprs.Str.prototype._isNullable=function(grammar,memo){return this.expr._isNullable(grammar,memo)};pexprs.Apply.prototype._isNullable=function(grammar,memo){var key=this.toMemoKey();if(!Object.prototype.hasOwnProperty.call(memo,key)){var body=grammar.ruleDict[this.ruleName];var inlined=body.substituteParams(this.params);memo[key]=false;memo[key]=inlined._isNullable(grammar,memo)}return memo[key]}},{"./pexprs":44}],38:[function(_dereq_,module,exports){"use strict";var pexprs=_dereq_("./pexprs");pexprs.PExpr.prototype.maybeRecordFailure=function(state,startPos){};pexprs.anything.maybeRecordFailure=pexprs.end.maybeRecordFailure=pexprs.Prim.prototype.maybeRecordFailure=pexprs.Not.prototype.maybeRecordFailure=function(state,startPos){state.recordFailure(startPos,this)}},{"./pexprs":44}],39:[function(_dereq_,module,exports){"use strict";var common=_dereq_("./common");var pexprs=_dereq_("./pexprs");pexprs.PExpr.prototype.outputRecipe=common.abstract;pexprs.anything.outputRecipe=function(sb,formals){sb.append("this.anything()")};pexprs.end.outputRecipe=function(sb,formals){sb.append("this.end()")};pexprs.Prim.prototype.outputRecipe=function(sb,formals){sb.append("this.prim(");sb.append(typeof this.obj==="string"?common.toStringLiteral(this.obj):""+this.obj);sb.append(")")};pexprs.Param.prototype.outputRecipe=function(sb,formals){sb.append("this.param("+this.index+")")};pexprs.Alt.prototype.outputRecipe=function(sb,formals){sb.append("this.alt(");for(var idx=0;idx0){sb.append(", ")}this.terms[idx].outputRecipe(sb,formals)}sb.append(")")};pexprs.Seq.prototype.outputRecipe=function(sb,formals){sb.append("this.seq(");for(var idx=0;idx0){sb.append(", ")}this.factors[idx].outputRecipe(sb,formals)}sb.append(")")};pexprs.Star.prototype.outputRecipe=function(sb,formals){sb.append("this.star(");this.expr.outputRecipe(sb,formals);sb.append(")")};pexprs.Plus.prototype.outputRecipe=function(sb,formals){sb.append("this.plus(");this.expr.outputRecipe(sb,formals);sb.append(")")};pexprs.Opt.prototype.outputRecipe=function(sb,formals){sb.append("this.opt(");this.expr.outputRecipe(sb,formals);sb.append(")")};pexprs.Not.prototype.outputRecipe=function(sb,formals){sb.append("this.not(");this.expr.outputRecipe(sb,formals);sb.append(")")};pexprs.Lookahead.prototype.outputRecipe=function(sb,formals){sb.append("this.la(");this.expr.outputRecipe(sb,formals);sb.append(")")};pexprs.Arr.prototype.outputRecipe=function(sb,formals){sb.append("this.arr(");this.expr.outputRecipe(sb,formals);sb.append(")")};pexprs.Str.prototype.outputRecipe=function(sb,formals){sb.append("this.str(");this.expr.outputRecipe(sb,formals);sb.append(")")};pexprs.Obj.prototype.outputRecipe=function(sb,formals){function outputPropertyRecipe(prop){sb.append("{name: ");sb.append(common.toStringLiteral(prop.name));sb.append(", pattern: ");prop.pattern.outputRecipe(sb,formals);sb.append("}")}sb.append("this.obj([");for(var idx=0;idx0){sb.append(", ")}outputPropertyRecipe(this.properties[idx])}sb.append("], ");sb.append(!!this.isLenient);sb.append(")")};pexprs.Apply.prototype.outputRecipe=function(sb,formals){sb.append("this.app(");sb.append(common.toStringLiteral(this.ruleName));if(this.ruleName.indexOf("_")>=0&&formals.length>0){var apps=formals.map(function(formal){return"this.app("+common.toStringLiteral(formal)+")"});sb.append(", ["+apps.join(", ")+"]")}else if(this.params.length>0){sb.append(", [");this.params.forEach(function(param,idx){if(idx>0){sb.append(", ")}param.outputRecipe(sb,formals)});sb.append("]")}sb.append(")")}},{"./common":26,"./pexprs":44}],40:[function(_dereq_,module,exports){"use strict";var pexprs=_dereq_("./pexprs");pexprs.PExpr.prototype.substituteParams=function(actuals){return this};pexprs.Param.prototype.substituteParams=function(actuals){return actuals[this.index]};pexprs.Alt.prototype.substituteParams=function(actuals){return new pexprs.Alt(this.terms.map(function(term){return term.substituteParams(actuals)}))};pexprs.Seq.prototype.substituteParams=function(actuals){return new pexprs.Seq(this.factors.map(function(factor){return factor.substituteParams(actuals)}))};pexprs.Iter.prototype.substituteParams=pexprs.Not.prototype.substituteParams=pexprs.Lookahead.prototype.substituteParams=pexprs.Arr.prototype.substituteParams=pexprs.Str.prototype.substituteParams=function(actuals){return new this.constructor(this.expr.substituteParams(actuals))};pexprs.Obj.prototype.substituteParams=function(actuals){var properties=this.properties.map(function(property){return{name:property.name,pattern:property.pattern.substituteParams(actuals)}});return new pexprs.Obj(properties,this.isLenient)};pexprs.Apply.prototype.substituteParams=function(actuals){if(this.params.length===0){return this}else{var params=this.params.map(function(param){return param.substituteParams(actuals)});return new pexprs.Apply(this.ruleName,params)}}},{"./pexprs":44}],41:[function(_dereq_,module,exports){"use strict";var pexprs=_dereq_("./pexprs");pexprs.PExpr.prototype.toDisplayString=function(){if(this.interval){return this.interval.trimmed().contents}return"["+this.constructor.name+"]"};pexprs.anything.toDisplayString=function(){return"_"};pexprs.end.toDisplayString=function(){return"end"};pexprs.Prim.prototype.toDisplayString=function(){return String(this.obj)};pexprs.Param.prototype.toDisplayString=function(){return"#"+this.index};pexprs.StringPrim.prototype.toDisplayString=function(){return'"'+this.obj+'"'};pexprs.Apply.prototype.toDisplayString=function(){return this.ruleName}},{"./pexprs":44}],42:[function(_dereq_,module,exports){"use strict";var common=_dereq_("./common");var pexprs=_dereq_("./pexprs");pexprs.PExpr.prototype.toExpected=function(ruleDict){return undefined};pexprs.anything.toExpected=function(ruleDict){return"any object"};pexprs.end.toExpected=function(ruleDict){return"end of input"};pexprs.Prim.prototype.toExpected=function(ruleDict){return common.toStringLiteral(this.obj)};pexprs.Not.prototype.toExpected=function(ruleDict){if(this.expr===pexprs.anything){return"nothing"}else{return"not "+this.expr.toExpected(ruleDict)}};pexprs.Apply.prototype.toExpected=function(ruleDict){var description=ruleDict[this.ruleName].description;if(description){return description}else{var article=/^[aeiouAEIOU]/.test(this.ruleName)?"an":"a";return article+" "+this.ruleName}}},{"./common":26,"./pexprs":44}],43:[function(_dereq_,module,exports){"use strict";var common=_dereq_("./common");var pexprs=_dereq_("./pexprs");pexprs.PExpr.prototype.toString=common.abstract;pexprs.anything.toString=function(){return"_"};pexprs.end.toString=function(){return"end"};pexprs.Prim.prototype.toString=function(){return JSON.stringify(this.obj)};pexprs.Param.prototype.toString=function(){return"#"+this.index};pexprs.RegExpPrim.prototype.toString=function(){return this.obj.toString()};pexprs.Alt.prototype.toString=function(){return this.terms.length===1?this.terms[0].toString():"("+this.terms.map(function(term){return term.toString()}).join(" | ")+")"};pexprs.Seq.prototype.toString=function(){return this.factors.length===1?this.factors[0].toString():"("+this.factors.map(function(factor){return factor.toString()}).join(" ")+")"};pexprs.Iter.prototype.toString=function(){return this.expr+this.operator};pexprs.Not.prototype.toString=function(){return"~"+this.expr};pexprs.Lookahead.prototype.toString=function(){return"&"+this.expr};pexprs.Arr.prototype.toString=function(){return"["+this.expr.toString()+"]"};pexprs.Str.prototype.toString=function(){return"``"+this.expr.toString()+"''"};pexprs.Obj.prototype.toString=function(){var parts=["{"];var first=true;function emit(part){if(first){first=false}else{parts.push(", ")}parts.push(part)}this.properties.forEach(function(property){emit(JSON.stringify(property.name)+": "+property.pattern.toString())});if(this.isLenient){emit("...")}parts.push("}");return parts.join("")};pexprs.Apply.prototype.toString=function(){if(this.params.length>0){var ps=this.params.map(function(param){return param.toString()});return this.ruleName+"<"+ps.join(",")+">"}else{return this.ruleName}}},{"./common":26,"./pexprs":44}],44:[function(_dereq_,module,exports){"use strict";var common=_dereq_("./common");var errors=_dereq_("./errors");var inherits=_dereq_("inherits");function PExpr(){throw new Error("PExpr cannot be instantiated -- it's abstract")}PExpr.prototype.withDescription=function(description){this.description=description;return this};PExpr.prototype.withInterval=function(interval){this.interval=interval.trimmed();return this};PExpr.prototype.withFormals=function(formals){this.formals=formals;return this};var anything=Object.create(PExpr.prototype);var end=Object.create(PExpr.prototype);function Prim(obj){this.obj=obj}inherits(Prim,PExpr);function StringPrim(obj){this.obj=obj}inherits(StringPrim,Prim);function RegExpPrim(obj){ -this.obj=obj}inherits(RegExpPrim,Prim);function Param(index){this.index=index}inherits(Param,PExpr);function Alt(terms){this.terms=terms}inherits(Alt,PExpr);function Extend(superGrammar,name,body){var origBody=superGrammar.ruleDict[name];this.terms=[body,origBody]}inherits(Extend,Alt);function Seq(factors){this.factors=factors}inherits(Seq,PExpr);function Iter(expr){this.expr=expr}inherits(Iter,PExpr);function Star(expr){this.expr=expr}inherits(Star,Iter);function Plus(expr){this.expr=expr}inherits(Plus,Iter);function Opt(expr){this.expr=expr}inherits(Opt,Iter);Star.prototype.operator="*";Plus.prototype.operator="+";Opt.prototype.operator="?";Star.prototype.minNumMatches=0;Plus.prototype.minNumMatches=1;Opt.prototype.minNumMatches=0;Star.prototype.maxNumMatches=Number.POSITIVE_INFINITY;Plus.prototype.maxNumMatches=Number.POSITIVE_INFINITY;Opt.prototype.maxNumMatches=1;function Not(expr){this.expr=expr}inherits(Not,PExpr);function Lookahead(expr){this.expr=expr}inherits(Lookahead,PExpr);function Arr(expr){this.expr=expr}inherits(Arr,PExpr);function Str(expr){this.expr=expr}inherits(Str,PExpr);function Obj(properties,isLenient){var names=properties.map(function(property){return property.name});var duplicates=common.getDuplicates(names);if(duplicates.length>0){throw new errors.DuplicatePropertyNames(duplicates)}else{this.properties=properties;this.isLenient=isLenient}}inherits(Obj,PExpr);function Apply(ruleName,optParams){this.ruleName=ruleName;this.params=optParams||[]}inherits(Apply,PExpr);Apply.prototype.toMemoKey=function(){if(!this._memoKey){Object.defineProperty(this,"_memoKey",{value:this.toString()})}return this._memoKey};exports.makePrim=function(obj){if(typeof obj==="string"&&obj.length!==1){return new StringPrim(obj)}else if(obj instanceof RegExp){return new RegExpPrim(obj)}else{return new Prim(obj)}};exports.PExpr=PExpr;exports.anything=anything;exports.end=end;exports.Prim=Prim;exports.StringPrim=StringPrim;exports.RegExpPrim=RegExpPrim;exports.Param=Param;exports.Alt=Alt;exports.Extend=Extend;exports.Seq=Seq;exports.Iter=Iter;exports.Star=Star;exports.Plus=Plus;exports.Opt=Opt;exports.Not=Not;exports.Lookahead=Lookahead;exports.Arr=Arr;exports.Str=Str;exports.Obj=Obj;exports.Apply=Apply;_dereq_("./pexprs-assertAllApplicationsAreValid");_dereq_("./pexprs-assertChoicesHaveUniformArity");_dereq_("./pexprs-assertIteratedExprsAreNotNullable");_dereq_("./pexprs-check");_dereq_("./pexprs-eval");_dereq_("./pexprs-maybeRecordFailure");_dereq_("./pexprs-getArity");_dereq_("./pexprs-outputRecipe");_dereq_("./pexprs-introduceParams");_dereq_("./pexprs-isNullable");_dereq_("./pexprs-substituteParams");_dereq_("./pexprs-toDisplayString");_dereq_("./pexprs-toExpected");_dereq_("./pexprs-toString")},{"./common":26,"./errors":27,"./pexprs-assertAllApplicationsAreValid":30,"./pexprs-assertChoicesHaveUniformArity":31,"./pexprs-assertIteratedExprsAreNotNullable":32,"./pexprs-check":33,"./pexprs-eval":34,"./pexprs-getArity":35,"./pexprs-introduceParams":36,"./pexprs-isNullable":37,"./pexprs-maybeRecordFailure":38,"./pexprs-outputRecipe":39,"./pexprs-substituteParams":40,"./pexprs-toDisplayString":41,"./pexprs-toExpected":42,"./pexprs-toString":43,inherits:12}],45:[function(_dereq_,module,exports){"use strict";var common=_dereq_("./common");function padNumbersToEqualLength(arr){var maxLen=0;var strings=arr.map(function(n){var str=n.toString();maxLen=Math.max(maxLen,str.length);return str});return strings.map(function(s){return common.padLeft(s,maxLen)})}exports.getLineAndColumn=function(str,offset){var lineNum=1;var colNum=1;var currOffset=0;var lineStartOffset=0;var nextLine=null;var prevLine=null;var prevLineStartOffset=-1;while(currOffset=0){prevLine=str.slice(prevLineStartOffset,lineStartOffset).replace(/\r?\n$/,"")}var line=str.slice(lineStartOffset,lineEndOffset).replace(/\r$/,"");return{lineNum:lineNum,colNum:colNum,line:line,prevLine:prevLine,nextLine:nextLine}};exports.getLineAndColumnMessage=function(str,offset){var lineAndCol=exports.getLineAndColumn(str,offset);var sb=new common.StringBuffer;sb.append("Line "+lineAndCol.lineNum+", col "+lineAndCol.colNum+":\n");var lineNumbers=padNumbersToEqualLength([lineAndCol.prevLine==null?0:lineAndCol.lineNum-1,lineAndCol.lineNum,lineAndCol.nextLine==null?0:lineAndCol.lineNum+1]);function appendLine(num,content,prefix){sb.append(prefix+lineNumbers[num]+" | "+content+"\n")}if(lineAndCol.prevLine!=null){appendLine(0,lineAndCol.prevLine," ")}appendLine(1,lineAndCol.line,"> ");var gutterWidth=2+lineNumbers[1].length+3;sb.append(common.padLeft("^",gutterWidth+lineAndCol.colNum)+"\n");if(lineAndCol.nextLine!=null){appendLine(2,lineAndCol.nextLine," ")}return sb.contents()}},{"./common":26}],46:[function(_dereq_,module,exports){exports.UnicodeCategories={ZWNJ:/\u200C/,ZWJ:/\u200D/,TAB:/\u0009/,VT:/\u000B/,FF:/\u000C/,SP:/\u0020/,NBSP:/\u00A0/,BOM:/\uFEFF/,LF:/\u000A/,CR:/\u000D/,LS:/\u2028/,PS:/\u2029/,L:/[\u0041-\u005A]|[\u00C0-\u00D6]|[\u00D8-\u00DE]|[\u0100-\u0100]|[\u0102-\u0102]|[\u0104-\u0104]|[\u0106-\u0106]|[\u0108-\u0108]|[\u010A-\u010A]|[\u010C-\u010C]|[\u010E-\u010E]|[\u0110-\u0110]|[\u0112-\u0112]|[\u0114-\u0114]|[\u0116-\u0116]|[\u0118-\u0118]|[\u011A-\u011A]|[\u011C-\u011C]|[\u011E-\u011E]|[\u0120-\u0120]|[\u0122-\u0122]|[\u0124-\u0124]|[\u0126-\u0126]|[\u0128-\u0128]|[\u012A-\u012A]|[\u012C-\u012C]|[\u012E-\u012E]|[\u0130-\u0130]|[\u0132-\u0132]|[\u0134-\u0134]|[\u0136-\u0136]|[\u0139-\u0139]|[\u013B-\u013B]|[\u013D-\u013D]|[\u013F-\u013F]|[\u0141-\u0141]|[\u0143-\u0143]|[\u0145-\u0145]|[\u0147-\u0147]|[\u014A-\u014A]|[\u014C-\u014C]|[\u014E-\u014E]|[\u0150-\u0150]|[\u0152-\u0152]|[\u0154-\u0154]|[\u0156-\u0156]|[\u0158-\u0158]|[\u015A-\u015A]|[\u015C-\u015C]|[\u015E-\u015E]|[\u0160-\u0160]|[\u0162-\u0162]|[\u0164-\u0164]|[\u0166-\u0166]|[\u0168-\u0168]|[\u016A-\u016A]|[\u016C-\u016C]|[\u016E-\u016E]|[\u0170-\u0170]|[\u0172-\u0172]|[\u0174-\u0174]|[\u0176-\u0176]|[\u0178-\u0179]|[\u017B-\u017B]|[\u017D-\u017D]|[\u0181-\u0182]|[\u0184-\u0184]|[\u0186-\u0187]|[\u0189-\u018B]|[\u018E-\u0191]|[\u0193-\u0194]|[\u0196-\u0198]|[\u019C-\u019D]|[\u019F-\u01A0]|[\u01A2-\u01A2]|[\u01A4-\u01A4]|[\u01A6-\u01A7]|[\u01A9-\u01A9]|[\u01AC-\u01AC]|[\u01AE-\u01AF]|[\u01B1-\u01B3]|[\u01B5-\u01B5]|[\u01B7-\u01B8]|[\u01BC-\u01BC]|[\u01C4-\u01C4]|[\u01C7-\u01C7]|[\u01CA-\u01CA]|[\u01CD-\u01CD]|[\u01CF-\u01CF]|[\u01D1-\u01D1]|[\u01D3-\u01D3]|[\u01D5-\u01D5]|[\u01D7-\u01D7]|[\u01D9-\u01D9]|[\u01DB-\u01DB]|[\u01DE-\u01DE]|[\u01E0-\u01E0]|[\u01E2-\u01E2]|[\u01E4-\u01E4]|[\u01E6-\u01E6]|[\u01E8-\u01E8]|[\u01EA-\u01EA]|[\u01EC-\u01EC]|[\u01EE-\u01EE]|[\u01F1-\u01F1]|[\u01F4-\u01F4]|[\u01FA-\u01FA]|[\u01FC-\u01FC]|[\u01FE-\u01FE]|[\u0200-\u0200]|[\u0202-\u0202]|[\u0204-\u0204]|[\u0206-\u0206]|[\u0208-\u0208]|[\u020A-\u020A]|[\u020C-\u020C]|[\u020E-\u020E]|[\u0210-\u0210]|[\u0212-\u0212]|[\u0214-\u0214]|[\u0216-\u0216]|[\u0386-\u0386]|[\u0388-\u038A]|[\u038C-\u038C]|[\u038E-\u038F]|[\u0391-\u03A1]|[\u03A3-\u03AB]|[\u03D2-\u03D4]|[\u03DA-\u03DA]|[\u03DC-\u03DC]|[\u03DE-\u03DE]|[\u03E0-\u03E0]|[\u03E2-\u03E2]|[\u03E4-\u03E4]|[\u03E6-\u03E6]|[\u03E8-\u03E8]|[\u03EA-\u03EA]|[\u03EC-\u03EC]|[\u03EE-\u03EE]|[\u0401-\u040C]|[\u040E-\u042F]|[\u0460-\u0460]|[\u0462-\u0462]|[\u0464-\u0464]|[\u0466-\u0466]|[\u0468-\u0468]|[\u046A-\u046A]|[\u046C-\u046C]|[\u046E-\u046E]|[\u0470-\u0470]|[\u0472-\u0472]|[\u0474-\u0474]|[\u0476-\u0476]|[\u0478-\u0478]|[\u047A-\u047A]|[\u047C-\u047C]|[\u047E-\u047E]|[\u0480-\u0480]|[\u0490-\u0490]|[\u0492-\u0492]|[\u0494-\u0494]|[\u0496-\u0496]|[\u0498-\u0498]|[\u049A-\u049A]|[\u049C-\u049C]|[\u049E-\u049E]|[\u04A0-\u04A0]|[\u04A2-\u04A2]|[\u04A4-\u04A4]|[\u04A6-\u04A6]|[\u04A8-\u04A8]|[\u04AA-\u04AA]|[\u04AC-\u04AC]|[\u04AE-\u04AE]|[\u04B0-\u04B0]|[\u04B2-\u04B2]|[\u04B4-\u04B4]|[\u04B6-\u04B6]|[\u04B8-\u04B8]|[\u04BA-\u04BA]|[\u04BC-\u04BC]|[\u04BE-\u04BE]|[\u04C1-\u04C1]|[\u04C3-\u04C3]|[\u04C7-\u04C7]|[\u04CB-\u04CB]|[\u04D0-\u04D0]|[\u04D2-\u04D2]|[\u04D4-\u04D4]|[\u04D6-\u04D6]|[\u04D8-\u04D8]|[\u04DA-\u04DA]|[\u04DC-\u04DC]|[\u04DE-\u04DE]|[\u04E0-\u04E0]|[\u04E2-\u04E2]|[\u04E4-\u04E4]|[\u04E6-\u04E6]|[\u04E8-\u04E8]|[\u04EA-\u04EA]|[\u04EE-\u04EE]|[\u04F0-\u04F0]|[\u04F2-\u04F2]|[\u04F4-\u04F4]|[\u04F8-\u04F8]|[\u0531-\u0556]|[\u10A0-\u10C5]|[\u1E00-\u1E00]|[\u1E02-\u1E02]|[\u1E04-\u1E04]|[\u1E06-\u1E06]|[\u1E08-\u1E08]|[\u1E0A-\u1E0A]|[\u1E0C-\u1E0C]|[\u1E0E-\u1E0E]|[\u1E10-\u1E10]|[\u1E12-\u1E12]|[\u1E14-\u1E14]|[\u1E16-\u1E16]|[\u1E18-\u1E18]|[\u1E1A-\u1E1A]|[\u1E1C-\u1E1C]|[\u1E1E-\u1E1E]|[\u1E20-\u1E20]|[\u1E22-\u1E22]|[\u1E24-\u1E24]|[\u1E26-\u1E26]|[\u1E28-\u1E28]|[\u1E2A-\u1E2A]|[\u1E2C-\u1E2C]|[\u1E2E-\u1E2E]|[\u1E30-\u1E30]|[\u1E32-\u1E32]|[\u1E34-\u1E34]|[\u1E36-\u1E36]|[\u1E38-\u1E38]|[\u1E3A-\u1E3A]|[\u1E3C-\u1E3C]|[\u1E3E-\u1E3E]|[\u1E40-\u1E40]|[\u1E42-\u1E42]|[\u1E44-\u1E44]|[\u1E46-\u1E46]|[\u1E48-\u1E48]|[\u1E4A-\u1E4A]|[\u1E4C-\u1E4C]|[\u1E4E-\u1E4E]|[\u1E50-\u1E50]|[\u1E52-\u1E52]|[\u1E54-\u1E54]|[\u1E56-\u1E56]|[\u1E58-\u1E58]|[\u1E5A-\u1E5A]|[\u1E5C-\u1E5C]|[\u1E5E-\u1E5E]|[\u1E60-\u1E60]|[\u1E62-\u1E62]|[\u1E64-\u1E64]|[\u1E66-\u1E66]|[\u1E68-\u1E68]|[\u1E6A-\u1E6A]|[\u1E6C-\u1E6C]|[\u1E6E-\u1E6E]|[\u1E70-\u1E70]|[\u1E72-\u1E72]|[\u1E74-\u1E74]|[\u1E76-\u1E76]|[\u1E78-\u1E78]|[\u1E7A-\u1E7A]|[\u1E7C-\u1E7C]|[\u1E7E-\u1E7E]|[\u1E80-\u1E80]|[\u1E82-\u1E82]|[\u1E84-\u1E84]|[\u1E86-\u1E86]|[\u1E88-\u1E88]|[\u1E8A-\u1E8A]|[\u1E8C-\u1E8C]|[\u1E8E-\u1E8E]|[\u1E90-\u1E90]|[\u1E92-\u1E92]|[\u1E94-\u1E94]|[\u1EA0-\u1EA0]|[\u1EA2-\u1EA2]|[\u1EA4-\u1EA4]|[\u1EA6-\u1EA6]|[\u1EA8-\u1EA8]|[\u1EAA-\u1EAA]|[\u1EAC-\u1EAC]|[\u1EAE-\u1EAE]|[\u1EB0-\u1EB0]|[\u1EB2-\u1EB2]|[\u1EB4-\u1EB4]|[\u1EB6-\u1EB6]|[\u1EB8-\u1EB8]|[\u1EBA-\u1EBA]|[\u1EBC-\u1EBC]|[\u1EBE-\u1EBE]|[\u1EC0-\u1EC0]|[\u1EC2-\u1EC2]|[\u1EC4-\u1EC4]|[\u1EC6-\u1EC6]|[\u1EC8-\u1EC8]|[\u1ECA-\u1ECA]|[\u1ECC-\u1ECC]|[\u1ECE-\u1ECE]|[\u1ED0-\u1ED0]|[\u1ED2-\u1ED2]|[\u1ED4-\u1ED4]|[\u1ED6-\u1ED6]|[\u1ED8-\u1ED8]|[\u1EDA-\u1EDA]|[\u1EDC-\u1EDC]|[\u1EDE-\u1EDE]|[\u1EE0-\u1EE0]|[\u1EE2-\u1EE2]|[\u1EE4-\u1EE4]|[\u1EE6-\u1EE6]|[\u1EE8-\u1EE8]|[\u1EEA-\u1EEA]|[\u1EEC-\u1EEC]|[\u1EEE-\u1EEE]|[\u1EF0-\u1EF0]|[\u1EF2-\u1EF2]|[\u1EF4-\u1EF4]|[\u1EF6-\u1EF6]|[\u1EF8-\u1EF8]|[\u1F08-\u1F0F]|[\u1F18-\u1F1D]|[\u1F28-\u1F2F]|[\u1F38-\u1F3F]|[\u1F48-\u1F4D]|[\u1F59-\u1F59]|[\u1F5B-\u1F5B]|[\u1F5D-\u1F5D]|[\u1F5F-\u1F5F]|[\u1F68-\u1F6F]|[\u1F88-\u1F8F]|[\u1F98-\u1F9F]|[\u1FA8-\u1FAF]|[\u1FB8-\u1FBC]|[\u1FC8-\u1FCC]|[\u1FD8-\u1FDB]|[\u1FE8-\u1FEC]|[\u1FF8-\u1FFC]|[\u2102-\u2102]|[\u2107-\u2107]|[\u210B-\u210D]|[\u2110-\u2112]|[\u2115-\u2115]|[\u2119-\u211D]|[\u2124-\u2124]|[\u2126-\u2126]|[\u2128-\u2128]|[\u212A-\u212D]|[\u2130-\u2131]|[\u2133-\u2133]|[\uFF21-\uFF3A]|[\u0061-\u007A]|[\u00AA-\u00AA]|[\u00B5-\u00B5]|[\u00BA-\u00BA]|[\u00DF-\u00F6]|[\u00F8-\u00FF]|[\u0101-\u0101]|[\u0103-\u0103]|[\u0105-\u0105]|[\u0107-\u0107]|[\u0109-\u0109]|[\u010B-\u010B]|[\u010D-\u010D]|[\u010F-\u010F]|[\u0111-\u0111]|[\u0113-\u0113]|[\u0115-\u0115]|[\u0117-\u0117]|[\u0119-\u0119]|[\u011B-\u011B]|[\u011D-\u011D]|[\u011F-\u011F]|[\u0121-\u0121]|[\u0123-\u0123]|[\u0125-\u0125]|[\u0127-\u0127]|[\u0129-\u0129]|[\u012B-\u012B]|[\u012D-\u012D]|[\u012F-\u012F]|[\u0131-\u0131]|[\u0133-\u0133]|[\u0135-\u0135]|[\u0137-\u0138]|[\u013A-\u013A]|[\u013C-\u013C]|[\u013E-\u013E]|[\u0140-\u0140]|[\u0142-\u0142]|[\u0144-\u0144]|[\u0146-\u0146]|[\u0148-\u0149]|[\u014B-\u014B]|[\u014D-\u014D]|[\u014F-\u014F]|[\u0151-\u0151]|[\u0153-\u0153]|[\u0155-\u0155]|[\u0157-\u0157]|[\u0159-\u0159]|[\u015B-\u015B]|[\u015D-\u015D]|[\u015F-\u015F]|[\u0161-\u0161]|[\u0163-\u0163]|[\u0165-\u0165]|[\u0167-\u0167]|[\u0169-\u0169]|[\u016B-\u016B]|[\u016D-\u016D]|[\u016F-\u016F]|[\u0171-\u0171]|[\u0173-\u0173]|[\u0175-\u0175]|[\u0177-\u0177]|[\u017A-\u017A]|[\u017C-\u017C]|[\u017E-\u0180]|[\u0183-\u0183]|[\u0185-\u0185]|[\u0188-\u0188]|[\u018C-\u018D]|[\u0192-\u0192]|[\u0195-\u0195]|[\u0199-\u019B]|[\u019E-\u019E]|[\u01A1-\u01A1]|[\u01A3-\u01A3]|[\u01A5-\u01A5]|[\u01A8-\u01A8]|[\u01AB-\u01AB]|[\u01AD-\u01AD]|[\u01B0-\u01B0]|[\u01B4-\u01B4]|[\u01B6-\u01B6]|[\u01B9-\u01BA]|[\u01BD-\u01BD]|[\u01C6-\u01C6]|[\u01C9-\u01C9]|[\u01CC-\u01CC]|[\u01CE-\u01CE]|[\u01D0-\u01D0]|[\u01D2-\u01D2]|[\u01D4-\u01D4]|[\u01D6-\u01D6]|[\u01D8-\u01D8]|[\u01DA-\u01DA]|[\u01DC-\u01DD]|[\u01DF-\u01DF]|[\u01E1-\u01E1]|[\u01E3-\u01E3]|[\u01E5-\u01E5]|[\u01E7-\u01E7]|[\u01E9-\u01E9]|[\u01EB-\u01EB]|[\u01ED-\u01ED]|[\u01EF-\u01F0]|[\u01F3-\u01F3]|[\u01F5-\u01F5]|[\u01FB-\u01FB]|[\u01FD-\u01FD]|[\u01FF-\u01FF]|[\u0201-\u0201]|[\u0203-\u0203]|[\u0205-\u0205]|[\u0207-\u0207]|[\u0209-\u0209]|[\u020B-\u020B]|[\u020D-\u020D]|[\u020F-\u020F]|[\u0211-\u0211]|[\u0213-\u0213]|[\u0215-\u0215]|[\u0217-\u0217]|[\u0250-\u02A8]|[\u0390-\u0390]|[\u03AC-\u03CE]|[\u03D0-\u03D1]|[\u03D5-\u03D6]|[\u03E3-\u03E3]|[\u03E5-\u03E5]|[\u03E7-\u03E7]|[\u03E9-\u03E9]|[\u03EB-\u03EB]|[\u03ED-\u03ED]|[\u03EF-\u03F2]|[\u0430-\u044F]|[\u0451-\u045C]|[\u045E-\u045F]|[\u0461-\u0461]|[\u0463-\u0463]|[\u0465-\u0465]|[\u0467-\u0467]|[\u0469-\u0469]|[\u046B-\u046B]|[\u046D-\u046D]|[\u046F-\u046F]|[\u0471-\u0471]|[\u0473-\u0473]|[\u0475-\u0475]|[\u0477-\u0477]|[\u0479-\u0479]|[\u047B-\u047B]|[\u047D-\u047D]|[\u047F-\u047F]|[\u0481-\u0481]|[\u0491-\u0491]|[\u0493-\u0493]|[\u0495-\u0495]|[\u0497-\u0497]|[\u0499-\u0499]|[\u049B-\u049B]|[\u049D-\u049D]|[\u049F-\u049F]|[\u04A1-\u04A1]|[\u04A3-\u04A3]|[\u04A5-\u04A5]|[\u04A7-\u04A7]|[\u04A9-\u04A9]|[\u04AB-\u04AB]|[\u04AD-\u04AD]|[\u04AF-\u04AF]|[\u04B1-\u04B1]|[\u04B3-\u04B3]|[\u04B5-\u04B5]|[\u04B7-\u04B7]|[\u04B9-\u04B9]|[\u04BB-\u04BB]|[\u04BD-\u04BD]|[\u04BF-\u04BF]|[\u04C2-\u04C2]|[\u04C4-\u04C4]|[\u04C8-\u04C8]|[\u04CC-\u04CC]|[\u04D1-\u04D1]|[\u04D3-\u04D3]|[\u04D5-\u04D5]|[\u04D7-\u04D7]|[\u04D9-\u04D9]|[\u04DB-\u04DB]|[\u04DD-\u04DD]|[\u04DF-\u04DF]|[\u04E1-\u04E1]|[\u04E3-\u04E3]|[\u04E5-\u04E5]|[\u04E7-\u04E7]|[\u04E9-\u04E9]|[\u04EB-\u04EB]|[\u04EF-\u04EF]|[\u04F1-\u04F1]|[\u04F3-\u04F3]|[\u04F5-\u04F5]|[\u04F9-\u04F9]|[\u0561-\u0587]|[\u10D0-\u10F6]|[\u1E01-\u1E01]|[\u1E03-\u1E03]|[\u1E05-\u1E05]|[\u1E07-\u1E07]|[\u1E09-\u1E09]|[\u1E0B-\u1E0B]|[\u1E0D-\u1E0D]|[\u1E0F-\u1E0F]|[\u1E11-\u1E11]|[\u1E13-\u1E13]|[\u1E15-\u1E15]|[\u1E17-\u1E17]|[\u1E19-\u1E19]|[\u1E1B-\u1E1B]|[\u1E1D-\u1E1D]|[\u1E1F-\u1E1F]|[\u1E21-\u1E21]|[\u1E23-\u1E23]|[\u1E25-\u1E25]|[\u1E27-\u1E27]|[\u1E29-\u1E29]|[\u1E2B-\u1E2B]|[\u1E2D-\u1E2D]|[\u1E2F-\u1E2F]|[\u1E31-\u1E31]|[\u1E33-\u1E33]|[\u1E35-\u1E35]|[\u1E37-\u1E37]|[\u1E39-\u1E39]|[\u1E3B-\u1E3B]|[\u1E3D-\u1E3D]|[\u1E3F-\u1E3F]|[\u1E41-\u1E41]|[\u1E43-\u1E43]|[\u1E45-\u1E45]|[\u1E47-\u1E47]|[\u1E49-\u1E49]|[\u1E4B-\u1E4B]|[\u1E4D-\u1E4D]|[\u1E4F-\u1E4F]|[\u1E51-\u1E51]|[\u1E53-\u1E53]|[\u1E55-\u1E55]|[\u1E57-\u1E57]|[\u1E59-\u1E59]|[\u1E5B-\u1E5B]|[\u1E5D-\u1E5D]|[\u1E5F-\u1E5F]|[\u1E61-\u1E61]|[\u1E63-\u1E63]|[\u1E65-\u1E65]|[\u1E67-\u1E67]|[\u1E69-\u1E69]|[\u1E6B-\u1E6B]|[\u1E6D-\u1E6D]|[\u1E6F-\u1E6F]|[\u1E71-\u1E71]|[\u1E73-\u1E73]|[\u1E75-\u1E75]|[\u1E77-\u1E77]|[\u1E79-\u1E79]|[\u1E7B-\u1E7B]|[\u1E7D-\u1E7D]|[\u1E7F-\u1E7F]|[\u1E81-\u1E81]|[\u1E83-\u1E83]|[\u1E85-\u1E85]|[\u1E87-\u1E87]|[\u1E89-\u1E89]|[\u1E8B-\u1E8B]|[\u1E8D-\u1E8D]|[\u1E8F-\u1E8F]|[\u1E91-\u1E91]|[\u1E93-\u1E93]|[\u1E95-\u1E9B]|[\u1EA1-\u1EA1]|[\u1EA3-\u1EA3]|[\u1EA5-\u1EA5]|[\u1EA7-\u1EA7]|[\u1EA9-\u1EA9]|[\u1EAB-\u1EAB]|[\u1EAD-\u1EAD]|[\u1EAF-\u1EAF]|[\u1EB1-\u1EB1]|[\u1EB3-\u1EB3]|[\u1EB5-\u1EB5]|[\u1EB7-\u1EB7]|[\u1EB9-\u1EB9]|[\u1EBB-\u1EBB]|[\u1EBD-\u1EBD]|[\u1EBF-\u1EBF]|[\u1EC1-\u1EC1]|[\u1EC3-\u1EC3]|[\u1EC5-\u1EC5]|[\u1EC7-\u1EC7]|[\u1EC9-\u1EC9]|[\u1ECB-\u1ECB]|[\u1ECD-\u1ECD]|[\u1ECF-\u1ECF]|[\u1ED1-\u1ED1]|[\u1ED3-\u1ED3]|[\u1ED5-\u1ED5]|[\u1ED7-\u1ED7]|[\u1ED9-\u1ED9]|[\u1EDB-\u1EDB]|[\u1EDD-\u1EDD]|[\u1EDF-\u1EDF]|[\u1EE1-\u1EE1]|[\u1EE3-\u1EE3]|[\u1EE5-\u1EE5]|[\u1EE7-\u1EE7]|[\u1EE9-\u1EE9]|[\u1EEB-\u1EEB]|[\u1EED-\u1EED]|[\u1EEF-\u1EEF]|[\u1EF1-\u1EF1]|[\u1EF3-\u1EF3]|[\u1EF5-\u1EF5]|[\u1EF7-\u1EF7]|[\u1EF9-\u1EF9]|[\u1F00-\u1F07]|[\u1F10-\u1F15]|[\u1F20-\u1F27]|[\u1F30-\u1F37]|[\u1F40-\u1F45]|[\u1F50-\u1F57]|[\u1F60-\u1F67]|[\u1F70-\u1F7D]|[\u1F80-\u1F87]|[\u1F90-\u1F97]|[\u1FA0-\u1FA7]|[\u1FB0-\u1FB4]|[\u1FB6-\u1FB7]|[\u1FBE-\u1FBE]|[\u1FC2-\u1FC4]|[\u1FC6-\u1FC7]|[\u1FD0-\u1FD3]|[\u1FD6-\u1FD7]|[\u1FE0-\u1FE7]|[\u1FF2-\u1FF4]|[\u1FF6-\u1FF7]|[\u207F-\u207F]|[\u210A-\u210A]|[\u210E-\u210F]|[\u2113-\u2113]|[\u2118-\u2118]|[\u212E-\u212F]|[\u2134-\u2134]|[\uFB00-\uFB06]|[\uFB13-\uFB17]|[\uFF41-\uFF5A]|[\u01C5-\u01C5]|[\u01C8-\u01C8]|[\u01CB-\u01CB]|[\u01F2-\u01F2]|[\u02B0-\u02B8]|[\u02BB-\u02C1]|[\u02D0-\u02D1]|[\u02E0-\u02E4]|[\u037A-\u037A]|[\u0559-\u0559]|[\u0640-\u0640]|[\u06E5-\u06E6]|[\u0E46-\u0E46]|[\u0EC6-\u0EC6]|[\u3005-\u3005]|[\u3031-\u3035]|[\u309D-\u309E]|[\u30FC-\u30FE]|[\uFF70-\uFF70]|[\uFF9E-\uFF9F]|[\u01AA-\u01AA]|[\u01BB-\u01BB]|[\u01BE-\u01C3]|[\u03F3-\u03F3]|[\u04C0-\u04C0]|[\u05D0-\u05EA]|[\u05F0-\u05F2]|[\u0621-\u063A]|[\u0641-\u064A]|[\u0671-\u06B7]|[\u06BA-\u06BE]|[\u06C0-\u06CE]|[\u06D0-\u06D3]|[\u06D5-\u06D5]|[\u0905-\u0939]|[\u093D-\u093D]|[\u0950-\u0950]|[\u0958-\u0961]|[\u0985-\u098C]|[\u098F-\u0990]|[\u0993-\u09A8]|[\u09AA-\u09B0]|[\u09B2-\u09B2]|[\u09B6-\u09B9]|[\u09DC-\u09DD]|[\u09DF-\u09E1]|[\u09F0-\u09F1]|[\u0A05-\u0A0A]|[\u0A0F-\u0A10]|[\u0A13-\u0A28]|[\u0A2A-\u0A30]|[\u0A32-\u0A33]|[\u0A35-\u0A36]|[\u0A38-\u0A39]|[\u0A59-\u0A5C]|[\u0A5E-\u0A5E]|[\u0A72-\u0A74]|[\u0A85-\u0A8B]|[\u0A8D-\u0A8D]|[\u0A8F-\u0A91]|[\u0A93-\u0AA8]|[\u0AAA-\u0AB0]|[\u0AB2-\u0AB3]|[\u0AB5-\u0AB9]|[\u0ABD-\u0ABD]|[\u0AD0-\u0AD0]|[\u0AE0-\u0AE0]|[\u0B05-\u0B0C]|[\u0B0F-\u0B10]|[\u0B13-\u0B28]|[\u0B2A-\u0B30]|[\u0B32-\u0B33]|[\u0B36-\u0B39]|[\u0B3D-\u0B3D]|[\u0B5C-\u0B5D]|[\u0B5F-\u0B61]|[\u0B85-\u0B8A]|[\u0B8E-\u0B90]|[\u0B92-\u0B95]|[\u0B99-\u0B9A]|[\u0B9C-\u0B9C]|[\u0B9E-\u0B9F]|[\u0BA3-\u0BA4]|[\u0BA8-\u0BAA]|[\u0BAE-\u0BB5]|[\u0BB7-\u0BB9]|[\u0C05-\u0C0C]|[\u0C0E-\u0C10]|[\u0C12-\u0C28]|[\u0C2A-\u0C33]|[\u0C35-\u0C39]|[\u0C60-\u0C61]|[\u0C85-\u0C8C]|[\u0C8E-\u0C90]|[\u0C92-\u0CA8]|[\u0CAA-\u0CB3]|[\u0CB5-\u0CB9]|[\u0CDE-\u0CDE]|[\u0CE0-\u0CE1]|[\u0D05-\u0D0C]|[\u0D0E-\u0D10]|[\u0D12-\u0D28]|[\u0D2A-\u0D39]|[\u0D60-\u0D61]|[\u0E01-\u0E30]|[\u0E32-\u0E33]|[\u0E40-\u0E45]|[\u0E81-\u0E82]|[\u0E84-\u0E84]|[\u0E87-\u0E88]|[\u0E8A-\u0E8A]|[\u0E8D-\u0E8D]|[\u0E94-\u0E97]|[\u0E99-\u0E9F]|[\u0EA1-\u0EA3]|[\u0EA5-\u0EA5]|[\u0EA7-\u0EA7]|[\u0EAA-\u0EAB]|[\u0EAD-\u0EB0]|[\u0EB2-\u0EB3]|[\u0EBD-\u0EBD]|[\u0EC0-\u0EC4]|[\u0EDC-\u0EDD]|[\u0F00-\u0F00]|[\u0F40-\u0F47]|[\u0F49-\u0F69]|[\u0F88-\u0F8B]|[\u1100-\u1159]|[\u115F-\u11A2]|[\u11A8-\u11F9]|[\u2135-\u2138]|[\u3006-\u3006]|[\u3041-\u3094]|[\u30A1-\u30FA]|[\u3105-\u312C]|[\u3131-\u318E]|[\u4E00-\u9FA5]|[\uAC00-\uD7A3]|[\uF900-\uFA2D]|[\uFB1F-\uFB28]|[\uFB2A-\uFB36]|[\uFB38-\uFB3C]|[\uFB3E-\uFB3E]|[\uFB40-\uFB41]|[\uFB43-\uFB44]|[\uFB46-\uFBB1]|[\uFBD3-\uFD3D]|[\uFD50-\uFD8F]|[\uFD92-\uFDC7]|[\uFDF0-\uFDFB]|[\uFE70-\uFE72]|[\uFE74-\uFE74]|[\uFE76-\uFEFC]|[\uFF66-\uFF6F]|[\uFF71-\uFF9D]|[\uFFA0-\uFFBE]|[\uFFC2-\uFFC7]|[\uFFCA-\uFFCF]|[\uFFD2-\uFFD7]|[\uFFDA-\uFFDC]/,Lu:/[\u0041-\u005A]|[\u00C0-\u00D6]|[\u00D8-\u00DE]|[\u0100-\u0100]|[\u0102-\u0102]|[\u0104-\u0104]|[\u0106-\u0106]|[\u0108-\u0108]|[\u010A-\u010A]|[\u010C-\u010C]|[\u010E-\u010E]|[\u0110-\u0110]|[\u0112-\u0112]|[\u0114-\u0114]|[\u0116-\u0116]|[\u0118-\u0118]|[\u011A-\u011A]|[\u011C-\u011C]|[\u011E-\u011E]|[\u0120-\u0120]|[\u0122-\u0122]|[\u0124-\u0124]|[\u0126-\u0126]|[\u0128-\u0128]|[\u012A-\u012A]|[\u012C-\u012C]|[\u012E-\u012E]|[\u0130-\u0130]|[\u0132-\u0132]|[\u0134-\u0134]|[\u0136-\u0136]|[\u0139-\u0139]|[\u013B-\u013B]|[\u013D-\u013D]|[\u013F-\u013F]|[\u0141-\u0141]|[\u0143-\u0143]|[\u0145-\u0145]|[\u0147-\u0147]|[\u014A-\u014A]|[\u014C-\u014C]|[\u014E-\u014E]|[\u0150-\u0150]|[\u0152-\u0152]|[\u0154-\u0154]|[\u0156-\u0156]|[\u0158-\u0158]|[\u015A-\u015A]|[\u015C-\u015C]|[\u015E-\u015E]|[\u0160-\u0160]|[\u0162-\u0162]|[\u0164-\u0164]|[\u0166-\u0166]|[\u0168-\u0168]|[\u016A-\u016A]|[\u016C-\u016C]|[\u016E-\u016E]|[\u0170-\u0170]|[\u0172-\u0172]|[\u0174-\u0174]|[\u0176-\u0176]|[\u0178-\u0179]|[\u017B-\u017B]|[\u017D-\u017D]|[\u0181-\u0182]|[\u0184-\u0184]|[\u0186-\u0187]|[\u0189-\u018B]|[\u018E-\u0191]|[\u0193-\u0194]|[\u0196-\u0198]|[\u019C-\u019D]|[\u019F-\u01A0]|[\u01A2-\u01A2]|[\u01A4-\u01A4]|[\u01A6-\u01A7]|[\u01A9-\u01A9]|[\u01AC-\u01AC]|[\u01AE-\u01AF]|[\u01B1-\u01B3]|[\u01B5-\u01B5]|[\u01B7-\u01B8]|[\u01BC-\u01BC]|[\u01C4-\u01C4]|[\u01C7-\u01C7]|[\u01CA-\u01CA]|[\u01CD-\u01CD]|[\u01CF-\u01CF]|[\u01D1-\u01D1]|[\u01D3-\u01D3]|[\u01D5-\u01D5]|[\u01D7-\u01D7]|[\u01D9-\u01D9]|[\u01DB-\u01DB]|[\u01DE-\u01DE]|[\u01E0-\u01E0]|[\u01E2-\u01E2]|[\u01E4-\u01E4]|[\u01E6-\u01E6]|[\u01E8-\u01E8]|[\u01EA-\u01EA]|[\u01EC-\u01EC]|[\u01EE-\u01EE]|[\u01F1-\u01F1]|[\u01F4-\u01F4]|[\u01FA-\u01FA]|[\u01FC-\u01FC]|[\u01FE-\u01FE]|[\u0200-\u0200]|[\u0202-\u0202]|[\u0204-\u0204]|[\u0206-\u0206]|[\u0208-\u0208]|[\u020A-\u020A]|[\u020C-\u020C]|[\u020E-\u020E]|[\u0210-\u0210]|[\u0212-\u0212]|[\u0214-\u0214]|[\u0216-\u0216]|[\u0386-\u0386]|[\u0388-\u038A]|[\u038C-\u038C]|[\u038E-\u038F]|[\u0391-\u03A1]|[\u03A3-\u03AB]|[\u03D2-\u03D4]|[\u03DA-\u03DA]|[\u03DC-\u03DC]|[\u03DE-\u03DE]|[\u03E0-\u03E0]|[\u03E2-\u03E2]|[\u03E4-\u03E4]|[\u03E6-\u03E6]|[\u03E8-\u03E8]|[\u03EA-\u03EA]|[\u03EC-\u03EC]|[\u03EE-\u03EE]|[\u0401-\u040C]|[\u040E-\u042F]|[\u0460-\u0460]|[\u0462-\u0462]|[\u0464-\u0464]|[\u0466-\u0466]|[\u0468-\u0468]|[\u046A-\u046A]|[\u046C-\u046C]|[\u046E-\u046E]|[\u0470-\u0470]|[\u0472-\u0472]|[\u0474-\u0474]|[\u0476-\u0476]|[\u0478-\u0478]|[\u047A-\u047A]|[\u047C-\u047C]|[\u047E-\u047E]|[\u0480-\u0480]|[\u0490-\u0490]|[\u0492-\u0492]|[\u0494-\u0494]|[\u0496-\u0496]|[\u0498-\u0498]|[\u049A-\u049A]|[\u049C-\u049C]|[\u049E-\u049E]|[\u04A0-\u04A0]|[\u04A2-\u04A2]|[\u04A4-\u04A4]|[\u04A6-\u04A6]|[\u04A8-\u04A8]|[\u04AA-\u04AA]|[\u04AC-\u04AC]|[\u04AE-\u04AE]|[\u04B0-\u04B0]|[\u04B2-\u04B2]|[\u04B4-\u04B4]|[\u04B6-\u04B6]|[\u04B8-\u04B8]|[\u04BA-\u04BA]|[\u04BC-\u04BC]|[\u04BE-\u04BE]|[\u04C1-\u04C1]|[\u04C3-\u04C3]|[\u04C7-\u04C7]|[\u04CB-\u04CB]|[\u04D0-\u04D0]|[\u04D2-\u04D2]|[\u04D4-\u04D4]|[\u04D6-\u04D6]|[\u04D8-\u04D8]|[\u04DA-\u04DA]|[\u04DC-\u04DC]|[\u04DE-\u04DE]|[\u04E0-\u04E0]|[\u04E2-\u04E2]|[\u04E4-\u04E4]|[\u04E6-\u04E6]|[\u04E8-\u04E8]|[\u04EA-\u04EA]|[\u04EE-\u04EE]|[\u04F0-\u04F0]|[\u04F2-\u04F2]|[\u04F4-\u04F4]|[\u04F8-\u04F8]|[\u0531-\u0556]|[\u10A0-\u10C5]|[\u1E00-\u1E00]|[\u1E02-\u1E02]|[\u1E04-\u1E04]|[\u1E06-\u1E06]|[\u1E08-\u1E08]|[\u1E0A-\u1E0A]|[\u1E0C-\u1E0C]|[\u1E0E-\u1E0E]|[\u1E10-\u1E10]|[\u1E12-\u1E12]|[\u1E14-\u1E14]|[\u1E16-\u1E16]|[\u1E18-\u1E18]|[\u1E1A-\u1E1A]|[\u1E1C-\u1E1C]|[\u1E1E-\u1E1E]|[\u1E20-\u1E20]|[\u1E22-\u1E22]|[\u1E24-\u1E24]|[\u1E26-\u1E26]|[\u1E28-\u1E28]|[\u1E2A-\u1E2A]|[\u1E2C-\u1E2C]|[\u1E2E-\u1E2E]|[\u1E30-\u1E30]|[\u1E32-\u1E32]|[\u1E34-\u1E34]|[\u1E36-\u1E36]|[\u1E38-\u1E38]|[\u1E3A-\u1E3A]|[\u1E3C-\u1E3C]|[\u1E3E-\u1E3E]|[\u1E40-\u1E40]|[\u1E42-\u1E42]|[\u1E44-\u1E44]|[\u1E46-\u1E46]|[\u1E48-\u1E48]|[\u1E4A-\u1E4A]|[\u1E4C-\u1E4C]|[\u1E4E-\u1E4E]|[\u1E50-\u1E50]|[\u1E52-\u1E52]|[\u1E54-\u1E54]|[\u1E56-\u1E56]|[\u1E58-\u1E58]|[\u1E5A-\u1E5A]|[\u1E5C-\u1E5C]|[\u1E5E-\u1E5E]|[\u1E60-\u1E60]|[\u1E62-\u1E62]|[\u1E64-\u1E64]|[\u1E66-\u1E66]|[\u1E68-\u1E68]|[\u1E6A-\u1E6A]|[\u1E6C-\u1E6C]|[\u1E6E-\u1E6E]|[\u1E70-\u1E70]|[\u1E72-\u1E72]|[\u1E74-\u1E74]|[\u1E76-\u1E76]|[\u1E78-\u1E78]|[\u1E7A-\u1E7A]|[\u1E7C-\u1E7C]|[\u1E7E-\u1E7E]|[\u1E80-\u1E80]|[\u1E82-\u1E82]|[\u1E84-\u1E84]|[\u1E86-\u1E86]|[\u1E88-\u1E88]|[\u1E8A-\u1E8A]|[\u1E8C-\u1E8C]|[\u1E8E-\u1E8E]|[\u1E90-\u1E90]|[\u1E92-\u1E92]|[\u1E94-\u1E94]|[\u1EA0-\u1EA0]|[\u1EA2-\u1EA2]|[\u1EA4-\u1EA4]|[\u1EA6-\u1EA6]|[\u1EA8-\u1EA8]|[\u1EAA-\u1EAA]|[\u1EAC-\u1EAC]|[\u1EAE-\u1EAE]|[\u1EB0-\u1EB0]|[\u1EB2-\u1EB2]|[\u1EB4-\u1EB4]|[\u1EB6-\u1EB6]|[\u1EB8-\u1EB8]|[\u1EBA-\u1EBA]|[\u1EBC-\u1EBC]|[\u1EBE-\u1EBE]|[\u1EC0-\u1EC0]|[\u1EC2-\u1EC2]|[\u1EC4-\u1EC4]|[\u1EC6-\u1EC6]|[\u1EC8-\u1EC8]|[\u1ECA-\u1ECA]|[\u1ECC-\u1ECC]|[\u1ECE-\u1ECE]|[\u1ED0-\u1ED0]|[\u1ED2-\u1ED2]|[\u1ED4-\u1ED4]|[\u1ED6-\u1ED6]|[\u1ED8-\u1ED8]|[\u1EDA-\u1EDA]|[\u1EDC-\u1EDC]|[\u1EDE-\u1EDE]|[\u1EE0-\u1EE0]|[\u1EE2-\u1EE2]|[\u1EE4-\u1EE4]|[\u1EE6-\u1EE6]|[\u1EE8-\u1EE8]|[\u1EEA-\u1EEA]|[\u1EEC-\u1EEC]|[\u1EEE-\u1EEE]|[\u1EF0-\u1EF0]|[\u1EF2-\u1EF2]|[\u1EF4-\u1EF4]|[\u1EF6-\u1EF6]|[\u1EF8-\u1EF8]|[\u1F08-\u1F0F]|[\u1F18-\u1F1D]|[\u1F28-\u1F2F]|[\u1F38-\u1F3F]|[\u1F48-\u1F4D]|[\u1F59-\u1F59]|[\u1F5B-\u1F5B]|[\u1F5D-\u1F5D]|[\u1F5F-\u1F5F]|[\u1F68-\u1F6F]|[\u1F88-\u1F8F]|[\u1F98-\u1F9F]|[\u1FA8-\u1FAF]|[\u1FB8-\u1FBC]|[\u1FC8-\u1FCC]|[\u1FD8-\u1FDB]|[\u1FE8-\u1FEC]|[\u1FF8-\u1FFC]|[\u2102-\u2102]|[\u2107-\u2107]|[\u210B-\u210D]|[\u2110-\u2112]|[\u2115-\u2115]|[\u2119-\u211D]|[\u2124-\u2124]|[\u2126-\u2126]|[\u2128-\u2128]|[\u212A-\u212D]|[\u2130-\u2131]|[\u2133-\u2133]|[\uFF21-\uFF3A]/,Ll:/[\u0061-\u007A]|[\u00AA-\u00AA]|[\u00B5-\u00B5]|[\u00BA-\u00BA]|[\u00DF-\u00F6]|[\u00F8-\u00FF]|[\u0101-\u0101]|[\u0103-\u0103]|[\u0105-\u0105]|[\u0107-\u0107]|[\u0109-\u0109]|[\u010B-\u010B]|[\u010D-\u010D]|[\u010F-\u010F]|[\u0111-\u0111]|[\u0113-\u0113]|[\u0115-\u0115]|[\u0117-\u0117]|[\u0119-\u0119]|[\u011B-\u011B]|[\u011D-\u011D]|[\u011F-\u011F]|[\u0121-\u0121]|[\u0123-\u0123]|[\u0125-\u0125]|[\u0127-\u0127]|[\u0129-\u0129]|[\u012B-\u012B]|[\u012D-\u012D]|[\u012F-\u012F]|[\u0131-\u0131]|[\u0133-\u0133]|[\u0135-\u0135]|[\u0137-\u0138]|[\u013A-\u013A]|[\u013C-\u013C]|[\u013E-\u013E]|[\u0140-\u0140]|[\u0142-\u0142]|[\u0144-\u0144]|[\u0146-\u0146]|[\u0148-\u0149]|[\u014B-\u014B]|[\u014D-\u014D]|[\u014F-\u014F]|[\u0151-\u0151]|[\u0153-\u0153]|[\u0155-\u0155]|[\u0157-\u0157]|[\u0159-\u0159]|[\u015B-\u015B]|[\u015D-\u015D]|[\u015F-\u015F]|[\u0161-\u0161]|[\u0163-\u0163]|[\u0165-\u0165]|[\u0167-\u0167]|[\u0169-\u0169]|[\u016B-\u016B]|[\u016D-\u016D]|[\u016F-\u016F]|[\u0171-\u0171]|[\u0173-\u0173]|[\u0175-\u0175]|[\u0177-\u0177]|[\u017A-\u017A]|[\u017C-\u017C]|[\u017E-\u0180]|[\u0183-\u0183]|[\u0185-\u0185]|[\u0188-\u0188]|[\u018C-\u018D]|[\u0192-\u0192]|[\u0195-\u0195]|[\u0199-\u019B]|[\u019E-\u019E]|[\u01A1-\u01A1]|[\u01A3-\u01A3]|[\u01A5-\u01A5]|[\u01A8-\u01A8]|[\u01AB-\u01AB]|[\u01AD-\u01AD]|[\u01B0-\u01B0]|[\u01B4-\u01B4]|[\u01B6-\u01B6]|[\u01B9-\u01BA]|[\u01BD-\u01BD]|[\u01C6-\u01C6]|[\u01C9-\u01C9]|[\u01CC-\u01CC]|[\u01CE-\u01CE]|[\u01D0-\u01D0]|[\u01D2-\u01D2]|[\u01D4-\u01D4]|[\u01D6-\u01D6]|[\u01D8-\u01D8]|[\u01DA-\u01DA]|[\u01DC-\u01DD]|[\u01DF-\u01DF]|[\u01E1-\u01E1]|[\u01E3-\u01E3]|[\u01E5-\u01E5]|[\u01E7-\u01E7]|[\u01E9-\u01E9]|[\u01EB-\u01EB]|[\u01ED-\u01ED]|[\u01EF-\u01F0]|[\u01F3-\u01F3]|[\u01F5-\u01F5]|[\u01FB-\u01FB]|[\u01FD-\u01FD]|[\u01FF-\u01FF]|[\u0201-\u0201]|[\u0203-\u0203]|[\u0205-\u0205]|[\u0207-\u0207]|[\u0209-\u0209]|[\u020B-\u020B]|[\u020D-\u020D]|[\u020F-\u020F]|[\u0211-\u0211]|[\u0213-\u0213]|[\u0215-\u0215]|[\u0217-\u0217]|[\u0250-\u02A8]|[\u0390-\u0390]|[\u03AC-\u03CE]|[\u03D0-\u03D1]|[\u03D5-\u03D6]|[\u03E3-\u03E3]|[\u03E5-\u03E5]|[\u03E7-\u03E7]|[\u03E9-\u03E9]|[\u03EB-\u03EB]|[\u03ED-\u03ED]|[\u03EF-\u03F2]|[\u0430-\u044F]|[\u0451-\u045C]|[\u045E-\u045F]|[\u0461-\u0461]|[\u0463-\u0463]|[\u0465-\u0465]|[\u0467-\u0467]|[\u0469-\u0469]|[\u046B-\u046B]|[\u046D-\u046D]|[\u046F-\u046F]|[\u0471-\u0471]|[\u0473-\u0473]|[\u0475-\u0475]|[\u0477-\u0477]|[\u0479-\u0479]|[\u047B-\u047B]|[\u047D-\u047D]|[\u047F-\u047F]|[\u0481-\u0481]|[\u0491-\u0491]|[\u0493-\u0493]|[\u0495-\u0495]|[\u0497-\u0497]|[\u0499-\u0499]|[\u049B-\u049B]|[\u049D-\u049D]|[\u049F-\u049F]|[\u04A1-\u04A1]|[\u04A3-\u04A3]|[\u04A5-\u04A5]|[\u04A7-\u04A7]|[\u04A9-\u04A9]|[\u04AB-\u04AB]|[\u04AD-\u04AD]|[\u04AF-\u04AF]|[\u04B1-\u04B1]|[\u04B3-\u04B3]|[\u04B5-\u04B5]|[\u04B7-\u04B7]|[\u04B9-\u04B9]|[\u04BB-\u04BB]|[\u04BD-\u04BD]|[\u04BF-\u04BF]|[\u04C2-\u04C2]|[\u04C4-\u04C4]|[\u04C8-\u04C8]|[\u04CC-\u04CC]|[\u04D1-\u04D1]|[\u04D3-\u04D3]|[\u04D5-\u04D5]|[\u04D7-\u04D7]|[\u04D9-\u04D9]|[\u04DB-\u04DB]|[\u04DD-\u04DD]|[\u04DF-\u04DF]|[\u04E1-\u04E1]|[\u04E3-\u04E3]|[\u04E5-\u04E5]|[\u04E7-\u04E7]|[\u04E9-\u04E9]|[\u04EB-\u04EB]|[\u04EF-\u04EF]|[\u04F1-\u04F1]|[\u04F3-\u04F3]|[\u04F5-\u04F5]|[\u04F9-\u04F9]|[\u0561-\u0587]|[\u10D0-\u10F6]|[\u1E01-\u1E01]|[\u1E03-\u1E03]|[\u1E05-\u1E05]|[\u1E07-\u1E07]|[\u1E09-\u1E09]|[\u1E0B-\u1E0B]|[\u1E0D-\u1E0D]|[\u1E0F-\u1E0F]|[\u1E11-\u1E11]|[\u1E13-\u1E13]|[\u1E15-\u1E15]|[\u1E17-\u1E17]|[\u1E19-\u1E19]|[\u1E1B-\u1E1B]|[\u1E1D-\u1E1D]|[\u1E1F-\u1E1F]|[\u1E21-\u1E21]|[\u1E23-\u1E23]|[\u1E25-\u1E25]|[\u1E27-\u1E27]|[\u1E29-\u1E29]|[\u1E2B-\u1E2B]|[\u1E2D-\u1E2D]|[\u1E2F-\u1E2F]|[\u1E31-\u1E31]|[\u1E33-\u1E33]|[\u1E35-\u1E35]|[\u1E37-\u1E37]|[\u1E39-\u1E39]|[\u1E3B-\u1E3B]|[\u1E3D-\u1E3D]|[\u1E3F-\u1E3F]|[\u1E41-\u1E41]|[\u1E43-\u1E43]|[\u1E45-\u1E45]|[\u1E47-\u1E47]|[\u1E49-\u1E49]|[\u1E4B-\u1E4B]|[\u1E4D-\u1E4D]|[\u1E4F-\u1E4F]|[\u1E51-\u1E51]|[\u1E53-\u1E53]|[\u1E55-\u1E55]|[\u1E57-\u1E57]|[\u1E59-\u1E59]|[\u1E5B-\u1E5B]|[\u1E5D-\u1E5D]|[\u1E5F-\u1E5F]|[\u1E61-\u1E61]|[\u1E63-\u1E63]|[\u1E65-\u1E65]|[\u1E67-\u1E67]|[\u1E69-\u1E69]|[\u1E6B-\u1E6B]|[\u1E6D-\u1E6D]|[\u1E6F-\u1E6F]|[\u1E71-\u1E71]|[\u1E73-\u1E73]|[\u1E75-\u1E75]|[\u1E77-\u1E77]|[\u1E79-\u1E79]|[\u1E7B-\u1E7B]|[\u1E7D-\u1E7D]|[\u1E7F-\u1E7F]|[\u1E81-\u1E81]|[\u1E83-\u1E83]|[\u1E85-\u1E85]|[\u1E87-\u1E87]|[\u1E89-\u1E89]|[\u1E8B-\u1E8B]|[\u1E8D-\u1E8D]|[\u1E8F-\u1E8F]|[\u1E91-\u1E91]|[\u1E93-\u1E93]|[\u1E95-\u1E9B]|[\u1EA1-\u1EA1]|[\u1EA3-\u1EA3]|[\u1EA5-\u1EA5]|[\u1EA7-\u1EA7]|[\u1EA9-\u1EA9]|[\u1EAB-\u1EAB]|[\u1EAD-\u1EAD]|[\u1EAF-\u1EAF]|[\u1EB1-\u1EB1]|[\u1EB3-\u1EB3]|[\u1EB5-\u1EB5]|[\u1EB7-\u1EB7]|[\u1EB9-\u1EB9]|[\u1EBB-\u1EBB]|[\u1EBD-\u1EBD]|[\u1EBF-\u1EBF]|[\u1EC1-\u1EC1]|[\u1EC3-\u1EC3]|[\u1EC5-\u1EC5]|[\u1EC7-\u1EC7]|[\u1EC9-\u1EC9]|[\u1ECB-\u1ECB]|[\u1ECD-\u1ECD]|[\u1ECF-\u1ECF]|[\u1ED1-\u1ED1]|[\u1ED3-\u1ED3]|[\u1ED5-\u1ED5]|[\u1ED7-\u1ED7]|[\u1ED9-\u1ED9]|[\u1EDB-\u1EDB]|[\u1EDD-\u1EDD]|[\u1EDF-\u1EDF]|[\u1EE1-\u1EE1]|[\u1EE3-\u1EE3]|[\u1EE5-\u1EE5]|[\u1EE7-\u1EE7]|[\u1EE9-\u1EE9]|[\u1EEB-\u1EEB]|[\u1EED-\u1EED]|[\u1EEF-\u1EEF]|[\u1EF1-\u1EF1]|[\u1EF3-\u1EF3]|[\u1EF5-\u1EF5]|[\u1EF7-\u1EF7]|[\u1EF9-\u1EF9]|[\u1F00-\u1F07]|[\u1F10-\u1F15]|[\u1F20-\u1F27]|[\u1F30-\u1F37]|[\u1F40-\u1F45]|[\u1F50-\u1F57]|[\u1F60-\u1F67]|[\u1F70-\u1F7D]|[\u1F80-\u1F87]|[\u1F90-\u1F97]|[\u1FA0-\u1FA7]|[\u1FB0-\u1FB4]|[\u1FB6-\u1FB7]|[\u1FBE-\u1FBE]|[\u1FC2-\u1FC4]|[\u1FC6-\u1FC7]|[\u1FD0-\u1FD3]|[\u1FD6-\u1FD7]|[\u1FE0-\u1FE7]|[\u1FF2-\u1FF4]|[\u1FF6-\u1FF7]|[\u207F-\u207F]|[\u210A-\u210A]|[\u210E-\u210F]|[\u2113-\u2113]|[\u2118-\u2118]|[\u212E-\u212F]|[\u2134-\u2134]|[\uFB00-\uFB06]|[\uFB13-\uFB17]|[\uFF41-\uFF5A]/,Lt:/[\u01C5-\u01C5]|[\u01C8-\u01C8]|[\u01CB-\u01CB]|[\u01F2-\u01F2]/,Lm:/[\u02B0-\u02B8]|[\u02BB-\u02C1]|[\u02D0-\u02D1]|[\u02E0-\u02E4]|[\u037A-\u037A]|[\u0559-\u0559]|[\u0640-\u0640]|[\u06E5-\u06E6]|[\u0E46-\u0E46]|[\u0EC6-\u0EC6]|[\u3005-\u3005]|[\u3031-\u3035]|[\u309D-\u309E]|[\u30FC-\u30FE]|[\uFF70-\uFF70]|[\uFF9E-\uFF9F]/,Lo:/[\u01AA-\u01AA]|[\u01BB-\u01BB]|[\u01BE-\u01C3]|[\u03F3-\u03F3]|[\u04C0-\u04C0]|[\u05D0-\u05EA]|[\u05F0-\u05F2]|[\u0621-\u063A]|[\u0641-\u064A]|[\u0671-\u06B7]|[\u06BA-\u06BE]|[\u06C0-\u06CE]|[\u06D0-\u06D3]|[\u06D5-\u06D5]|[\u0905-\u0939]|[\u093D-\u093D]|[\u0950-\u0950]|[\u0958-\u0961]|[\u0985-\u098C]|[\u098F-\u0990]|[\u0993-\u09A8]|[\u09AA-\u09B0]|[\u09B2-\u09B2]|[\u09B6-\u09B9]|[\u09DC-\u09DD]|[\u09DF-\u09E1]|[\u09F0-\u09F1]|[\u0A05-\u0A0A]|[\u0A0F-\u0A10]|[\u0A13-\u0A28]|[\u0A2A-\u0A30]|[\u0A32-\u0A33]|[\u0A35-\u0A36]|[\u0A38-\u0A39]|[\u0A59-\u0A5C]|[\u0A5E-\u0A5E]|[\u0A72-\u0A74]|[\u0A85-\u0A8B]|[\u0A8D-\u0A8D]|[\u0A8F-\u0A91]|[\u0A93-\u0AA8]|[\u0AAA-\u0AB0]|[\u0AB2-\u0AB3]|[\u0AB5-\u0AB9]|[\u0ABD-\u0ABD]|[\u0AD0-\u0AD0]|[\u0AE0-\u0AE0]|[\u0B05-\u0B0C]|[\u0B0F-\u0B10]|[\u0B13-\u0B28]|[\u0B2A-\u0B30]|[\u0B32-\u0B33]|[\u0B36-\u0B39]|[\u0B3D-\u0B3D]|[\u0B5C-\u0B5D]|[\u0B5F-\u0B61]|[\u0B85-\u0B8A]|[\u0B8E-\u0B90]|[\u0B92-\u0B95]|[\u0B99-\u0B9A]|[\u0B9C-\u0B9C]|[\u0B9E-\u0B9F]|[\u0BA3-\u0BA4]|[\u0BA8-\u0BAA]|[\u0BAE-\u0BB5]|[\u0BB7-\u0BB9]|[\u0C05-\u0C0C]|[\u0C0E-\u0C10]|[\u0C12-\u0C28]|[\u0C2A-\u0C33]|[\u0C35-\u0C39]|[\u0C60-\u0C61]|[\u0C85-\u0C8C]|[\u0C8E-\u0C90]|[\u0C92-\u0CA8]|[\u0CAA-\u0CB3]|[\u0CB5-\u0CB9]|[\u0CDE-\u0CDE]|[\u0CE0-\u0CE1]|[\u0D05-\u0D0C]|[\u0D0E-\u0D10]|[\u0D12-\u0D28]|[\u0D2A-\u0D39]|[\u0D60-\u0D61]|[\u0E01-\u0E30]|[\u0E32-\u0E33]|[\u0E40-\u0E45]|[\u0E81-\u0E82]|[\u0E84-\u0E84]|[\u0E87-\u0E88]|[\u0E8A-\u0E8A]|[\u0E8D-\u0E8D]|[\u0E94-\u0E97]|[\u0E99-\u0E9F]|[\u0EA1-\u0EA3]|[\u0EA5-\u0EA5]|[\u0EA7-\u0EA7]|[\u0EAA-\u0EAB]|[\u0EAD-\u0EB0]|[\u0EB2-\u0EB3]|[\u0EBD-\u0EBD]|[\u0EC0-\u0EC4]|[\u0EDC-\u0EDD]|[\u0F00-\u0F00]|[\u0F40-\u0F47]|[\u0F49-\u0F69]|[\u0F88-\u0F8B]|[\u1100-\u1159]|[\u115F-\u11A2]|[\u11A8-\u11F9]|[\u2135-\u2138]|[\u3006-\u3006]|[\u3041-\u3094]|[\u30A1-\u30FA]|[\u3105-\u312C]|[\u3131-\u318E]|[\u4E00-\u9FA5]|[\uAC00-\uD7A3]|[\uF900-\uFA2D]|[\uFB1F-\uFB28]|[\uFB2A-\uFB36]|[\uFB38-\uFB3C]|[\uFB3E-\uFB3E]|[\uFB40-\uFB41]|[\uFB43-\uFB44]|[\uFB46-\uFBB1]|[\uFBD3-\uFD3D]|[\uFD50-\uFD8F]|[\uFD92-\uFDC7]|[\uFDF0-\uFDFB]|[\uFE70-\uFE72]|[\uFE74-\uFE74]|[\uFE76-\uFEFC]|[\uFF66-\uFF6F]|[\uFF71-\uFF9D]|[\uFFA0-\uFFBE]|[\uFFC2-\uFFC7]|[\uFFCA-\uFFCF]|[\uFFD2-\uFFD7]|[\uFFDA-\uFFDC]/, -Nl:/[\u2160-\u2182]|[\u3007-\u3007]|[\u3021-\u3029]/,Mn:/[\u0300-\u0345]|[\u0360-\u0361]|[\u0483-\u0486]|[\u0591-\u05A1]|[\u05A3-\u05B9]|[\u05BB-\u05BD]|[\u05BF-\u05BF]|[\u05C1-\u05C2]|[\u05C4-\u05C4]|[\u064B-\u0652]|[\u0670-\u0670]|[\u06D6-\u06DC]|[\u06DF-\u06E4]|[\u06E7-\u06E8]|[\u06EA-\u06ED]|[\u0901-\u0902]|[\u093C-\u093C]|[\u0941-\u0948]|[\u094D-\u094D]|[\u0951-\u0954]|[\u0962-\u0963]|[\u0981-\u0981]|[\u09BC-\u09BC]|[\u09C1-\u09C4]|[\u09CD-\u09CD]|[\u09E2-\u09E3]|[\u0A02-\u0A02]|[\u0A3C-\u0A3C]|[\u0A41-\u0A42]|[\u0A47-\u0A48]|[\u0A4B-\u0A4D]|[\u0A70-\u0A71]|[\u0A81-\u0A82]|[\u0ABC-\u0ABC]|[\u0AC1-\u0AC5]|[\u0AC7-\u0AC8]|[\u0ACD-\u0ACD]|[\u0B01-\u0B01]|[\u0B3C-\u0B3C]|[\u0B3F-\u0B3F]|[\u0B41-\u0B43]|[\u0B4D-\u0B4D]|[\u0B56-\u0B56]|[\u0B82-\u0B82]|[\u0BC0-\u0BC0]|[\u0BCD-\u0BCD]|[\u0C3E-\u0C40]|[\u0C46-\u0C48]|[\u0C4A-\u0C4D]|[\u0C55-\u0C56]|[\u0CBF-\u0CBF]|[\u0CC6-\u0CC6]|[\u0CCC-\u0CCD]|[\u0D41-\u0D43]|[\u0D4D-\u0D4D]|[\u0E31-\u0E31]|[\u0E34-\u0E3A]|[\u0E47-\u0E4E]|[\u0EB1-\u0EB1]|[\u0EB4-\u0EB9]|[\u0EBB-\u0EBC]|[\u0EC8-\u0ECD]|[\u0F18-\u0F19]|[\u0F35-\u0F35]|[\u0F37-\u0F37]|[\u0F39-\u0F39]|[\u0F71-\u0F7E]|[\u0F80-\u0F84]|[\u0F86-\u0F87]|[\u0F90-\u0F95]|[\u0F97-\u0F97]|[\u0F99-\u0FAD]|[\u0FB1-\u0FB7]|[\u0FB9-\u0FB9]|[\u20D0-\u20DC]|[\u20E1-\u20E1]|[\u302A-\u302F]|[\u3099-\u309A]|[\uFB1E-\uFB1E]|[\uFE20-\uFE23]/,Mc:/[\u0903-\u0903]|[\u093E-\u0940]|[\u0949-\u094C]|[\u0982-\u0983]|[\u09BE-\u09C0]|[\u09C7-\u09C8]|[\u09CB-\u09CC]|[\u09D7-\u09D7]|[\u0A3E-\u0A40]|[\u0A83-\u0A83]|[\u0ABE-\u0AC0]|[\u0AC9-\u0AC9]|[\u0ACB-\u0ACC]|[\u0B02-\u0B03]|[\u0B3E-\u0B3E]|[\u0B40-\u0B40]|[\u0B47-\u0B48]|[\u0B4B-\u0B4C]|[\u0B57-\u0B57]|[\u0B83-\u0B83]|[\u0BBE-\u0BBF]|[\u0BC1-\u0BC2]|[\u0BC6-\u0BC8]|[\u0BCA-\u0BCC]|[\u0BD7-\u0BD7]|[\u0C01-\u0C03]|[\u0C41-\u0C44]|[\u0C82-\u0C83]|[\u0CBE-\u0CBE]|[\u0CC0-\u0CC4]|[\u0CC7-\u0CC8]|[\u0CCA-\u0CCB]|[\u0CD5-\u0CD6]|[\u0D02-\u0D03]|[\u0D3E-\u0D40]|[\u0D46-\u0D48]|[\u0D4A-\u0D4C]|[\u0D57-\u0D57]|[\u0F3E-\u0F3F]|[\u0F7F-\u0F7F]/,Nd:/[\u0030-\u0039]|[\u0660-\u0669]|[\u06F0-\u06F9]|[\u0966-\u096F]|[\u09E6-\u09EF]|[\u0A66-\u0A6F]|[\u0AE6-\u0AEF]|[\u0B66-\u0B6F]|[\u0BE7-\u0BEF]|[\u0C66-\u0C6F]|[\u0CE6-\u0CEF]|[\u0D66-\u0D6F]|[\u0E50-\u0E59]|[\u0ED0-\u0ED9]|[\u0F20-\u0F29]|[\uFF10-\uFF19]/,Pc:/[\u005F-\u005F]|[\u203F-\u2040]|[\u30FB-\u30FB]|[\uFE33-\uFE34]|[\uFE4D-\uFE4F]|[\uFF3F-\uFF3F]|[\uFF65-\uFF65]/,Zs:/[\u2000-\u200B]|[\u3000-\u3000]/}},{}]},{},[28])(28)}); +output+=encode(temp>>10);output+=encode(temp>>4&63);output+=encode(temp<<2&63);output+="=";break}return output}exports.toByteArray=b64ToByteArray;exports.fromByteArray=uint8ToBase64})(typeof exports==="undefined"?this.base64js={}:exports)},{}],5:[function(_dereq_,module,exports){exports.read=function(buffer,offset,isLE,mLen,nBytes){var e,m,eLen=nBytes*8-mLen-1,eMax=(1<>1,nBits=-7,i=isLE?nBytes-1:0,d=isLE?-1:1,s=buffer[offset+i];i+=d;e=s&(1<<-nBits)-1;s>>=-nBits;nBits+=eLen;for(;nBits>0;e=e*256+buffer[offset+i],i+=d,nBits-=8){}m=e&(1<<-nBits)-1;e>>=-nBits;nBits+=mLen;for(;nBits>0;m=m*256+buffer[offset+i],i+=d,nBits-=8){}if(e===0){e=1-eBias}else if(e===eMax){return m?NaN:(s?-1:1)*Infinity}else{m=m+Math.pow(2,mLen);e=e-eBias}return(s?-1:1)*m*Math.pow(2,e-mLen)};exports.write=function(buffer,value,offset,isLE,mLen,nBytes){var e,m,c,eLen=nBytes*8-mLen-1,eMax=(1<>1,rt=mLen===23?Math.pow(2,-24)-Math.pow(2,-77):0,i=isLE?0:nBytes-1,d=isLE?1:-1,s=value<0||value===0&&1/value<0?1:0;value=Math.abs(value);if(isNaN(value)||value===Infinity){m=isNaN(value)?1:0;e=eMax}else{e=Math.floor(Math.log(value)/Math.LN2);if(value*(c=Math.pow(2,-e))<1){e--;c*=2}if(e+eBias>=1){value+=rt/c}else{value+=rt*Math.pow(2,1-eBias)}if(value*c>=2){e++;c/=2}if(e+eBias>=eMax){m=0;e=eMax}else if(e+eBias>=1){m=(value*c-1)*Math.pow(2,mLen);e=e+eBias}else{m=value*Math.pow(2,eBias-1)*Math.pow(2,mLen);e=0}}for(;mLen>=8;buffer[offset+i]=m&255,i+=d,m/=256,mLen-=8){}e=e<0;buffer[offset+i]=e&255,i+=d,e/=256,eLen-=8){}buffer[offset+i-d]|=s*128}},{}],6:[function(_dereq_,module,exports){var Buffer=_dereq_("buffer").Buffer;var intSize=4;var zeroBuffer=new Buffer(intSize);zeroBuffer.fill(0);var chrsz=8;function toArray(buf,bigEndian){if(buf.length%intSize!==0){var len=buf.length+(intSize-buf.length%intSize);buf=Buffer.concat([buf,zeroBuffer],len)}var arr=[];var fn=bigEndian?buf.readInt32BE:buf.readInt32LE;for(var i=0;iblocksize){key=fn(key)}else if(key.length>5]|=128<>>9<<4)+14]=len;var a=1732584193;var b=-271733879;var c=-1732584194;var d=271733878;for(var i=0;i>16)+(y>>16)+(lsw>>16);return msw<<16|lsw&65535}function bit_rol(num,cnt){return num<>>32-cnt}module.exports=function md5(buf){return helpers.hash(buf,core_md5,16)}},{"./helpers":6}],9:[function(_dereq_,module,exports){(function(){var _global=this;var mathRNG,whatwgRNG;mathRNG=function(size){var bytes=new Array(size);var r;for(var i=0,r;i>>((i&3)<<3)&255}return bytes};if(_global.crypto&&crypto.getRandomValues){whatwgRNG=function(size){var bytes=new Uint8Array(size);crypto.getRandomValues(bytes);return bytes}}module.exports=whatwgRNG||mathRNG})()},{}],10:[function(_dereq_,module,exports){var helpers=_dereq_("./helpers");function core_sha1(x,len){x[len>>5]|=128<<24-len%32;x[(len+64>>9<<4)+15]=len;var w=Array(80);var a=1732584193;var b=-271733879;var c=-1732584194;var d=271733878;var e=-1009589776;for(var i=0;i>16)+(y>>16)+(lsw>>16);return msw<<16|lsw&65535}function rol(num,cnt){return num<>>32-cnt}module.exports=function sha1(buf){return helpers.hash(buf,core_sha1,20,true)}},{"./helpers":6}],11:[function(_dereq_,module,exports){var helpers=_dereq_("./helpers");var safe_add=function(x,y){var lsw=(x&65535)+(y&65535);var msw=(x>>16)+(y>>16)+(lsw>>16);return msw<<16|lsw&65535};var S=function(X,n){return X>>>n|X<<32-n};var R=function(X,n){return X>>>n};var Ch=function(x,y,z){return x&y^~x&z};var Maj=function(x,y,z){return x&y^x&z^y&z};var Sigma0256=function(x){return S(x,2)^S(x,13)^S(x,22)};var Sigma1256=function(x){return S(x,6)^S(x,11)^S(x,25)};var Gamma0256=function(x){return S(x,7)^S(x,18)^R(x,3)};var Gamma1256=function(x){return S(x,17)^S(x,19)^R(x,10)};var core_sha256=function(m,l){var K=new Array(1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298);var HASH=new Array(1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225);var W=new Array(64);var a,b,c,d,e,f,g,h,i,j;var T1,T2;m[l>>5]|=128<<24-l%32;m[(l+64>>9<<4)+15]=l;for(var i=0;i0){var prettyProblems=problems.map(function(problem){return"- "+problem});var error=new Error("Found errors in the action dictionary of the '"+name+"' "+what+":\n"+prettyProblems.join("\n"));error.problems=problems;throw error}},_topDownActionArity:function(actionName){if(actionName==="_default"||actionName==="_iter"){return 1}else if(actionName==="_terminal"){return 0}return this.ruleDict[actionName].getArity()},_inheritsFrom:function(grammar){var g=this.superGrammar;while(g){if(g===grammar){return true}g=g.superGrammar}return false},toRecipe:function(optVarName){if(this.isBuiltIn()){throw new Error("Why would anyone want to generate a recipe for the "+this.name+" grammar?!?!")}var sb=new common.StringBuffer;if(optVarName){sb.append("var "+optVarName+" = ")}sb.append("(function() {\n");var superGrammarDecl="";if(!this.superGrammar.isBuiltIn()){sb.append(this.superGrammar.toRecipe("buildSuperGrammar"));superGrammarDecl=" .withSuperGrammar(buildSuperGrammar.call(this))\n"}sb.append(" return new this.newGrammar("+common.toStringLiteral(this.name)+")\n");sb.append(superGrammarDecl);if(this.defaultStartRule){sb.append(" .withDefaultStartRule('"+this.defaultStartRule+"')\n")}var self=this;Object.keys(this.ruleDict).forEach(function(ruleName){var body=self.ruleDict[ruleName];sb.append(" .");if(self.superGrammar.ruleDict[ruleName]){sb.append(body instanceof pexprs.Extend?"extend":"override")}else{sb.append("define")}var formals="["+body.formals.map(common.toStringLiteral).join(", ")+"]";sb.append("("+common.toStringLiteral(ruleName)+", "+formals+", ");body.outputRecipe(sb,body.formals);if(body.description){sb.append(", "+common.toStringLiteral(body.description))}sb.append(")\n")});sb.append(" .build();\n});\n");return sb.contents()},toOperationActionDictionaryTemplate:function(){return this._toOperationOrAttributeActionDictionaryTemplate()},toAttributeActionDictionaryTemplate:function(){return this._toOperationOrAttributeActionDictionaryTemplate()},_toOperationOrAttributeActionDictionaryTemplate:function(){var sb=new common.StringBuffer;sb.append("{");var first=true;for(var ruleName in this.ruleDict){if(ruleName==="spaces_"){continue}var body=this.ruleDict[ruleName];if(first){first=false}else{sb.append(",")}sb.append("\n");sb.append(" ");this.addSemanticActionTemplate(ruleName,body,sb)}sb.append("\n}");return sb.contents()},addSemanticActionTemplate:function(ruleName,body,sb){sb.append(ruleName);sb.append(": function(");var arity=this._topDownActionArity(ruleName);sb.append(common.repeat("_",arity).join(", "));sb.append(") {\n");sb.append(" }")}};Grammar.ProtoBuiltInRules=new Grammar("ProtoBuiltInRules",undefined,{_:pexprs.anything.withFormals([]),end:pexprs.end.withFormals([]),spaces_:new pexprs.Star(new pexprs.Apply("space")).withFormals([]),space:pexprs.makePrim(/[\s]/).withFormals([]).withDescription("a space")});module.exports=Grammar},{"./InputStream":18,"./Interval":19,"./MatchResult":20,"./Semantics":23,"./State":24,"./common":26,"./errors":27,"./nodes":29,"./pexprs":44}],17:[function(_dereq_,module,exports){"use strict";var Grammar=_dereq_("./Grammar");var common=_dereq_("./common");var errors=_dereq_("./errors");var pexprs=_dereq_("./pexprs");function GrammarDecl(name){this.name=name}function onOhmError(doFn,onErrorFn){try{doFn()}catch(e){if(e instanceof errors.Error){onErrorFn(e)}else{throw e}}}GrammarDecl.prototype.ensureSuperGrammar=function(){if(!this.superGrammar){this.withSuperGrammar(this.name==="BuiltInRules"?Grammar.ProtoBuiltInRules:Grammar.BuiltInRules)}return this.superGrammar};GrammarDecl.prototype.installOverriddenOrExtendedRule=function(name,formals,body){var duplicateParameterNames=common.getDuplicates(formals);if(duplicateParameterNames.length>0){throw new errors.DuplicateParameterNames(name,duplicateParameterNames)}var baseRule=this.ensureSuperGrammar().ruleDict[name];if(formals.length!==baseRule.formals.length){throw new errors.WrongNumberOfParameters(name,baseRule.formals.length,formals.length)}return this.install(name,formals,baseRule.description,body)};GrammarDecl.prototype.install=function(name,formals,description,body){body=body.introduceParams(formals);body.formals=formals;body.description=description;this.ruleDict[name]=body;return this};GrammarDecl.prototype.withSuperGrammar=function(superGrammar){if(this.superGrammar){throw new Error("the super grammar of a GrammarDecl cannot be set more than once")}this.superGrammar=superGrammar;this.ruleDict=Object.create(superGrammar.ruleDict);if(!superGrammar.isBuiltIn()){this.defaultStartRule=superGrammar.defaultStartRule}return this};GrammarDecl.prototype.withDefaultStartRule=function(ruleName){this.defaultStartRule=ruleName;return this};GrammarDecl.prototype.build=function(){var grammar=new Grammar(this.name,this.ensureSuperGrammar(),this.ruleDict,this.defaultStartRule);var grammarErrors=[];var grammarHasInvalidApplications=false;Object.keys(grammar.ruleDict).forEach(function(ruleName){var body=grammar.ruleDict[ruleName];onOhmError(function(){body.assertChoicesHaveUniformArity(ruleName)},function(e){grammarErrors.push(e)});onOhmError(function(){body.assertAllApplicationsAreValid(grammar)},function(e){grammarErrors.push(e);grammarHasInvalidApplications=true})});if(!grammarHasInvalidApplications){Object.keys(grammar.ruleDict).forEach(function(ruleName){var body=grammar.ruleDict[ruleName];onOhmError(function(){body.assertIteratedExprsAreNotNullable(grammar,ruleName)},function(e){grammarErrors.push(e)})})}if(grammarErrors.length>0){errors.throwErrors(grammarErrors)}return grammar};GrammarDecl.prototype.define=function(name,formals,body,optDescr){this.ensureSuperGrammar();if(this.superGrammar.ruleDict[name]){throw new errors.DuplicateRuleDeclaration(name,this.name,this.superGrammar.name)}else if(this.ruleDict[name]){throw new errors.DuplicateRuleDeclaration(name,this.name,this.name)}var duplicateParameterNames=common.getDuplicates(formals);if(duplicateParameterNames.length>0){throw new errors.DuplicateParameterNames(name,duplicateParameterNames)}return this.install(name,formals,optDescr,body)};GrammarDecl.prototype.override=function(name,formals,body){var baseRule=this.ensureSuperGrammar().ruleDict[name];if(!baseRule){throw new errors.CannotOverrideUndeclaredRule(name,this.superGrammar.name)}this.installOverriddenOrExtendedRule(name,formals,body);return this};GrammarDecl.prototype.extend=function(name,formals,body){var baseRule=this.ensureSuperGrammar().ruleDict[name];if(!baseRule){throw new errors.CannotExtendUndeclaredRule(name,this.superGrammar.name)}this.installOverriddenOrExtendedRule(name,formals,new pexprs.Extend(this.superGrammar,name,body));return this};module.exports=GrammarDecl},{"./Grammar":16,"./common":26,"./errors":27,"./pexprs":44}],18:[function(_dereq_,module,exports){"use strict";var common=_dereq_("./common");var Interval=_dereq_("./Interval");function InputStream(){throw new Error("InputStream cannot be instantiated -- it's abstract")}InputStream.newFor=function(obj){if(typeof obj==="string"){return new StringInputStream(obj)}else if(Array.isArray(obj)){return new ListInputStream(obj)}else if(obj instanceof InputStream){return obj}else{throw new Error("cannot make input stream for "+obj)}};InputStream.prototype={init:function(source){this.source=source;this.pos=0;this.posInfos=[]},atEnd:function(){return this.pos===this.source.length},next:function(){if(this.atEnd()){return common.fail}else{return this.source[this.pos++]}},matchExactly:function(x){return this.next()===x?true:common.fail},sourceSlice:function(startIdx,endIdx){return this.source.slice(startIdx,endIdx)},intervalFrom:function(startIdx){return new Interval(this,startIdx,this.pos)}};function StringInputStream(source){this.init(source)}StringInputStream.prototype=Object.create(InputStream.prototype,{matchString:{value:function(s){for(var idx=0;idx0){if(idx===expected.length-1){sb.append(expected.length>2?", or ":" or ")}else{sb.append(", ")}}sb.append(expected[idx])}return sb.contents()};MatchFailure.prototype.getExpected=function(){var expected={};var ruleDict=this.state.grammar.ruleDict;this._exprsAndStacks.forEach(function(obj){expected[obj.expr.toExpected(ruleDict)]=true});return Object.keys(expected)};module.exports=MatchResult},{"./common":26,"./util":45,inherits:12}],21:[function(_dereq_,module,exports){"use strict";var extend=_dereq_("util-extend");function Namespace(){}Namespace.prototype=Object.create(null);Namespace.asNamespace=function(objOrNamespace){if(objOrNamespace instanceof Namespace){return objOrNamespace}return Namespace.createNamespace(objOrNamespace)};Namespace.createNamespace=function(optProps){return Namespace.extend(Namespace.prototype,optProps)};Namespace.extend=function(namespace,optProps){if(namespace!==Namespace.prototype&&!(namespace instanceof Namespace)){throw new TypeError("not a Namespace object: "+namespace)}var ns=Object.create(namespace,{constructor:{value:Namespace,enumerable:false,writable:true,configurable:true}});return extend(ns,optProps)};Namespace.toString=function(ns){return Object.prototype.toString.call(ns)};module.exports=Namespace},{"util-extend":14}],22:[function(_dereq_,module,exports){"use strict";function PosInfo(globalApplicationStack){this.globalApplicationStack=globalApplicationStack;this.applicationStack=[];this.activeApplications={};this.memo={}}PosInfo.prototype={isActive:function(application){return this.activeApplications[application.toMemoKey()]},enter:function(application){this.globalApplicationStack.push(application); +this.applicationStack.push(application);this.activeApplications[application.toMemoKey()]=true},exit:function(){var application=this.globalApplicationStack.pop();this.applicationStack.pop();this.activeApplications[application.toMemoKey()]=false},shouldUseMemoizedResult:function(memoRec){var involvedApplications=memoRec.involvedApplications;for(var memoKey in involvedApplications){if(involvedApplications[memoKey]&&this.activeApplications[memoKey]){return false}}return true},getCurrentLeftRecursion:function(){if(this.leftRecursionStack){return this.leftRecursionStack[this.leftRecursionStack.length-1]}},startLeftRecursion:function(application){if(!this.leftRecursionStack){this.leftRecursionStack=[]}this.leftRecursionStack.push({memoKey:application.toMemoKey(),value:false,pos:-1,involvedApplications:{}});this.updateInvolvedApplications()},endLeftRecursion:function(application){this.leftRecursionStack.pop()},updateInvolvedApplications:function(){var currentLeftRecursion=this.getCurrentLeftRecursion();var involvedApplications=currentLeftRecursion.involvedApplications;var lrApplicationMemoKey=currentLeftRecursion.memoKey;var idx=this.applicationStack.length-1;while(true){var memoKey=this.applicationStack[idx--].toMemoKey();if(memoKey===lrApplicationMemoKey){break}involvedApplications[memoKey]=true}}};module.exports=PosInfo},{}],23:[function(_dereq_,module,exports){"use strict";var Symbol=_dereq_("symbol");var inherits=_dereq_("inherits");var MatchResult=_dereq_("./MatchResult");var common=_dereq_("./common");function Wrapper(){}Wrapper.prototype.toString=function(){return"[semantics wrapper for "+this._node.grammar.name+"]"};Wrapper.prototype.child=function(idx){if(!(0<=idx&&idx0){return}if(posthis.rightmostFailPos){this.rightmostFailPos=pos}if(!this.failures){return}function addStack(stack,stacks){for(var idx=0;idx0){arr.push(fn())}return arr};exports.repeatStr=function(str,n){return new Array(n+1).join(str)};exports.repeat=function(x,n){return exports.repeatFn(function(){return x},n)};exports.getDuplicates=function(array){var duplicates=[];for(var idx=0;idx=0;var hasDoubleQuotes=str.indexOf('"')>=0;var delim=hasSingleQuotes&&!hasDoubleQuotes?'"':"'";var sb=new exports.StringBuffer;sb.append(delim);for(var idx=0;idx1){throw new MultipleErrors(errors)}}}},{"./Namespace":21}],28:[function(_dereq_,module,exports){(function(Buffer){"use strict";var Builder=_dereq_("./Builder");var Grammar=_dereq_("./Grammar");var Namespace=_dereq_("./Namespace");var UnicodeCategories=_dereq_("../third_party/unicode").UnicodeCategories;var common=_dereq_("./common");var errors=_dereq_("./errors");var util=_dereq_("./util");var ohmGrammar;var documentInterface={querySelector:function(sel){return document.querySelector(sel)},querySelectorAll:function(sel){return document.querySelectorAll(sel)}};function isElement(obj){return!!(obj&&obj.nodeType===1)}function isUndefined(obj){return obj===void 0}var MAX_ARRAY_INDEX=Math.pow(2,53)-1;function isArrayLike(obj){if(obj==null){return false}var length=obj.length;return typeof length==="number"&&length>=0&&length<=MAX_ARRAY_INDEX}function load(url){var req=new XMLHttpRequest;req.open("GET",url,false);try{req.send();if(req.status===0||req.status===200){return req.responseText}}catch(e){}throw new Error("unable to load url "+url)}function buildGrammar(match,namespace,optOhmGrammarForTesting){var builder;var decl;var currentRuleName;var currentRuleFormals;var overriding=false;var metaGrammar=optOhmGrammarForTesting||ohmGrammar;var helpers=metaGrammar.semantics().addOperation("visit",{Grammar:function(n,s,open,rs,close){builder=new Builder;var grammarName=n.visit();decl=builder.newGrammar(grammarName,namespace);s.visit();rs.visit();var g=decl.build();if(grammarName in namespace){throw new errors.DuplicateGrammarDeclaration(grammarName,namespace)}g.definitionInterval=this.interval.trimmed();namespace[grammarName]=g;return g},SuperGrammar:function(_,n){var superGrammarName=n.visit();if(superGrammarName==="null"){decl.withSuperGrammar(null)}else{if(!namespace||!(superGrammarName in namespace)){throw new errors.UndeclaredGrammar(superGrammarName,namespace)}decl.withSuperGrammar(namespace[superGrammarName])}},Rule_define:function(n,fs,d,_,b){currentRuleName=n.visit();currentRuleFormals=fs.visit()[0]||[];if(!decl.defaultStartRule&&decl.ensureSuperGrammar()!==Grammar.ProtoBuiltInRules){decl.withDefaultStartRule(currentRuleName)}var body=b.visit();body.definitionInterval=this.interval.trimmed();var description=d.visit()[0];return decl.define(currentRuleName,currentRuleFormals,body,description)},Rule_override:function(n,fs,_,b){currentRuleName=n.visit();currentRuleFormals=fs.visit()[0]||[];overriding=true;var body=b.visit();body.definitionInterval=this.interval.trimmed();var ans=decl.override(currentRuleName,currentRuleFormals,body);overriding=false;return ans},Rule_extend:function(n,fs,_,b){currentRuleName=n.visit();currentRuleFormals=fs.visit()[0]||[];var body=b.visit();var ans=decl.extend(currentRuleName,currentRuleFormals,body);decl.ruleDict[currentRuleName].definitionInterval=this.interval.trimmed();return ans},Formals:function(opointy,fs,cpointy){return fs.visit()},Params:function(opointy,ps,cpointy){return ps.visit()},Alt:function(term,_,terms){var args=[term.visit()].concat(terms.visit());return builder.alt.apply(builder,args).withInterval(this.interval)},Term_inline:function(b,n){var inlineRuleName=currentRuleName+"_"+n.visit();var body=b.visit();body.definitionInterval=this.interval.trimmed();var isNewRuleDeclaration=!(decl.superGrammar&&decl.superGrammar.ruleDict[inlineRuleName]);if(overriding&&!isNewRuleDeclaration){decl.override(inlineRuleName,currentRuleFormals,body)}else{decl.define(inlineRuleName,currentRuleFormals,body)}var params=currentRuleFormals.map(function(formal){return builder.app(formal)});return builder.app(inlineRuleName,params).withInterval(body.interval)},Seq:function(expr){return builder.seq.apply(builder,expr.visit()).withInterval(this.interval)},Iter_star:function(x,_){return builder.star(x.visit()).withInterval(this.interval)},Iter_plus:function(x,_){return builder.plus(x.visit()).withInterval(this.interval)},Iter_opt:function(x,_){return builder.opt(x.visit()).withInterval(this.interval)},Pred_not:function(_,x){return builder.not(x.visit()).withInterval(this.interval)},Pred_lookahead:function(_,x){return builder.la(x.visit()).withInterval(this.interval)},Base_application:function(rule,ps){return builder.app(rule.visit(),ps.visit()[0]||[]).withInterval(this.interval)},Base_prim:function(expr){return builder.prim(expr.visit()).withInterval(this.interval)},Base_paren:function(open,x,close){return x.visit()},Base_arr:function(open,x,close){return builder.arr(x.visit()).withInterval(this.interval)},Base_str:function(open,x,close){return builder.str(x.visit())},Base_obj:function(open,lenient,close){return builder.obj([],lenient.visit()[0])},Base_objWithProps:function(open,ps,_,lenient,close){return builder.obj(ps.visit(),lenient.visit()[0]).withInterval(this.interval)},Props:function(p,_,ps){return[p.visit()].concat(ps.visit())},Prop:function(n,_,p){return{name:n.visit(),pattern:p.visit()}},ruleDescr:function(open,t,close){return t.visit()},ruleDescrText:function(_){return this.interval.contents.trim()},caseName:function(_,space1,n,space2,end){return n.visit()},name:function(first,rest){return this.interval.contents},nameFirst:function(expr){},nameRest:function(expr){},keyword_null:function(_){return null},keyword_true:function(_){return true},keyword_false:function(_){return false},string:function(open,cs,close){return cs.visit().map(function(c){return common.unescapeChar(c)}).join("")},strChar:function(_){return this.interval.contents},escapeChar:function(_){return this.interval.contents},regExp:function(open,e,close){return e.visit()},reCharClass_unicode:function(open,unicodeClass,close){return UnicodeCategories[unicodeClass.visit().join("")]},reCharClass_ordinary:function(open,_,close){return new RegExp(this.interval.contents)},number:function(_,digits){return parseInt(this.interval.contents)},space:function(expr){},space_multiLine:function(start,_,end){},space_singleLine:function(start,_,end){},ListOf_some:function(x,_,xs){return[x.visit()].concat(xs.visit())},ListOf_none:function(){return[]}});return helpers(match).visit()}function compileAndLoad(source,namespace){var m=ohmGrammar.match(source,"Grammars");if(m.failed()){throw new errors.GrammarSyntaxError(m)}return buildGrammar(m,namespace)}function getScriptElementContents(el){if(!isElement(el)){throw new TypeError("Expected a DOM Node, got "+common.unexpectedObjToString(el))}if(el.type!=="text/ohm-js"){throw new Error('Expected a script tag with type="text/ohm-js", got '+el)}return el.getAttribute("src")?load(el.getAttribute("src")):el.innerHTML}function grammar(source,optNamespace){var ns=grammars(source,optNamespace);var grammarNames=Object.keys(ns);if(grammarNames.length===0){throw new Error("Missing grammar definition")}else if(grammarNames.length>1){var secondGrammar=ns[grammarNames[1]];var interval=secondGrammar.definitionInterval;throw new Error(util.getLineAndColumnMessage(interval.inputStream.source,interval.startIdx)+"Found more than one grammar definition -- use ohm.grammars() instead.")}return ns[grammarNames[0]]}function grammars(source,optNamespace){var ns=Namespace.extend(Namespace.asNamespace(optNamespace));if(typeof source!=="string"){if(Buffer&&Buffer.isBuffer(source)){source=source.toString()}else{throw new TypeError("Expected string as first argument, got "+common.unexpectedObjToString(source))}}compileAndLoad(source,ns);return ns}function grammarFromScriptElement(optNode){var node=optNode;if(isUndefined(node)){var nodeList=documentInterface.querySelectorAll('script[type="text/ohm-js"]');if(nodeList.length!==1){throw new Error('Expected exactly one script tag with type="text/ohm-js", found '+nodeList.length)}node=nodeList[0]}return grammar(getScriptElementContents(node))}function grammarsFromScriptElements(optNodeOrNodeList){if(isElement(optNodeOrNodeList)){return grammars(optNodeOrNodeList)}var nodeList=optNodeOrNodeList;if(isUndefined(nodeList)){nodeList=documentInterface.querySelectorAll('script[type="text/ohm-js"]')}else if(typeof nodeList==="string"||!isElement(nodeList)&&!isArrayLike(nodeList)){throw new TypeError("Expected a Node, NodeList, or Array, but got "+nodeList)}var ns=Namespace.createNamespace();for(var i=0;i0};Node.prototype.hasNoChildren=function(){return!this.hasChildren()};Node.prototype.onlyChild=function(){if(this.children.length!==1){throw new Error("cannot get only child of a node of type "+this.ctorName+" (it has "+this.numChildren()+" children)")}else{return this.firstChild()}};Node.prototype.firstChild=function(){if(this.hasNoChildren()){throw new Error("cannot get first child of a "+this.ctorName+" node, which has no children")}else{return this.childAt(0)}};Node.prototype.lastChild=function(){if(this.hasNoChildren()){throw new Error("cannot get last child of a "+this.ctorName+" node, which has no children")}else{return this.childAt(this.numChildren()-1)}};Node.prototype.childBefore=function(child){var childIdx=this.indexOfChild(child);if(childIdx<0){throw new Error("Node.childBefore() called w/ an argument that is not a child")}else if(childIdx===0){throw new Error("cannot get child before first child")}else{return this.childAt(childIdx-1)}};Node.prototype.childAfter=function(child){var childIdx=this.indexOfChild(child);if(childIdx<0){throw new Error("Node.childAfter() called w/ an argument that is not a child")}else if(childIdx===this.numChildren()-1){throw new Error("cannot get child after last child")}else{return this.childAt(childIdx+1)}};Node.prototype.isTerminal=function(){return false};Node.prototype.toJSON=function(){var r={};r[this.ctorName]=this.children;return r};function TerminalNode(grammar,value,interval){Node.call(this,grammar,"_terminal",[],interval);this.primitiveValue=value}inherits(TerminalNode,Node);TerminalNode.prototype.isTerminal=function(){return true};module.exports={Node:Node,TerminalNode:TerminalNode}},{inherits:12}],30:[function(_dereq_,module,exports){"use strict";var common=_dereq_("./common");var pexprs=_dereq_("./pexprs");var errors=_dereq_("./errors");pexprs.PExpr.prototype.assertAllApplicationsAreValid=common.abstract;pexprs.anything.assertAllApplicationsAreValid=function(grammar){};pexprs.end.assertAllApplicationsAreValid=function(grammar){};pexprs.Prim.prototype.assertAllApplicationsAreValid=function(grammar){};pexprs.Param.prototype.assertAllApplicationsAreValid=function(grammar){};pexprs.Alt.prototype.assertAllApplicationsAreValid=function(grammar){for(var idx=0;idx=1};pexprs.end.check=function(grammar,vals){return vals[0]instanceof nodes.Node&&vals[0].isTerminal()&&vals[0].primitiveValue===undefined};pexprs.Prim.prototype.check=function(grammar,vals){return vals[0]instanceof nodes.Node&&vals[0].isTerminal()&&vals[0].primitiveValue===this.obj};pexprs.Param.prototype.check=function(grammar,vals){return vals.length>=1};pexprs.RegExpPrim.prototype.check=function(grammar,vals){return vals[0]instanceof nodes.Node&&vals[0].isTerminal()&&typeof vals[0].primitiveValue==="string"&&vals[0].primitiveValue.replace(this.obj,"")===""};pexprs.Alt.prototype.check=function(grammar,vals){for(var i=0;i1?state.applicationStack[state.applicationStack.length-1].params:[];var app=this.substituteParams(actuals);var ruleName=app.ruleName;var memoKey=app.toMemoKey();if(common.isSyntactic(ruleName)){skipSpaces(state)}var origPosInfo=state.getCurrentPosInfo();var memoRec=origPosInfo.memo[memoKey];var currentLR;if(memoRec&&origPosInfo.shouldUseMemoizedResult(memoRec)){return useMemoizedResult(memoRec)}else if(origPosInfo.isActive(app)){currentLR=origPosInfo.getCurrentLeftRecursion();if(currentLR&¤tLR.memoKey===memoKey){origPosInfo.updateInvolvedApplications();return useMemoizedResult(currentLR)}else{origPosInfo.startLeftRecursion(app);return false}}else{var body=grammar.ruleDict[ruleName];var origPos=inputStream.pos;origPosInfo.enter(app);if(body.description){state.ignoreFailures()}var value=app.evalOnce(body,state,inputStream,origPos);currentLR=origPosInfo.getCurrentLeftRecursion();if(currentLR){if(currentLR.memoKey===memoKey){value=app.handleLeftRecursion(body,state,origPos,currentLR,value);origPosInfo.memo[memoKey]={pos:inputStream.pos,value:value,involvedApplications:currentLR.involvedApplications};origPosInfo.endLeftRecursion(app)}else if(!currentLR.involvedApplications[memoKey]){origPosInfo.memo[memoKey]={pos:inputStream.pos,value:value}}}else{origPosInfo.memo[memoKey]={pos:inputStream.pos,value:value}}if(body.description){state.recordFailures();if(!value){state.recordFailure(origPos,app)}}if(state.isTracing()&&origPosInfo.memo[memoKey]){var entry=state.getTraceEntry(origPos,app,value);entry.setLeftRecursive(currentLR&¤tLR.memoKey===memoKey);origPosInfo.memo[memoKey].traceEntry=entry}var ans;if(value){bindings.push(value);if(state.applicationStack.length===1){if(common.isSyntactic(ruleName)){skipSpaces(state)}ans=pexprs.end.eval(state);bindings.pop()}else{ans=true}}else{ans=false}origPosInfo.exit();return ans}};pexprs.Apply.prototype.evalOnce=function(expr,state,inputStream,origPos){if(expr.eval(state)){var arity=expr.getArity();var bindings=state.bindings.splice(state.bindings.length-arity,arity);var ans=new Node(state.grammar,this.ruleName,bindings,inputStream.intervalFrom(origPos));return ans}else{return false}};pexprs.Apply.prototype.handleLeftRecursion=function(body,state,origPos,currentLR,seedValue){if(!seedValue){return seedValue}var inputStream=state.inputStream;var value=seedValue;currentLR.value=seedValue;currentLR.pos=inputStream.pos;while(true){if(state.isTracing()){currentLR.traceEntry=common.clone(state.trace[state.trace.length-1])}inputStream.pos=origPos;value=this.evalOnce(body,state,inputStream,origPos);if(value&&inputStream.pos>currentLR.pos){currentLR.value=value;currentLR.pos=inputStream.pos}else{inputStream.pos=currentLR.pos;if(state.isTracing()){state.trace.pop()}break}}return currentLR.value}},{"./InputStream":18,"./common":26,"./nodes":29,"./pexprs":44}],35:[function(_dereq_,module,exports){"use strict";var pexprs=_dereq_("./pexprs");pexprs.PExpr.prototype.getArity=function(){return 1};pexprs.Alt.prototype.getArity=function(){return this.terms.length===0?0:this.terms[0].getArity()};pexprs.Seq.prototype.getArity=function(){var arity=0;for(var idx=0;idx=0){if(this.params.length>0){throw new Error("FIXME: should catch this earlier")}return new pexprs.Param(index)}else{this.params.forEach(function(param,idx,params){params[idx]=param.introduceParams(formals)});return this}}},{"./pexprs":44}],37:[function(_dereq_,module,exports){"use strict";var pexprs=_dereq_("./pexprs");pexprs.PExpr.prototype.isNullable=function(grammar){return this._isNullable(grammar,Object.create(null))};pexprs.PExpr.prototype._isNullable=function(grammar,memo){return false};pexprs.end._isNullable=function(grammar,memo){return true};pexprs.StringPrim.prototype._isNullable=function(grammar,memo){return this.obj===""};pexprs.Alt.prototype._isNullable=function(grammar,memo){return this.terms.length===0||this.terms.some(function(term){return term._isNullable(grammar,memo)})};pexprs.Seq.prototype._isNullable=function(grammar,memo){return this.factors.every(function(factor){return factor._isNullable(grammar,memo)})};pexprs.Star.prototype._isNullable=pexprs.Opt.prototype._isNullable=pexprs.Not.prototype._isNullable=pexprs.Lookahead.prototype._isNullable=function(grammar,memo){return true};pexprs.Str.prototype._isNullable=function(grammar,memo){return this.expr._isNullable(grammar,memo)};pexprs.Apply.prototype._isNullable=function(grammar,memo){var key=this.toMemoKey();if(!Object.prototype.hasOwnProperty.call(memo,key)){var body=grammar.ruleDict[this.ruleName];var inlined=body.substituteParams(this.params);memo[key]=false;memo[key]=inlined._isNullable(grammar,memo)}return memo[key]}},{"./pexprs":44}],38:[function(_dereq_,module,exports){"use strict";var pexprs=_dereq_("./pexprs");pexprs.PExpr.prototype.maybeRecordFailure=function(state,startPos){};pexprs.anything.maybeRecordFailure=pexprs.end.maybeRecordFailure=pexprs.Prim.prototype.maybeRecordFailure=pexprs.Not.prototype.maybeRecordFailure=function(state,startPos){state.recordFailure(startPos,this)}},{"./pexprs":44}],39:[function(_dereq_,module,exports){"use strict";var common=_dereq_("./common");var pexprs=_dereq_("./pexprs");pexprs.PExpr.prototype.outputRecipe=common.abstract;pexprs.anything.outputRecipe=function(sb,formals){sb.append("this.anything()")};pexprs.end.outputRecipe=function(sb,formals){sb.append("this.end()")};pexprs.Prim.prototype.outputRecipe=function(sb,formals){sb.append("this.prim(");sb.append(typeof this.obj==="string"?common.toStringLiteral(this.obj):""+this.obj);sb.append(")")};pexprs.Param.prototype.outputRecipe=function(sb,formals){sb.append("this.param("+this.index+")")};pexprs.Alt.prototype.outputRecipe=function(sb,formals){sb.append("this.alt(");for(var idx=0;idx0){sb.append(", ")}this.terms[idx].outputRecipe(sb,formals)}sb.append(")")};pexprs.Seq.prototype.outputRecipe=function(sb,formals){sb.append("this.seq(");for(var idx=0;idx0){sb.append(", ")}this.factors[idx].outputRecipe(sb,formals)}sb.append(")")};pexprs.Star.prototype.outputRecipe=function(sb,formals){sb.append("this.star(");this.expr.outputRecipe(sb,formals);sb.append(")")};pexprs.Plus.prototype.outputRecipe=function(sb,formals){sb.append("this.plus(");this.expr.outputRecipe(sb,formals);sb.append(")")};pexprs.Opt.prototype.outputRecipe=function(sb,formals){sb.append("this.opt(");this.expr.outputRecipe(sb,formals);sb.append(")")};pexprs.Not.prototype.outputRecipe=function(sb,formals){sb.append("this.not(");this.expr.outputRecipe(sb,formals);sb.append(")")};pexprs.Lookahead.prototype.outputRecipe=function(sb,formals){sb.append("this.la(");this.expr.outputRecipe(sb,formals);sb.append(")")};pexprs.Arr.prototype.outputRecipe=function(sb,formals){sb.append("this.arr(");this.expr.outputRecipe(sb,formals);sb.append(")")};pexprs.Str.prototype.outputRecipe=function(sb,formals){sb.append("this.str(");this.expr.outputRecipe(sb,formals);sb.append(")")};pexprs.Obj.prototype.outputRecipe=function(sb,formals){function outputPropertyRecipe(prop){sb.append("{name: ");sb.append(common.toStringLiteral(prop.name));sb.append(", pattern: ");prop.pattern.outputRecipe(sb,formals);sb.append("}")}sb.append("this.obj([");for(var idx=0;idx0){sb.append(", ")}outputPropertyRecipe(this.properties[idx])}sb.append("], ");sb.append(!!this.isLenient);sb.append(")")};pexprs.Apply.prototype.outputRecipe=function(sb,formals){sb.append("this.app(");sb.append(common.toStringLiteral(this.ruleName));if(this.ruleName.indexOf("_")>=0&&formals.length>0){var apps=formals.map(function(formal){return"this.app("+common.toStringLiteral(formal)+")"});sb.append(", ["+apps.join(", ")+"]")}else if(this.params.length>0){sb.append(", [");this.params.forEach(function(param,idx){if(idx>0){sb.append(", ")}param.outputRecipe(sb,formals)});sb.append("]")}sb.append(")")}},{"./common":26,"./pexprs":44}],40:[function(_dereq_,module,exports){"use strict";var pexprs=_dereq_("./pexprs");pexprs.PExpr.prototype.substituteParams=function(actuals){return this};pexprs.Param.prototype.substituteParams=function(actuals){return actuals[this.index]};pexprs.Alt.prototype.substituteParams=function(actuals){return new pexprs.Alt(this.terms.map(function(term){return term.substituteParams(actuals)}))};pexprs.Seq.prototype.substituteParams=function(actuals){return new pexprs.Seq(this.factors.map(function(factor){return factor.substituteParams(actuals)}))};pexprs.Iter.prototype.substituteParams=pexprs.Not.prototype.substituteParams=pexprs.Lookahead.prototype.substituteParams=pexprs.Arr.prototype.substituteParams=pexprs.Str.prototype.substituteParams=function(actuals){return new this.constructor(this.expr.substituteParams(actuals))};pexprs.Obj.prototype.substituteParams=function(actuals){var properties=this.properties.map(function(property){return{name:property.name,pattern:property.pattern.substituteParams(actuals)}});return new pexprs.Obj(properties,this.isLenient)};pexprs.Apply.prototype.substituteParams=function(actuals){if(this.params.length===0){return this}else{var params=this.params.map(function(param){return param.substituteParams(actuals)});return new pexprs.Apply(this.ruleName,params)}}},{"./pexprs":44}],41:[function(_dereq_,module,exports){"use strict";var pexprs=_dereq_("./pexprs");pexprs.PExpr.prototype.toDisplayString=function(){if(this.interval){return this.interval.trimmed().contents}return"["+this.constructor.name+"]"};pexprs.anything.toDisplayString=function(){return"_"};pexprs.end.toDisplayString=function(){return"end"};pexprs.Prim.prototype.toDisplayString=function(){return String(this.obj)};pexprs.Param.prototype.toDisplayString=function(){return"#"+this.index};pexprs.StringPrim.prototype.toDisplayString=function(){return'"'+this.obj+'"'};pexprs.Apply.prototype.toDisplayString=function(){return this.ruleName}},{"./pexprs":44}],42:[function(_dereq_,module,exports){"use strict";var common=_dereq_("./common");var pexprs=_dereq_("./pexprs");pexprs.PExpr.prototype.toExpected=function(ruleDict){return undefined};pexprs.anything.toExpected=function(ruleDict){return"any object"};pexprs.end.toExpected=function(ruleDict){return"end of input"};pexprs.Prim.prototype.toExpected=function(ruleDict){return common.toStringLiteral(this.obj)};pexprs.Not.prototype.toExpected=function(ruleDict){if(this.expr===pexprs.anything){return"nothing"}else{return"not "+this.expr.toExpected(ruleDict)}};pexprs.Apply.prototype.toExpected=function(ruleDict){var description=ruleDict[this.ruleName].description;if(description){return description}else{var article=/^[aeiouAEIOU]/.test(this.ruleName)?"an":"a";return article+" "+this.ruleName}}},{"./common":26,"./pexprs":44}],43:[function(_dereq_,module,exports){"use strict";var common=_dereq_("./common");var pexprs=_dereq_("./pexprs");pexprs.PExpr.prototype.toString=common.abstract;pexprs.anything.toString=function(){return"_"};pexprs.end.toString=function(){return"end"};pexprs.Prim.prototype.toString=function(){return JSON.stringify(this.obj)};pexprs.Param.prototype.toString=function(){return"#"+this.index};pexprs.RegExpPrim.prototype.toString=function(){return this.obj.toString()};pexprs.Alt.prototype.toString=function(){return this.terms.length===1?this.terms[0].toString():"("+this.terms.map(function(term){return term.toString()}).join(" | ")+")"};pexprs.Seq.prototype.toString=function(){return this.factors.length===1?this.factors[0].toString():"("+this.factors.map(function(factor){return factor.toString()}).join(" ")+")"};pexprs.Iter.prototype.toString=function(){return this.expr+this.operator};pexprs.Not.prototype.toString=function(){return"~"+this.expr};pexprs.Lookahead.prototype.toString=function(){return"&"+this.expr};pexprs.Arr.prototype.toString=function(){return"["+this.expr.toString()+"]"};pexprs.Str.prototype.toString=function(){return"``"+this.expr.toString()+"''"};pexprs.Obj.prototype.toString=function(){var parts=["{"];var first=true;function emit(part){if(first){first=false}else{parts.push(", ")}parts.push(part)}this.properties.forEach(function(property){emit(JSON.stringify(property.name)+": "+property.pattern.toString())});if(this.isLenient){emit("...")}parts.push("}");return parts.join("")};pexprs.Apply.prototype.toString=function(){if(this.params.length>0){var ps=this.params.map(function(param){return param.toString()});return this.ruleName+"<"+ps.join(",")+">"}else{return this.ruleName}}},{"./common":26,"./pexprs":44}],44:[function(_dereq_,module,exports){"use strict";var common=_dereq_("./common");var errors=_dereq_("./errors");var inherits=_dereq_("inherits");function PExpr(){throw new Error("PExpr cannot be instantiated -- it's abstract")}PExpr.prototype.withDescription=function(description){this.description=description;return this};PExpr.prototype.withInterval=function(interval){this.interval=interval.trimmed();return this};PExpr.prototype.withFormals=function(formals){this.formals=formals;return this};var anything=Object.create(PExpr.prototype);var end=Object.create(PExpr.prototype);function Prim(obj){this.obj=obj}inherits(Prim,PExpr); +function StringPrim(obj){this.obj=obj}inherits(StringPrim,Prim);function RegExpPrim(obj){this.obj=obj}inherits(RegExpPrim,Prim);function Param(index){this.index=index}inherits(Param,PExpr);function Alt(terms){this.terms=terms}inherits(Alt,PExpr);function Extend(superGrammar,name,body){var origBody=superGrammar.ruleDict[name];this.terms=[body,origBody]}inherits(Extend,Alt);function Seq(factors){this.factors=factors}inherits(Seq,PExpr);function Iter(expr){this.expr=expr}inherits(Iter,PExpr);function Star(expr){this.expr=expr}inherits(Star,Iter);function Plus(expr){this.expr=expr}inherits(Plus,Iter);function Opt(expr){this.expr=expr}inherits(Opt,Iter);Star.prototype.operator="*";Plus.prototype.operator="+";Opt.prototype.operator="?";Star.prototype.minNumMatches=0;Plus.prototype.minNumMatches=1;Opt.prototype.minNumMatches=0;Star.prototype.maxNumMatches=Number.POSITIVE_INFINITY;Plus.prototype.maxNumMatches=Number.POSITIVE_INFINITY;Opt.prototype.maxNumMatches=1;function Not(expr){this.expr=expr}inherits(Not,PExpr);function Lookahead(expr){this.expr=expr}inherits(Lookahead,PExpr);function Arr(expr){this.expr=expr}inherits(Arr,PExpr);function Str(expr){this.expr=expr}inherits(Str,PExpr);function Obj(properties,isLenient){var names=properties.map(function(property){return property.name});var duplicates=common.getDuplicates(names);if(duplicates.length>0){throw new errors.DuplicatePropertyNames(duplicates)}else{this.properties=properties;this.isLenient=isLenient}}inherits(Obj,PExpr);function Apply(ruleName,optParams){this.ruleName=ruleName;this.params=optParams||[]}inherits(Apply,PExpr);Apply.prototype.toMemoKey=function(){if(!this._memoKey){Object.defineProperty(this,"_memoKey",{value:this.toString()})}return this._memoKey};exports.makePrim=function(obj){if(typeof obj==="string"&&obj.length!==1){return new StringPrim(obj)}else if(obj instanceof RegExp){return new RegExpPrim(obj)}else{return new Prim(obj)}};exports.PExpr=PExpr;exports.anything=anything;exports.end=end;exports.Prim=Prim;exports.StringPrim=StringPrim;exports.RegExpPrim=RegExpPrim;exports.Param=Param;exports.Alt=Alt;exports.Extend=Extend;exports.Seq=Seq;exports.Iter=Iter;exports.Star=Star;exports.Plus=Plus;exports.Opt=Opt;exports.Not=Not;exports.Lookahead=Lookahead;exports.Arr=Arr;exports.Str=Str;exports.Obj=Obj;exports.Apply=Apply;_dereq_("./pexprs-assertAllApplicationsAreValid");_dereq_("./pexprs-assertChoicesHaveUniformArity");_dereq_("./pexprs-assertIteratedExprsAreNotNullable");_dereq_("./pexprs-check");_dereq_("./pexprs-eval");_dereq_("./pexprs-maybeRecordFailure");_dereq_("./pexprs-getArity");_dereq_("./pexprs-outputRecipe");_dereq_("./pexprs-introduceParams");_dereq_("./pexprs-isNullable");_dereq_("./pexprs-substituteParams");_dereq_("./pexprs-toDisplayString");_dereq_("./pexprs-toExpected");_dereq_("./pexprs-toString")},{"./common":26,"./errors":27,"./pexprs-assertAllApplicationsAreValid":30,"./pexprs-assertChoicesHaveUniformArity":31,"./pexprs-assertIteratedExprsAreNotNullable":32,"./pexprs-check":33,"./pexprs-eval":34,"./pexprs-getArity":35,"./pexprs-introduceParams":36,"./pexprs-isNullable":37,"./pexprs-maybeRecordFailure":38,"./pexprs-outputRecipe":39,"./pexprs-substituteParams":40,"./pexprs-toDisplayString":41,"./pexprs-toExpected":42,"./pexprs-toString":43,inherits:12}],45:[function(_dereq_,module,exports){"use strict";var common=_dereq_("./common");function padNumbersToEqualLength(arr){var maxLen=0;var strings=arr.map(function(n){var str=n.toString();maxLen=Math.max(maxLen,str.length);return str});return strings.map(function(s){return common.padLeft(s,maxLen)})}function strcpy(dest,src,offset){var origDestLen=dest.length;var start=dest.slice(0,offset);var end=dest.slice(offset+src.length);return(start+src+end).substr(0,origDestLen)}exports.getLineAndColumn=function(str,offset){var lineNum=1;var colNum=1;var currOffset=0;var lineStartOffset=0;var nextLine=null;var prevLine=null;var prevLineStartOffset=-1;while(currOffset=0){prevLine=str.slice(prevLineStartOffset,lineStartOffset).replace(/\r?\n$/,"")}var line=str.slice(lineStartOffset,lineEndOffset).replace(/\r$/,"");return{lineNum:lineNum,colNum:colNum,line:line,prevLine:prevLine,nextLine:nextLine}};exports.getLineAndColumnMessage=function(str,offset){var repeatStr=common.repeatStr;var lineAndCol=exports.getLineAndColumn(str,offset);var sb=new common.StringBuffer;sb.append("Line "+lineAndCol.lineNum+", col "+lineAndCol.colNum+":\n");var lineNumbers=padNumbersToEqualLength([lineAndCol.prevLine==null?0:lineAndCol.lineNum-1,lineAndCol.lineNum,lineAndCol.nextLine==null?0:lineAndCol.lineNum+1]);function appendLine(num,content,prefix){sb.append(prefix+lineNumbers[num]+" | "+content+"\n")}if(lineAndCol.prevLine!=null){appendLine(0,lineAndCol.prevLine," ")}appendLine(1,lineAndCol.line,"> ");var lineLen=lineAndCol.line.length;var indicationLine=repeatStr(" ",lineLen+1);var ranges=Array.prototype.slice.call(arguments,2);for(var i=0;i=0&&startIdx<=endIdx,"range start must be >= 0 and <= end");var lineStartOffset=offset-lineAndCol.colNum+1;startIdx=Math.max(0,startIdx-lineStartOffset);endIdx=Math.min(endIdx-lineStartOffset,lineLen);indicationLine=strcpy(indicationLine,repeatStr("~",endIdx-startIdx),startIdx)}var gutterWidth=2+lineNumbers[1].length+3;sb.append(repeatStr(" ",gutterWidth));indicationLine=strcpy(indicationLine,"^",lineAndCol.colNum-1);sb.append(indicationLine.replace(/ +$/,"")+"\n");if(lineAndCol.nextLine!=null){appendLine(2,lineAndCol.nextLine," ")}return sb.contents()}},{"./common":26}],46:[function(_dereq_,module,exports){exports.UnicodeCategories={ZWNJ:/\u200C/,ZWJ:/\u200D/,TAB:/\u0009/,VT:/\u000B/,FF:/\u000C/,SP:/\u0020/,NBSP:/\u00A0/,BOM:/\uFEFF/,LF:/\u000A/,CR:/\u000D/,LS:/\u2028/,PS:/\u2029/,L:/[\u0041-\u005A]|[\u00C0-\u00D6]|[\u00D8-\u00DE]|[\u0100-\u0100]|[\u0102-\u0102]|[\u0104-\u0104]|[\u0106-\u0106]|[\u0108-\u0108]|[\u010A-\u010A]|[\u010C-\u010C]|[\u010E-\u010E]|[\u0110-\u0110]|[\u0112-\u0112]|[\u0114-\u0114]|[\u0116-\u0116]|[\u0118-\u0118]|[\u011A-\u011A]|[\u011C-\u011C]|[\u011E-\u011E]|[\u0120-\u0120]|[\u0122-\u0122]|[\u0124-\u0124]|[\u0126-\u0126]|[\u0128-\u0128]|[\u012A-\u012A]|[\u012C-\u012C]|[\u012E-\u012E]|[\u0130-\u0130]|[\u0132-\u0132]|[\u0134-\u0134]|[\u0136-\u0136]|[\u0139-\u0139]|[\u013B-\u013B]|[\u013D-\u013D]|[\u013F-\u013F]|[\u0141-\u0141]|[\u0143-\u0143]|[\u0145-\u0145]|[\u0147-\u0147]|[\u014A-\u014A]|[\u014C-\u014C]|[\u014E-\u014E]|[\u0150-\u0150]|[\u0152-\u0152]|[\u0154-\u0154]|[\u0156-\u0156]|[\u0158-\u0158]|[\u015A-\u015A]|[\u015C-\u015C]|[\u015E-\u015E]|[\u0160-\u0160]|[\u0162-\u0162]|[\u0164-\u0164]|[\u0166-\u0166]|[\u0168-\u0168]|[\u016A-\u016A]|[\u016C-\u016C]|[\u016E-\u016E]|[\u0170-\u0170]|[\u0172-\u0172]|[\u0174-\u0174]|[\u0176-\u0176]|[\u0178-\u0179]|[\u017B-\u017B]|[\u017D-\u017D]|[\u0181-\u0182]|[\u0184-\u0184]|[\u0186-\u0187]|[\u0189-\u018B]|[\u018E-\u0191]|[\u0193-\u0194]|[\u0196-\u0198]|[\u019C-\u019D]|[\u019F-\u01A0]|[\u01A2-\u01A2]|[\u01A4-\u01A4]|[\u01A6-\u01A7]|[\u01A9-\u01A9]|[\u01AC-\u01AC]|[\u01AE-\u01AF]|[\u01B1-\u01B3]|[\u01B5-\u01B5]|[\u01B7-\u01B8]|[\u01BC-\u01BC]|[\u01C4-\u01C4]|[\u01C7-\u01C7]|[\u01CA-\u01CA]|[\u01CD-\u01CD]|[\u01CF-\u01CF]|[\u01D1-\u01D1]|[\u01D3-\u01D3]|[\u01D5-\u01D5]|[\u01D7-\u01D7]|[\u01D9-\u01D9]|[\u01DB-\u01DB]|[\u01DE-\u01DE]|[\u01E0-\u01E0]|[\u01E2-\u01E2]|[\u01E4-\u01E4]|[\u01E6-\u01E6]|[\u01E8-\u01E8]|[\u01EA-\u01EA]|[\u01EC-\u01EC]|[\u01EE-\u01EE]|[\u01F1-\u01F1]|[\u01F4-\u01F4]|[\u01FA-\u01FA]|[\u01FC-\u01FC]|[\u01FE-\u01FE]|[\u0200-\u0200]|[\u0202-\u0202]|[\u0204-\u0204]|[\u0206-\u0206]|[\u0208-\u0208]|[\u020A-\u020A]|[\u020C-\u020C]|[\u020E-\u020E]|[\u0210-\u0210]|[\u0212-\u0212]|[\u0214-\u0214]|[\u0216-\u0216]|[\u0386-\u0386]|[\u0388-\u038A]|[\u038C-\u038C]|[\u038E-\u038F]|[\u0391-\u03A1]|[\u03A3-\u03AB]|[\u03D2-\u03D4]|[\u03DA-\u03DA]|[\u03DC-\u03DC]|[\u03DE-\u03DE]|[\u03E0-\u03E0]|[\u03E2-\u03E2]|[\u03E4-\u03E4]|[\u03E6-\u03E6]|[\u03E8-\u03E8]|[\u03EA-\u03EA]|[\u03EC-\u03EC]|[\u03EE-\u03EE]|[\u0401-\u040C]|[\u040E-\u042F]|[\u0460-\u0460]|[\u0462-\u0462]|[\u0464-\u0464]|[\u0466-\u0466]|[\u0468-\u0468]|[\u046A-\u046A]|[\u046C-\u046C]|[\u046E-\u046E]|[\u0470-\u0470]|[\u0472-\u0472]|[\u0474-\u0474]|[\u0476-\u0476]|[\u0478-\u0478]|[\u047A-\u047A]|[\u047C-\u047C]|[\u047E-\u047E]|[\u0480-\u0480]|[\u0490-\u0490]|[\u0492-\u0492]|[\u0494-\u0494]|[\u0496-\u0496]|[\u0498-\u0498]|[\u049A-\u049A]|[\u049C-\u049C]|[\u049E-\u049E]|[\u04A0-\u04A0]|[\u04A2-\u04A2]|[\u04A4-\u04A4]|[\u04A6-\u04A6]|[\u04A8-\u04A8]|[\u04AA-\u04AA]|[\u04AC-\u04AC]|[\u04AE-\u04AE]|[\u04B0-\u04B0]|[\u04B2-\u04B2]|[\u04B4-\u04B4]|[\u04B6-\u04B6]|[\u04B8-\u04B8]|[\u04BA-\u04BA]|[\u04BC-\u04BC]|[\u04BE-\u04BE]|[\u04C1-\u04C1]|[\u04C3-\u04C3]|[\u04C7-\u04C7]|[\u04CB-\u04CB]|[\u04D0-\u04D0]|[\u04D2-\u04D2]|[\u04D4-\u04D4]|[\u04D6-\u04D6]|[\u04D8-\u04D8]|[\u04DA-\u04DA]|[\u04DC-\u04DC]|[\u04DE-\u04DE]|[\u04E0-\u04E0]|[\u04E2-\u04E2]|[\u04E4-\u04E4]|[\u04E6-\u04E6]|[\u04E8-\u04E8]|[\u04EA-\u04EA]|[\u04EE-\u04EE]|[\u04F0-\u04F0]|[\u04F2-\u04F2]|[\u04F4-\u04F4]|[\u04F8-\u04F8]|[\u0531-\u0556]|[\u10A0-\u10C5]|[\u1E00-\u1E00]|[\u1E02-\u1E02]|[\u1E04-\u1E04]|[\u1E06-\u1E06]|[\u1E08-\u1E08]|[\u1E0A-\u1E0A]|[\u1E0C-\u1E0C]|[\u1E0E-\u1E0E]|[\u1E10-\u1E10]|[\u1E12-\u1E12]|[\u1E14-\u1E14]|[\u1E16-\u1E16]|[\u1E18-\u1E18]|[\u1E1A-\u1E1A]|[\u1E1C-\u1E1C]|[\u1E1E-\u1E1E]|[\u1E20-\u1E20]|[\u1E22-\u1E22]|[\u1E24-\u1E24]|[\u1E26-\u1E26]|[\u1E28-\u1E28]|[\u1E2A-\u1E2A]|[\u1E2C-\u1E2C]|[\u1E2E-\u1E2E]|[\u1E30-\u1E30]|[\u1E32-\u1E32]|[\u1E34-\u1E34]|[\u1E36-\u1E36]|[\u1E38-\u1E38]|[\u1E3A-\u1E3A]|[\u1E3C-\u1E3C]|[\u1E3E-\u1E3E]|[\u1E40-\u1E40]|[\u1E42-\u1E42]|[\u1E44-\u1E44]|[\u1E46-\u1E46]|[\u1E48-\u1E48]|[\u1E4A-\u1E4A]|[\u1E4C-\u1E4C]|[\u1E4E-\u1E4E]|[\u1E50-\u1E50]|[\u1E52-\u1E52]|[\u1E54-\u1E54]|[\u1E56-\u1E56]|[\u1E58-\u1E58]|[\u1E5A-\u1E5A]|[\u1E5C-\u1E5C]|[\u1E5E-\u1E5E]|[\u1E60-\u1E60]|[\u1E62-\u1E62]|[\u1E64-\u1E64]|[\u1E66-\u1E66]|[\u1E68-\u1E68]|[\u1E6A-\u1E6A]|[\u1E6C-\u1E6C]|[\u1E6E-\u1E6E]|[\u1E70-\u1E70]|[\u1E72-\u1E72]|[\u1E74-\u1E74]|[\u1E76-\u1E76]|[\u1E78-\u1E78]|[\u1E7A-\u1E7A]|[\u1E7C-\u1E7C]|[\u1E7E-\u1E7E]|[\u1E80-\u1E80]|[\u1E82-\u1E82]|[\u1E84-\u1E84]|[\u1E86-\u1E86]|[\u1E88-\u1E88]|[\u1E8A-\u1E8A]|[\u1E8C-\u1E8C]|[\u1E8E-\u1E8E]|[\u1E90-\u1E90]|[\u1E92-\u1E92]|[\u1E94-\u1E94]|[\u1EA0-\u1EA0]|[\u1EA2-\u1EA2]|[\u1EA4-\u1EA4]|[\u1EA6-\u1EA6]|[\u1EA8-\u1EA8]|[\u1EAA-\u1EAA]|[\u1EAC-\u1EAC]|[\u1EAE-\u1EAE]|[\u1EB0-\u1EB0]|[\u1EB2-\u1EB2]|[\u1EB4-\u1EB4]|[\u1EB6-\u1EB6]|[\u1EB8-\u1EB8]|[\u1EBA-\u1EBA]|[\u1EBC-\u1EBC]|[\u1EBE-\u1EBE]|[\u1EC0-\u1EC0]|[\u1EC2-\u1EC2]|[\u1EC4-\u1EC4]|[\u1EC6-\u1EC6]|[\u1EC8-\u1EC8]|[\u1ECA-\u1ECA]|[\u1ECC-\u1ECC]|[\u1ECE-\u1ECE]|[\u1ED0-\u1ED0]|[\u1ED2-\u1ED2]|[\u1ED4-\u1ED4]|[\u1ED6-\u1ED6]|[\u1ED8-\u1ED8]|[\u1EDA-\u1EDA]|[\u1EDC-\u1EDC]|[\u1EDE-\u1EDE]|[\u1EE0-\u1EE0]|[\u1EE2-\u1EE2]|[\u1EE4-\u1EE4]|[\u1EE6-\u1EE6]|[\u1EE8-\u1EE8]|[\u1EEA-\u1EEA]|[\u1EEC-\u1EEC]|[\u1EEE-\u1EEE]|[\u1EF0-\u1EF0]|[\u1EF2-\u1EF2]|[\u1EF4-\u1EF4]|[\u1EF6-\u1EF6]|[\u1EF8-\u1EF8]|[\u1F08-\u1F0F]|[\u1F18-\u1F1D]|[\u1F28-\u1F2F]|[\u1F38-\u1F3F]|[\u1F48-\u1F4D]|[\u1F59-\u1F59]|[\u1F5B-\u1F5B]|[\u1F5D-\u1F5D]|[\u1F5F-\u1F5F]|[\u1F68-\u1F6F]|[\u1F88-\u1F8F]|[\u1F98-\u1F9F]|[\u1FA8-\u1FAF]|[\u1FB8-\u1FBC]|[\u1FC8-\u1FCC]|[\u1FD8-\u1FDB]|[\u1FE8-\u1FEC]|[\u1FF8-\u1FFC]|[\u2102-\u2102]|[\u2107-\u2107]|[\u210B-\u210D]|[\u2110-\u2112]|[\u2115-\u2115]|[\u2119-\u211D]|[\u2124-\u2124]|[\u2126-\u2126]|[\u2128-\u2128]|[\u212A-\u212D]|[\u2130-\u2131]|[\u2133-\u2133]|[\uFF21-\uFF3A]|[\u0061-\u007A]|[\u00AA-\u00AA]|[\u00B5-\u00B5]|[\u00BA-\u00BA]|[\u00DF-\u00F6]|[\u00F8-\u00FF]|[\u0101-\u0101]|[\u0103-\u0103]|[\u0105-\u0105]|[\u0107-\u0107]|[\u0109-\u0109]|[\u010B-\u010B]|[\u010D-\u010D]|[\u010F-\u010F]|[\u0111-\u0111]|[\u0113-\u0113]|[\u0115-\u0115]|[\u0117-\u0117]|[\u0119-\u0119]|[\u011B-\u011B]|[\u011D-\u011D]|[\u011F-\u011F]|[\u0121-\u0121]|[\u0123-\u0123]|[\u0125-\u0125]|[\u0127-\u0127]|[\u0129-\u0129]|[\u012B-\u012B]|[\u012D-\u012D]|[\u012F-\u012F]|[\u0131-\u0131]|[\u0133-\u0133]|[\u0135-\u0135]|[\u0137-\u0138]|[\u013A-\u013A]|[\u013C-\u013C]|[\u013E-\u013E]|[\u0140-\u0140]|[\u0142-\u0142]|[\u0144-\u0144]|[\u0146-\u0146]|[\u0148-\u0149]|[\u014B-\u014B]|[\u014D-\u014D]|[\u014F-\u014F]|[\u0151-\u0151]|[\u0153-\u0153]|[\u0155-\u0155]|[\u0157-\u0157]|[\u0159-\u0159]|[\u015B-\u015B]|[\u015D-\u015D]|[\u015F-\u015F]|[\u0161-\u0161]|[\u0163-\u0163]|[\u0165-\u0165]|[\u0167-\u0167]|[\u0169-\u0169]|[\u016B-\u016B]|[\u016D-\u016D]|[\u016F-\u016F]|[\u0171-\u0171]|[\u0173-\u0173]|[\u0175-\u0175]|[\u0177-\u0177]|[\u017A-\u017A]|[\u017C-\u017C]|[\u017E-\u0180]|[\u0183-\u0183]|[\u0185-\u0185]|[\u0188-\u0188]|[\u018C-\u018D]|[\u0192-\u0192]|[\u0195-\u0195]|[\u0199-\u019B]|[\u019E-\u019E]|[\u01A1-\u01A1]|[\u01A3-\u01A3]|[\u01A5-\u01A5]|[\u01A8-\u01A8]|[\u01AB-\u01AB]|[\u01AD-\u01AD]|[\u01B0-\u01B0]|[\u01B4-\u01B4]|[\u01B6-\u01B6]|[\u01B9-\u01BA]|[\u01BD-\u01BD]|[\u01C6-\u01C6]|[\u01C9-\u01C9]|[\u01CC-\u01CC]|[\u01CE-\u01CE]|[\u01D0-\u01D0]|[\u01D2-\u01D2]|[\u01D4-\u01D4]|[\u01D6-\u01D6]|[\u01D8-\u01D8]|[\u01DA-\u01DA]|[\u01DC-\u01DD]|[\u01DF-\u01DF]|[\u01E1-\u01E1]|[\u01E3-\u01E3]|[\u01E5-\u01E5]|[\u01E7-\u01E7]|[\u01E9-\u01E9]|[\u01EB-\u01EB]|[\u01ED-\u01ED]|[\u01EF-\u01F0]|[\u01F3-\u01F3]|[\u01F5-\u01F5]|[\u01FB-\u01FB]|[\u01FD-\u01FD]|[\u01FF-\u01FF]|[\u0201-\u0201]|[\u0203-\u0203]|[\u0205-\u0205]|[\u0207-\u0207]|[\u0209-\u0209]|[\u020B-\u020B]|[\u020D-\u020D]|[\u020F-\u020F]|[\u0211-\u0211]|[\u0213-\u0213]|[\u0215-\u0215]|[\u0217-\u0217]|[\u0250-\u02A8]|[\u0390-\u0390]|[\u03AC-\u03CE]|[\u03D0-\u03D1]|[\u03D5-\u03D6]|[\u03E3-\u03E3]|[\u03E5-\u03E5]|[\u03E7-\u03E7]|[\u03E9-\u03E9]|[\u03EB-\u03EB]|[\u03ED-\u03ED]|[\u03EF-\u03F2]|[\u0430-\u044F]|[\u0451-\u045C]|[\u045E-\u045F]|[\u0461-\u0461]|[\u0463-\u0463]|[\u0465-\u0465]|[\u0467-\u0467]|[\u0469-\u0469]|[\u046B-\u046B]|[\u046D-\u046D]|[\u046F-\u046F]|[\u0471-\u0471]|[\u0473-\u0473]|[\u0475-\u0475]|[\u0477-\u0477]|[\u0479-\u0479]|[\u047B-\u047B]|[\u047D-\u047D]|[\u047F-\u047F]|[\u0481-\u0481]|[\u0491-\u0491]|[\u0493-\u0493]|[\u0495-\u0495]|[\u0497-\u0497]|[\u0499-\u0499]|[\u049B-\u049B]|[\u049D-\u049D]|[\u049F-\u049F]|[\u04A1-\u04A1]|[\u04A3-\u04A3]|[\u04A5-\u04A5]|[\u04A7-\u04A7]|[\u04A9-\u04A9]|[\u04AB-\u04AB]|[\u04AD-\u04AD]|[\u04AF-\u04AF]|[\u04B1-\u04B1]|[\u04B3-\u04B3]|[\u04B5-\u04B5]|[\u04B7-\u04B7]|[\u04B9-\u04B9]|[\u04BB-\u04BB]|[\u04BD-\u04BD]|[\u04BF-\u04BF]|[\u04C2-\u04C2]|[\u04C4-\u04C4]|[\u04C8-\u04C8]|[\u04CC-\u04CC]|[\u04D1-\u04D1]|[\u04D3-\u04D3]|[\u04D5-\u04D5]|[\u04D7-\u04D7]|[\u04D9-\u04D9]|[\u04DB-\u04DB]|[\u04DD-\u04DD]|[\u04DF-\u04DF]|[\u04E1-\u04E1]|[\u04E3-\u04E3]|[\u04E5-\u04E5]|[\u04E7-\u04E7]|[\u04E9-\u04E9]|[\u04EB-\u04EB]|[\u04EF-\u04EF]|[\u04F1-\u04F1]|[\u04F3-\u04F3]|[\u04F5-\u04F5]|[\u04F9-\u04F9]|[\u0561-\u0587]|[\u10D0-\u10F6]|[\u1E01-\u1E01]|[\u1E03-\u1E03]|[\u1E05-\u1E05]|[\u1E07-\u1E07]|[\u1E09-\u1E09]|[\u1E0B-\u1E0B]|[\u1E0D-\u1E0D]|[\u1E0F-\u1E0F]|[\u1E11-\u1E11]|[\u1E13-\u1E13]|[\u1E15-\u1E15]|[\u1E17-\u1E17]|[\u1E19-\u1E19]|[\u1E1B-\u1E1B]|[\u1E1D-\u1E1D]|[\u1E1F-\u1E1F]|[\u1E21-\u1E21]|[\u1E23-\u1E23]|[\u1E25-\u1E25]|[\u1E27-\u1E27]|[\u1E29-\u1E29]|[\u1E2B-\u1E2B]|[\u1E2D-\u1E2D]|[\u1E2F-\u1E2F]|[\u1E31-\u1E31]|[\u1E33-\u1E33]|[\u1E35-\u1E35]|[\u1E37-\u1E37]|[\u1E39-\u1E39]|[\u1E3B-\u1E3B]|[\u1E3D-\u1E3D]|[\u1E3F-\u1E3F]|[\u1E41-\u1E41]|[\u1E43-\u1E43]|[\u1E45-\u1E45]|[\u1E47-\u1E47]|[\u1E49-\u1E49]|[\u1E4B-\u1E4B]|[\u1E4D-\u1E4D]|[\u1E4F-\u1E4F]|[\u1E51-\u1E51]|[\u1E53-\u1E53]|[\u1E55-\u1E55]|[\u1E57-\u1E57]|[\u1E59-\u1E59]|[\u1E5B-\u1E5B]|[\u1E5D-\u1E5D]|[\u1E5F-\u1E5F]|[\u1E61-\u1E61]|[\u1E63-\u1E63]|[\u1E65-\u1E65]|[\u1E67-\u1E67]|[\u1E69-\u1E69]|[\u1E6B-\u1E6B]|[\u1E6D-\u1E6D]|[\u1E6F-\u1E6F]|[\u1E71-\u1E71]|[\u1E73-\u1E73]|[\u1E75-\u1E75]|[\u1E77-\u1E77]|[\u1E79-\u1E79]|[\u1E7B-\u1E7B]|[\u1E7D-\u1E7D]|[\u1E7F-\u1E7F]|[\u1E81-\u1E81]|[\u1E83-\u1E83]|[\u1E85-\u1E85]|[\u1E87-\u1E87]|[\u1E89-\u1E89]|[\u1E8B-\u1E8B]|[\u1E8D-\u1E8D]|[\u1E8F-\u1E8F]|[\u1E91-\u1E91]|[\u1E93-\u1E93]|[\u1E95-\u1E9B]|[\u1EA1-\u1EA1]|[\u1EA3-\u1EA3]|[\u1EA5-\u1EA5]|[\u1EA7-\u1EA7]|[\u1EA9-\u1EA9]|[\u1EAB-\u1EAB]|[\u1EAD-\u1EAD]|[\u1EAF-\u1EAF]|[\u1EB1-\u1EB1]|[\u1EB3-\u1EB3]|[\u1EB5-\u1EB5]|[\u1EB7-\u1EB7]|[\u1EB9-\u1EB9]|[\u1EBB-\u1EBB]|[\u1EBD-\u1EBD]|[\u1EBF-\u1EBF]|[\u1EC1-\u1EC1]|[\u1EC3-\u1EC3]|[\u1EC5-\u1EC5]|[\u1EC7-\u1EC7]|[\u1EC9-\u1EC9]|[\u1ECB-\u1ECB]|[\u1ECD-\u1ECD]|[\u1ECF-\u1ECF]|[\u1ED1-\u1ED1]|[\u1ED3-\u1ED3]|[\u1ED5-\u1ED5]|[\u1ED7-\u1ED7]|[\u1ED9-\u1ED9]|[\u1EDB-\u1EDB]|[\u1EDD-\u1EDD]|[\u1EDF-\u1EDF]|[\u1EE1-\u1EE1]|[\u1EE3-\u1EE3]|[\u1EE5-\u1EE5]|[\u1EE7-\u1EE7]|[\u1EE9-\u1EE9]|[\u1EEB-\u1EEB]|[\u1EED-\u1EED]|[\u1EEF-\u1EEF]|[\u1EF1-\u1EF1]|[\u1EF3-\u1EF3]|[\u1EF5-\u1EF5]|[\u1EF7-\u1EF7]|[\u1EF9-\u1EF9]|[\u1F00-\u1F07]|[\u1F10-\u1F15]|[\u1F20-\u1F27]|[\u1F30-\u1F37]|[\u1F40-\u1F45]|[\u1F50-\u1F57]|[\u1F60-\u1F67]|[\u1F70-\u1F7D]|[\u1F80-\u1F87]|[\u1F90-\u1F97]|[\u1FA0-\u1FA7]|[\u1FB0-\u1FB4]|[\u1FB6-\u1FB7]|[\u1FBE-\u1FBE]|[\u1FC2-\u1FC4]|[\u1FC6-\u1FC7]|[\u1FD0-\u1FD3]|[\u1FD6-\u1FD7]|[\u1FE0-\u1FE7]|[\u1FF2-\u1FF4]|[\u1FF6-\u1FF7]|[\u207F-\u207F]|[\u210A-\u210A]|[\u210E-\u210F]|[\u2113-\u2113]|[\u2118-\u2118]|[\u212E-\u212F]|[\u2134-\u2134]|[\uFB00-\uFB06]|[\uFB13-\uFB17]|[\uFF41-\uFF5A]|[\u01C5-\u01C5]|[\u01C8-\u01C8]|[\u01CB-\u01CB]|[\u01F2-\u01F2]|[\u02B0-\u02B8]|[\u02BB-\u02C1]|[\u02D0-\u02D1]|[\u02E0-\u02E4]|[\u037A-\u037A]|[\u0559-\u0559]|[\u0640-\u0640]|[\u06E5-\u06E6]|[\u0E46-\u0E46]|[\u0EC6-\u0EC6]|[\u3005-\u3005]|[\u3031-\u3035]|[\u309D-\u309E]|[\u30FC-\u30FE]|[\uFF70-\uFF70]|[\uFF9E-\uFF9F]|[\u01AA-\u01AA]|[\u01BB-\u01BB]|[\u01BE-\u01C3]|[\u03F3-\u03F3]|[\u04C0-\u04C0]|[\u05D0-\u05EA]|[\u05F0-\u05F2]|[\u0621-\u063A]|[\u0641-\u064A]|[\u0671-\u06B7]|[\u06BA-\u06BE]|[\u06C0-\u06CE]|[\u06D0-\u06D3]|[\u06D5-\u06D5]|[\u0905-\u0939]|[\u093D-\u093D]|[\u0950-\u0950]|[\u0958-\u0961]|[\u0985-\u098C]|[\u098F-\u0990]|[\u0993-\u09A8]|[\u09AA-\u09B0]|[\u09B2-\u09B2]|[\u09B6-\u09B9]|[\u09DC-\u09DD]|[\u09DF-\u09E1]|[\u09F0-\u09F1]|[\u0A05-\u0A0A]|[\u0A0F-\u0A10]|[\u0A13-\u0A28]|[\u0A2A-\u0A30]|[\u0A32-\u0A33]|[\u0A35-\u0A36]|[\u0A38-\u0A39]|[\u0A59-\u0A5C]|[\u0A5E-\u0A5E]|[\u0A72-\u0A74]|[\u0A85-\u0A8B]|[\u0A8D-\u0A8D]|[\u0A8F-\u0A91]|[\u0A93-\u0AA8]|[\u0AAA-\u0AB0]|[\u0AB2-\u0AB3]|[\u0AB5-\u0AB9]|[\u0ABD-\u0ABD]|[\u0AD0-\u0AD0]|[\u0AE0-\u0AE0]|[\u0B05-\u0B0C]|[\u0B0F-\u0B10]|[\u0B13-\u0B28]|[\u0B2A-\u0B30]|[\u0B32-\u0B33]|[\u0B36-\u0B39]|[\u0B3D-\u0B3D]|[\u0B5C-\u0B5D]|[\u0B5F-\u0B61]|[\u0B85-\u0B8A]|[\u0B8E-\u0B90]|[\u0B92-\u0B95]|[\u0B99-\u0B9A]|[\u0B9C-\u0B9C]|[\u0B9E-\u0B9F]|[\u0BA3-\u0BA4]|[\u0BA8-\u0BAA]|[\u0BAE-\u0BB5]|[\u0BB7-\u0BB9]|[\u0C05-\u0C0C]|[\u0C0E-\u0C10]|[\u0C12-\u0C28]|[\u0C2A-\u0C33]|[\u0C35-\u0C39]|[\u0C60-\u0C61]|[\u0C85-\u0C8C]|[\u0C8E-\u0C90]|[\u0C92-\u0CA8]|[\u0CAA-\u0CB3]|[\u0CB5-\u0CB9]|[\u0CDE-\u0CDE]|[\u0CE0-\u0CE1]|[\u0D05-\u0D0C]|[\u0D0E-\u0D10]|[\u0D12-\u0D28]|[\u0D2A-\u0D39]|[\u0D60-\u0D61]|[\u0E01-\u0E30]|[\u0E32-\u0E33]|[\u0E40-\u0E45]|[\u0E81-\u0E82]|[\u0E84-\u0E84]|[\u0E87-\u0E88]|[\u0E8A-\u0E8A]|[\u0E8D-\u0E8D]|[\u0E94-\u0E97]|[\u0E99-\u0E9F]|[\u0EA1-\u0EA3]|[\u0EA5-\u0EA5]|[\u0EA7-\u0EA7]|[\u0EAA-\u0EAB]|[\u0EAD-\u0EB0]|[\u0EB2-\u0EB3]|[\u0EBD-\u0EBD]|[\u0EC0-\u0EC4]|[\u0EDC-\u0EDD]|[\u0F00-\u0F00]|[\u0F40-\u0F47]|[\u0F49-\u0F69]|[\u0F88-\u0F8B]|[\u1100-\u1159]|[\u115F-\u11A2]|[\u11A8-\u11F9]|[\u2135-\u2138]|[\u3006-\u3006]|[\u3041-\u3094]|[\u30A1-\u30FA]|[\u3105-\u312C]|[\u3131-\u318E]|[\u4E00-\u9FA5]|[\uAC00-\uD7A3]|[\uF900-\uFA2D]|[\uFB1F-\uFB28]|[\uFB2A-\uFB36]|[\uFB38-\uFB3C]|[\uFB3E-\uFB3E]|[\uFB40-\uFB41]|[\uFB43-\uFB44]|[\uFB46-\uFBB1]|[\uFBD3-\uFD3D]|[\uFD50-\uFD8F]|[\uFD92-\uFDC7]|[\uFDF0-\uFDFB]|[\uFE70-\uFE72]|[\uFE74-\uFE74]|[\uFE76-\uFEFC]|[\uFF66-\uFF6F]|[\uFF71-\uFF9D]|[\uFFA0-\uFFBE]|[\uFFC2-\uFFC7]|[\uFFCA-\uFFCF]|[\uFFD2-\uFFD7]|[\uFFDA-\uFFDC]/,Lu:/[\u0041-\u005A]|[\u00C0-\u00D6]|[\u00D8-\u00DE]|[\u0100-\u0100]|[\u0102-\u0102]|[\u0104-\u0104]|[\u0106-\u0106]|[\u0108-\u0108]|[\u010A-\u010A]|[\u010C-\u010C]|[\u010E-\u010E]|[\u0110-\u0110]|[\u0112-\u0112]|[\u0114-\u0114]|[\u0116-\u0116]|[\u0118-\u0118]|[\u011A-\u011A]|[\u011C-\u011C]|[\u011E-\u011E]|[\u0120-\u0120]|[\u0122-\u0122]|[\u0124-\u0124]|[\u0126-\u0126]|[\u0128-\u0128]|[\u012A-\u012A]|[\u012C-\u012C]|[\u012E-\u012E]|[\u0130-\u0130]|[\u0132-\u0132]|[\u0134-\u0134]|[\u0136-\u0136]|[\u0139-\u0139]|[\u013B-\u013B]|[\u013D-\u013D]|[\u013F-\u013F]|[\u0141-\u0141]|[\u0143-\u0143]|[\u0145-\u0145]|[\u0147-\u0147]|[\u014A-\u014A]|[\u014C-\u014C]|[\u014E-\u014E]|[\u0150-\u0150]|[\u0152-\u0152]|[\u0154-\u0154]|[\u0156-\u0156]|[\u0158-\u0158]|[\u015A-\u015A]|[\u015C-\u015C]|[\u015E-\u015E]|[\u0160-\u0160]|[\u0162-\u0162]|[\u0164-\u0164]|[\u0166-\u0166]|[\u0168-\u0168]|[\u016A-\u016A]|[\u016C-\u016C]|[\u016E-\u016E]|[\u0170-\u0170]|[\u0172-\u0172]|[\u0174-\u0174]|[\u0176-\u0176]|[\u0178-\u0179]|[\u017B-\u017B]|[\u017D-\u017D]|[\u0181-\u0182]|[\u0184-\u0184]|[\u0186-\u0187]|[\u0189-\u018B]|[\u018E-\u0191]|[\u0193-\u0194]|[\u0196-\u0198]|[\u019C-\u019D]|[\u019F-\u01A0]|[\u01A2-\u01A2]|[\u01A4-\u01A4]|[\u01A6-\u01A7]|[\u01A9-\u01A9]|[\u01AC-\u01AC]|[\u01AE-\u01AF]|[\u01B1-\u01B3]|[\u01B5-\u01B5]|[\u01B7-\u01B8]|[\u01BC-\u01BC]|[\u01C4-\u01C4]|[\u01C7-\u01C7]|[\u01CA-\u01CA]|[\u01CD-\u01CD]|[\u01CF-\u01CF]|[\u01D1-\u01D1]|[\u01D3-\u01D3]|[\u01D5-\u01D5]|[\u01D7-\u01D7]|[\u01D9-\u01D9]|[\u01DB-\u01DB]|[\u01DE-\u01DE]|[\u01E0-\u01E0]|[\u01E2-\u01E2]|[\u01E4-\u01E4]|[\u01E6-\u01E6]|[\u01E8-\u01E8]|[\u01EA-\u01EA]|[\u01EC-\u01EC]|[\u01EE-\u01EE]|[\u01F1-\u01F1]|[\u01F4-\u01F4]|[\u01FA-\u01FA]|[\u01FC-\u01FC]|[\u01FE-\u01FE]|[\u0200-\u0200]|[\u0202-\u0202]|[\u0204-\u0204]|[\u0206-\u0206]|[\u0208-\u0208]|[\u020A-\u020A]|[\u020C-\u020C]|[\u020E-\u020E]|[\u0210-\u0210]|[\u0212-\u0212]|[\u0214-\u0214]|[\u0216-\u0216]|[\u0386-\u0386]|[\u0388-\u038A]|[\u038C-\u038C]|[\u038E-\u038F]|[\u0391-\u03A1]|[\u03A3-\u03AB]|[\u03D2-\u03D4]|[\u03DA-\u03DA]|[\u03DC-\u03DC]|[\u03DE-\u03DE]|[\u03E0-\u03E0]|[\u03E2-\u03E2]|[\u03E4-\u03E4]|[\u03E6-\u03E6]|[\u03E8-\u03E8]|[\u03EA-\u03EA]|[\u03EC-\u03EC]|[\u03EE-\u03EE]|[\u0401-\u040C]|[\u040E-\u042F]|[\u0460-\u0460]|[\u0462-\u0462]|[\u0464-\u0464]|[\u0466-\u0466]|[\u0468-\u0468]|[\u046A-\u046A]|[\u046C-\u046C]|[\u046E-\u046E]|[\u0470-\u0470]|[\u0472-\u0472]|[\u0474-\u0474]|[\u0476-\u0476]|[\u0478-\u0478]|[\u047A-\u047A]|[\u047C-\u047C]|[\u047E-\u047E]|[\u0480-\u0480]|[\u0490-\u0490]|[\u0492-\u0492]|[\u0494-\u0494]|[\u0496-\u0496]|[\u0498-\u0498]|[\u049A-\u049A]|[\u049C-\u049C]|[\u049E-\u049E]|[\u04A0-\u04A0]|[\u04A2-\u04A2]|[\u04A4-\u04A4]|[\u04A6-\u04A6]|[\u04A8-\u04A8]|[\u04AA-\u04AA]|[\u04AC-\u04AC]|[\u04AE-\u04AE]|[\u04B0-\u04B0]|[\u04B2-\u04B2]|[\u04B4-\u04B4]|[\u04B6-\u04B6]|[\u04B8-\u04B8]|[\u04BA-\u04BA]|[\u04BC-\u04BC]|[\u04BE-\u04BE]|[\u04C1-\u04C1]|[\u04C3-\u04C3]|[\u04C7-\u04C7]|[\u04CB-\u04CB]|[\u04D0-\u04D0]|[\u04D2-\u04D2]|[\u04D4-\u04D4]|[\u04D6-\u04D6]|[\u04D8-\u04D8]|[\u04DA-\u04DA]|[\u04DC-\u04DC]|[\u04DE-\u04DE]|[\u04E0-\u04E0]|[\u04E2-\u04E2]|[\u04E4-\u04E4]|[\u04E6-\u04E6]|[\u04E8-\u04E8]|[\u04EA-\u04EA]|[\u04EE-\u04EE]|[\u04F0-\u04F0]|[\u04F2-\u04F2]|[\u04F4-\u04F4]|[\u04F8-\u04F8]|[\u0531-\u0556]|[\u10A0-\u10C5]|[\u1E00-\u1E00]|[\u1E02-\u1E02]|[\u1E04-\u1E04]|[\u1E06-\u1E06]|[\u1E08-\u1E08]|[\u1E0A-\u1E0A]|[\u1E0C-\u1E0C]|[\u1E0E-\u1E0E]|[\u1E10-\u1E10]|[\u1E12-\u1E12]|[\u1E14-\u1E14]|[\u1E16-\u1E16]|[\u1E18-\u1E18]|[\u1E1A-\u1E1A]|[\u1E1C-\u1E1C]|[\u1E1E-\u1E1E]|[\u1E20-\u1E20]|[\u1E22-\u1E22]|[\u1E24-\u1E24]|[\u1E26-\u1E26]|[\u1E28-\u1E28]|[\u1E2A-\u1E2A]|[\u1E2C-\u1E2C]|[\u1E2E-\u1E2E]|[\u1E30-\u1E30]|[\u1E32-\u1E32]|[\u1E34-\u1E34]|[\u1E36-\u1E36]|[\u1E38-\u1E38]|[\u1E3A-\u1E3A]|[\u1E3C-\u1E3C]|[\u1E3E-\u1E3E]|[\u1E40-\u1E40]|[\u1E42-\u1E42]|[\u1E44-\u1E44]|[\u1E46-\u1E46]|[\u1E48-\u1E48]|[\u1E4A-\u1E4A]|[\u1E4C-\u1E4C]|[\u1E4E-\u1E4E]|[\u1E50-\u1E50]|[\u1E52-\u1E52]|[\u1E54-\u1E54]|[\u1E56-\u1E56]|[\u1E58-\u1E58]|[\u1E5A-\u1E5A]|[\u1E5C-\u1E5C]|[\u1E5E-\u1E5E]|[\u1E60-\u1E60]|[\u1E62-\u1E62]|[\u1E64-\u1E64]|[\u1E66-\u1E66]|[\u1E68-\u1E68]|[\u1E6A-\u1E6A]|[\u1E6C-\u1E6C]|[\u1E6E-\u1E6E]|[\u1E70-\u1E70]|[\u1E72-\u1E72]|[\u1E74-\u1E74]|[\u1E76-\u1E76]|[\u1E78-\u1E78]|[\u1E7A-\u1E7A]|[\u1E7C-\u1E7C]|[\u1E7E-\u1E7E]|[\u1E80-\u1E80]|[\u1E82-\u1E82]|[\u1E84-\u1E84]|[\u1E86-\u1E86]|[\u1E88-\u1E88]|[\u1E8A-\u1E8A]|[\u1E8C-\u1E8C]|[\u1E8E-\u1E8E]|[\u1E90-\u1E90]|[\u1E92-\u1E92]|[\u1E94-\u1E94]|[\u1EA0-\u1EA0]|[\u1EA2-\u1EA2]|[\u1EA4-\u1EA4]|[\u1EA6-\u1EA6]|[\u1EA8-\u1EA8]|[\u1EAA-\u1EAA]|[\u1EAC-\u1EAC]|[\u1EAE-\u1EAE]|[\u1EB0-\u1EB0]|[\u1EB2-\u1EB2]|[\u1EB4-\u1EB4]|[\u1EB6-\u1EB6]|[\u1EB8-\u1EB8]|[\u1EBA-\u1EBA]|[\u1EBC-\u1EBC]|[\u1EBE-\u1EBE]|[\u1EC0-\u1EC0]|[\u1EC2-\u1EC2]|[\u1EC4-\u1EC4]|[\u1EC6-\u1EC6]|[\u1EC8-\u1EC8]|[\u1ECA-\u1ECA]|[\u1ECC-\u1ECC]|[\u1ECE-\u1ECE]|[\u1ED0-\u1ED0]|[\u1ED2-\u1ED2]|[\u1ED4-\u1ED4]|[\u1ED6-\u1ED6]|[\u1ED8-\u1ED8]|[\u1EDA-\u1EDA]|[\u1EDC-\u1EDC]|[\u1EDE-\u1EDE]|[\u1EE0-\u1EE0]|[\u1EE2-\u1EE2]|[\u1EE4-\u1EE4]|[\u1EE6-\u1EE6]|[\u1EE8-\u1EE8]|[\u1EEA-\u1EEA]|[\u1EEC-\u1EEC]|[\u1EEE-\u1EEE]|[\u1EF0-\u1EF0]|[\u1EF2-\u1EF2]|[\u1EF4-\u1EF4]|[\u1EF6-\u1EF6]|[\u1EF8-\u1EF8]|[\u1F08-\u1F0F]|[\u1F18-\u1F1D]|[\u1F28-\u1F2F]|[\u1F38-\u1F3F]|[\u1F48-\u1F4D]|[\u1F59-\u1F59]|[\u1F5B-\u1F5B]|[\u1F5D-\u1F5D]|[\u1F5F-\u1F5F]|[\u1F68-\u1F6F]|[\u1F88-\u1F8F]|[\u1F98-\u1F9F]|[\u1FA8-\u1FAF]|[\u1FB8-\u1FBC]|[\u1FC8-\u1FCC]|[\u1FD8-\u1FDB]|[\u1FE8-\u1FEC]|[\u1FF8-\u1FFC]|[\u2102-\u2102]|[\u2107-\u2107]|[\u210B-\u210D]|[\u2110-\u2112]|[\u2115-\u2115]|[\u2119-\u211D]|[\u2124-\u2124]|[\u2126-\u2126]|[\u2128-\u2128]|[\u212A-\u212D]|[\u2130-\u2131]|[\u2133-\u2133]|[\uFF21-\uFF3A]/,Ll:/[\u0061-\u007A]|[\u00AA-\u00AA]|[\u00B5-\u00B5]|[\u00BA-\u00BA]|[\u00DF-\u00F6]|[\u00F8-\u00FF]|[\u0101-\u0101]|[\u0103-\u0103]|[\u0105-\u0105]|[\u0107-\u0107]|[\u0109-\u0109]|[\u010B-\u010B]|[\u010D-\u010D]|[\u010F-\u010F]|[\u0111-\u0111]|[\u0113-\u0113]|[\u0115-\u0115]|[\u0117-\u0117]|[\u0119-\u0119]|[\u011B-\u011B]|[\u011D-\u011D]|[\u011F-\u011F]|[\u0121-\u0121]|[\u0123-\u0123]|[\u0125-\u0125]|[\u0127-\u0127]|[\u0129-\u0129]|[\u012B-\u012B]|[\u012D-\u012D]|[\u012F-\u012F]|[\u0131-\u0131]|[\u0133-\u0133]|[\u0135-\u0135]|[\u0137-\u0138]|[\u013A-\u013A]|[\u013C-\u013C]|[\u013E-\u013E]|[\u0140-\u0140]|[\u0142-\u0142]|[\u0144-\u0144]|[\u0146-\u0146]|[\u0148-\u0149]|[\u014B-\u014B]|[\u014D-\u014D]|[\u014F-\u014F]|[\u0151-\u0151]|[\u0153-\u0153]|[\u0155-\u0155]|[\u0157-\u0157]|[\u0159-\u0159]|[\u015B-\u015B]|[\u015D-\u015D]|[\u015F-\u015F]|[\u0161-\u0161]|[\u0163-\u0163]|[\u0165-\u0165]|[\u0167-\u0167]|[\u0169-\u0169]|[\u016B-\u016B]|[\u016D-\u016D]|[\u016F-\u016F]|[\u0171-\u0171]|[\u0173-\u0173]|[\u0175-\u0175]|[\u0177-\u0177]|[\u017A-\u017A]|[\u017C-\u017C]|[\u017E-\u0180]|[\u0183-\u0183]|[\u0185-\u0185]|[\u0188-\u0188]|[\u018C-\u018D]|[\u0192-\u0192]|[\u0195-\u0195]|[\u0199-\u019B]|[\u019E-\u019E]|[\u01A1-\u01A1]|[\u01A3-\u01A3]|[\u01A5-\u01A5]|[\u01A8-\u01A8]|[\u01AB-\u01AB]|[\u01AD-\u01AD]|[\u01B0-\u01B0]|[\u01B4-\u01B4]|[\u01B6-\u01B6]|[\u01B9-\u01BA]|[\u01BD-\u01BD]|[\u01C6-\u01C6]|[\u01C9-\u01C9]|[\u01CC-\u01CC]|[\u01CE-\u01CE]|[\u01D0-\u01D0]|[\u01D2-\u01D2]|[\u01D4-\u01D4]|[\u01D6-\u01D6]|[\u01D8-\u01D8]|[\u01DA-\u01DA]|[\u01DC-\u01DD]|[\u01DF-\u01DF]|[\u01E1-\u01E1]|[\u01E3-\u01E3]|[\u01E5-\u01E5]|[\u01E7-\u01E7]|[\u01E9-\u01E9]|[\u01EB-\u01EB]|[\u01ED-\u01ED]|[\u01EF-\u01F0]|[\u01F3-\u01F3]|[\u01F5-\u01F5]|[\u01FB-\u01FB]|[\u01FD-\u01FD]|[\u01FF-\u01FF]|[\u0201-\u0201]|[\u0203-\u0203]|[\u0205-\u0205]|[\u0207-\u0207]|[\u0209-\u0209]|[\u020B-\u020B]|[\u020D-\u020D]|[\u020F-\u020F]|[\u0211-\u0211]|[\u0213-\u0213]|[\u0215-\u0215]|[\u0217-\u0217]|[\u0250-\u02A8]|[\u0390-\u0390]|[\u03AC-\u03CE]|[\u03D0-\u03D1]|[\u03D5-\u03D6]|[\u03E3-\u03E3]|[\u03E5-\u03E5]|[\u03E7-\u03E7]|[\u03E9-\u03E9]|[\u03EB-\u03EB]|[\u03ED-\u03ED]|[\u03EF-\u03F2]|[\u0430-\u044F]|[\u0451-\u045C]|[\u045E-\u045F]|[\u0461-\u0461]|[\u0463-\u0463]|[\u0465-\u0465]|[\u0467-\u0467]|[\u0469-\u0469]|[\u046B-\u046B]|[\u046D-\u046D]|[\u046F-\u046F]|[\u0471-\u0471]|[\u0473-\u0473]|[\u0475-\u0475]|[\u0477-\u0477]|[\u0479-\u0479]|[\u047B-\u047B]|[\u047D-\u047D]|[\u047F-\u047F]|[\u0481-\u0481]|[\u0491-\u0491]|[\u0493-\u0493]|[\u0495-\u0495]|[\u0497-\u0497]|[\u0499-\u0499]|[\u049B-\u049B]|[\u049D-\u049D]|[\u049F-\u049F]|[\u04A1-\u04A1]|[\u04A3-\u04A3]|[\u04A5-\u04A5]|[\u04A7-\u04A7]|[\u04A9-\u04A9]|[\u04AB-\u04AB]|[\u04AD-\u04AD]|[\u04AF-\u04AF]|[\u04B1-\u04B1]|[\u04B3-\u04B3]|[\u04B5-\u04B5]|[\u04B7-\u04B7]|[\u04B9-\u04B9]|[\u04BB-\u04BB]|[\u04BD-\u04BD]|[\u04BF-\u04BF]|[\u04C2-\u04C2]|[\u04C4-\u04C4]|[\u04C8-\u04C8]|[\u04CC-\u04CC]|[\u04D1-\u04D1]|[\u04D3-\u04D3]|[\u04D5-\u04D5]|[\u04D7-\u04D7]|[\u04D9-\u04D9]|[\u04DB-\u04DB]|[\u04DD-\u04DD]|[\u04DF-\u04DF]|[\u04E1-\u04E1]|[\u04E3-\u04E3]|[\u04E5-\u04E5]|[\u04E7-\u04E7]|[\u04E9-\u04E9]|[\u04EB-\u04EB]|[\u04EF-\u04EF]|[\u04F1-\u04F1]|[\u04F3-\u04F3]|[\u04F5-\u04F5]|[\u04F9-\u04F9]|[\u0561-\u0587]|[\u10D0-\u10F6]|[\u1E01-\u1E01]|[\u1E03-\u1E03]|[\u1E05-\u1E05]|[\u1E07-\u1E07]|[\u1E09-\u1E09]|[\u1E0B-\u1E0B]|[\u1E0D-\u1E0D]|[\u1E0F-\u1E0F]|[\u1E11-\u1E11]|[\u1E13-\u1E13]|[\u1E15-\u1E15]|[\u1E17-\u1E17]|[\u1E19-\u1E19]|[\u1E1B-\u1E1B]|[\u1E1D-\u1E1D]|[\u1E1F-\u1E1F]|[\u1E21-\u1E21]|[\u1E23-\u1E23]|[\u1E25-\u1E25]|[\u1E27-\u1E27]|[\u1E29-\u1E29]|[\u1E2B-\u1E2B]|[\u1E2D-\u1E2D]|[\u1E2F-\u1E2F]|[\u1E31-\u1E31]|[\u1E33-\u1E33]|[\u1E35-\u1E35]|[\u1E37-\u1E37]|[\u1E39-\u1E39]|[\u1E3B-\u1E3B]|[\u1E3D-\u1E3D]|[\u1E3F-\u1E3F]|[\u1E41-\u1E41]|[\u1E43-\u1E43]|[\u1E45-\u1E45]|[\u1E47-\u1E47]|[\u1E49-\u1E49]|[\u1E4B-\u1E4B]|[\u1E4D-\u1E4D]|[\u1E4F-\u1E4F]|[\u1E51-\u1E51]|[\u1E53-\u1E53]|[\u1E55-\u1E55]|[\u1E57-\u1E57]|[\u1E59-\u1E59]|[\u1E5B-\u1E5B]|[\u1E5D-\u1E5D]|[\u1E5F-\u1E5F]|[\u1E61-\u1E61]|[\u1E63-\u1E63]|[\u1E65-\u1E65]|[\u1E67-\u1E67]|[\u1E69-\u1E69]|[\u1E6B-\u1E6B]|[\u1E6D-\u1E6D]|[\u1E6F-\u1E6F]|[\u1E71-\u1E71]|[\u1E73-\u1E73]|[\u1E75-\u1E75]|[\u1E77-\u1E77]|[\u1E79-\u1E79]|[\u1E7B-\u1E7B]|[\u1E7D-\u1E7D]|[\u1E7F-\u1E7F]|[\u1E81-\u1E81]|[\u1E83-\u1E83]|[\u1E85-\u1E85]|[\u1E87-\u1E87]|[\u1E89-\u1E89]|[\u1E8B-\u1E8B]|[\u1E8D-\u1E8D]|[\u1E8F-\u1E8F]|[\u1E91-\u1E91]|[\u1E93-\u1E93]|[\u1E95-\u1E9B]|[\u1EA1-\u1EA1]|[\u1EA3-\u1EA3]|[\u1EA5-\u1EA5]|[\u1EA7-\u1EA7]|[\u1EA9-\u1EA9]|[\u1EAB-\u1EAB]|[\u1EAD-\u1EAD]|[\u1EAF-\u1EAF]|[\u1EB1-\u1EB1]|[\u1EB3-\u1EB3]|[\u1EB5-\u1EB5]|[\u1EB7-\u1EB7]|[\u1EB9-\u1EB9]|[\u1EBB-\u1EBB]|[\u1EBD-\u1EBD]|[\u1EBF-\u1EBF]|[\u1EC1-\u1EC1]|[\u1EC3-\u1EC3]|[\u1EC5-\u1EC5]|[\u1EC7-\u1EC7]|[\u1EC9-\u1EC9]|[\u1ECB-\u1ECB]|[\u1ECD-\u1ECD]|[\u1ECF-\u1ECF]|[\u1ED1-\u1ED1]|[\u1ED3-\u1ED3]|[\u1ED5-\u1ED5]|[\u1ED7-\u1ED7]|[\u1ED9-\u1ED9]|[\u1EDB-\u1EDB]|[\u1EDD-\u1EDD]|[\u1EDF-\u1EDF]|[\u1EE1-\u1EE1]|[\u1EE3-\u1EE3]|[\u1EE5-\u1EE5]|[\u1EE7-\u1EE7]|[\u1EE9-\u1EE9]|[\u1EEB-\u1EEB]|[\u1EED-\u1EED]|[\u1EEF-\u1EEF]|[\u1EF1-\u1EF1]|[\u1EF3-\u1EF3]|[\u1EF5-\u1EF5]|[\u1EF7-\u1EF7]|[\u1EF9-\u1EF9]|[\u1F00-\u1F07]|[\u1F10-\u1F15]|[\u1F20-\u1F27]|[\u1F30-\u1F37]|[\u1F40-\u1F45]|[\u1F50-\u1F57]|[\u1F60-\u1F67]|[\u1F70-\u1F7D]|[\u1F80-\u1F87]|[\u1F90-\u1F97]|[\u1FA0-\u1FA7]|[\u1FB0-\u1FB4]|[\u1FB6-\u1FB7]|[\u1FBE-\u1FBE]|[\u1FC2-\u1FC4]|[\u1FC6-\u1FC7]|[\u1FD0-\u1FD3]|[\u1FD6-\u1FD7]|[\u1FE0-\u1FE7]|[\u1FF2-\u1FF4]|[\u1FF6-\u1FF7]|[\u207F-\u207F]|[\u210A-\u210A]|[\u210E-\u210F]|[\u2113-\u2113]|[\u2118-\u2118]|[\u212E-\u212F]|[\u2134-\u2134]|[\uFB00-\uFB06]|[\uFB13-\uFB17]|[\uFF41-\uFF5A]/,Lt:/[\u01C5-\u01C5]|[\u01C8-\u01C8]|[\u01CB-\u01CB]|[\u01F2-\u01F2]/,Lm:/[\u02B0-\u02B8]|[\u02BB-\u02C1]|[\u02D0-\u02D1]|[\u02E0-\u02E4]|[\u037A-\u037A]|[\u0559-\u0559]|[\u0640-\u0640]|[\u06E5-\u06E6]|[\u0E46-\u0E46]|[\u0EC6-\u0EC6]|[\u3005-\u3005]|[\u3031-\u3035]|[\u309D-\u309E]|[\u30FC-\u30FE]|[\uFF70-\uFF70]|[\uFF9E-\uFF9F]/, +Lo:/[\u01AA-\u01AA]|[\u01BB-\u01BB]|[\u01BE-\u01C3]|[\u03F3-\u03F3]|[\u04C0-\u04C0]|[\u05D0-\u05EA]|[\u05F0-\u05F2]|[\u0621-\u063A]|[\u0641-\u064A]|[\u0671-\u06B7]|[\u06BA-\u06BE]|[\u06C0-\u06CE]|[\u06D0-\u06D3]|[\u06D5-\u06D5]|[\u0905-\u0939]|[\u093D-\u093D]|[\u0950-\u0950]|[\u0958-\u0961]|[\u0985-\u098C]|[\u098F-\u0990]|[\u0993-\u09A8]|[\u09AA-\u09B0]|[\u09B2-\u09B2]|[\u09B6-\u09B9]|[\u09DC-\u09DD]|[\u09DF-\u09E1]|[\u09F0-\u09F1]|[\u0A05-\u0A0A]|[\u0A0F-\u0A10]|[\u0A13-\u0A28]|[\u0A2A-\u0A30]|[\u0A32-\u0A33]|[\u0A35-\u0A36]|[\u0A38-\u0A39]|[\u0A59-\u0A5C]|[\u0A5E-\u0A5E]|[\u0A72-\u0A74]|[\u0A85-\u0A8B]|[\u0A8D-\u0A8D]|[\u0A8F-\u0A91]|[\u0A93-\u0AA8]|[\u0AAA-\u0AB0]|[\u0AB2-\u0AB3]|[\u0AB5-\u0AB9]|[\u0ABD-\u0ABD]|[\u0AD0-\u0AD0]|[\u0AE0-\u0AE0]|[\u0B05-\u0B0C]|[\u0B0F-\u0B10]|[\u0B13-\u0B28]|[\u0B2A-\u0B30]|[\u0B32-\u0B33]|[\u0B36-\u0B39]|[\u0B3D-\u0B3D]|[\u0B5C-\u0B5D]|[\u0B5F-\u0B61]|[\u0B85-\u0B8A]|[\u0B8E-\u0B90]|[\u0B92-\u0B95]|[\u0B99-\u0B9A]|[\u0B9C-\u0B9C]|[\u0B9E-\u0B9F]|[\u0BA3-\u0BA4]|[\u0BA8-\u0BAA]|[\u0BAE-\u0BB5]|[\u0BB7-\u0BB9]|[\u0C05-\u0C0C]|[\u0C0E-\u0C10]|[\u0C12-\u0C28]|[\u0C2A-\u0C33]|[\u0C35-\u0C39]|[\u0C60-\u0C61]|[\u0C85-\u0C8C]|[\u0C8E-\u0C90]|[\u0C92-\u0CA8]|[\u0CAA-\u0CB3]|[\u0CB5-\u0CB9]|[\u0CDE-\u0CDE]|[\u0CE0-\u0CE1]|[\u0D05-\u0D0C]|[\u0D0E-\u0D10]|[\u0D12-\u0D28]|[\u0D2A-\u0D39]|[\u0D60-\u0D61]|[\u0E01-\u0E30]|[\u0E32-\u0E33]|[\u0E40-\u0E45]|[\u0E81-\u0E82]|[\u0E84-\u0E84]|[\u0E87-\u0E88]|[\u0E8A-\u0E8A]|[\u0E8D-\u0E8D]|[\u0E94-\u0E97]|[\u0E99-\u0E9F]|[\u0EA1-\u0EA3]|[\u0EA5-\u0EA5]|[\u0EA7-\u0EA7]|[\u0EAA-\u0EAB]|[\u0EAD-\u0EB0]|[\u0EB2-\u0EB3]|[\u0EBD-\u0EBD]|[\u0EC0-\u0EC4]|[\u0EDC-\u0EDD]|[\u0F00-\u0F00]|[\u0F40-\u0F47]|[\u0F49-\u0F69]|[\u0F88-\u0F8B]|[\u1100-\u1159]|[\u115F-\u11A2]|[\u11A8-\u11F9]|[\u2135-\u2138]|[\u3006-\u3006]|[\u3041-\u3094]|[\u30A1-\u30FA]|[\u3105-\u312C]|[\u3131-\u318E]|[\u4E00-\u9FA5]|[\uAC00-\uD7A3]|[\uF900-\uFA2D]|[\uFB1F-\uFB28]|[\uFB2A-\uFB36]|[\uFB38-\uFB3C]|[\uFB3E-\uFB3E]|[\uFB40-\uFB41]|[\uFB43-\uFB44]|[\uFB46-\uFBB1]|[\uFBD3-\uFD3D]|[\uFD50-\uFD8F]|[\uFD92-\uFDC7]|[\uFDF0-\uFDFB]|[\uFE70-\uFE72]|[\uFE74-\uFE74]|[\uFE76-\uFEFC]|[\uFF66-\uFF6F]|[\uFF71-\uFF9D]|[\uFFA0-\uFFBE]|[\uFFC2-\uFFC7]|[\uFFCA-\uFFCF]|[\uFFD2-\uFFD7]|[\uFFDA-\uFFDC]/,Nl:/[\u2160-\u2182]|[\u3007-\u3007]|[\u3021-\u3029]/,Mn:/[\u0300-\u0345]|[\u0360-\u0361]|[\u0483-\u0486]|[\u0591-\u05A1]|[\u05A3-\u05B9]|[\u05BB-\u05BD]|[\u05BF-\u05BF]|[\u05C1-\u05C2]|[\u05C4-\u05C4]|[\u064B-\u0652]|[\u0670-\u0670]|[\u06D6-\u06DC]|[\u06DF-\u06E4]|[\u06E7-\u06E8]|[\u06EA-\u06ED]|[\u0901-\u0902]|[\u093C-\u093C]|[\u0941-\u0948]|[\u094D-\u094D]|[\u0951-\u0954]|[\u0962-\u0963]|[\u0981-\u0981]|[\u09BC-\u09BC]|[\u09C1-\u09C4]|[\u09CD-\u09CD]|[\u09E2-\u09E3]|[\u0A02-\u0A02]|[\u0A3C-\u0A3C]|[\u0A41-\u0A42]|[\u0A47-\u0A48]|[\u0A4B-\u0A4D]|[\u0A70-\u0A71]|[\u0A81-\u0A82]|[\u0ABC-\u0ABC]|[\u0AC1-\u0AC5]|[\u0AC7-\u0AC8]|[\u0ACD-\u0ACD]|[\u0B01-\u0B01]|[\u0B3C-\u0B3C]|[\u0B3F-\u0B3F]|[\u0B41-\u0B43]|[\u0B4D-\u0B4D]|[\u0B56-\u0B56]|[\u0B82-\u0B82]|[\u0BC0-\u0BC0]|[\u0BCD-\u0BCD]|[\u0C3E-\u0C40]|[\u0C46-\u0C48]|[\u0C4A-\u0C4D]|[\u0C55-\u0C56]|[\u0CBF-\u0CBF]|[\u0CC6-\u0CC6]|[\u0CCC-\u0CCD]|[\u0D41-\u0D43]|[\u0D4D-\u0D4D]|[\u0E31-\u0E31]|[\u0E34-\u0E3A]|[\u0E47-\u0E4E]|[\u0EB1-\u0EB1]|[\u0EB4-\u0EB9]|[\u0EBB-\u0EBC]|[\u0EC8-\u0ECD]|[\u0F18-\u0F19]|[\u0F35-\u0F35]|[\u0F37-\u0F37]|[\u0F39-\u0F39]|[\u0F71-\u0F7E]|[\u0F80-\u0F84]|[\u0F86-\u0F87]|[\u0F90-\u0F95]|[\u0F97-\u0F97]|[\u0F99-\u0FAD]|[\u0FB1-\u0FB7]|[\u0FB9-\u0FB9]|[\u20D0-\u20DC]|[\u20E1-\u20E1]|[\u302A-\u302F]|[\u3099-\u309A]|[\uFB1E-\uFB1E]|[\uFE20-\uFE23]/,Mc:/[\u0903-\u0903]|[\u093E-\u0940]|[\u0949-\u094C]|[\u0982-\u0983]|[\u09BE-\u09C0]|[\u09C7-\u09C8]|[\u09CB-\u09CC]|[\u09D7-\u09D7]|[\u0A3E-\u0A40]|[\u0A83-\u0A83]|[\u0ABE-\u0AC0]|[\u0AC9-\u0AC9]|[\u0ACB-\u0ACC]|[\u0B02-\u0B03]|[\u0B3E-\u0B3E]|[\u0B40-\u0B40]|[\u0B47-\u0B48]|[\u0B4B-\u0B4C]|[\u0B57-\u0B57]|[\u0B83-\u0B83]|[\u0BBE-\u0BBF]|[\u0BC1-\u0BC2]|[\u0BC6-\u0BC8]|[\u0BCA-\u0BCC]|[\u0BD7-\u0BD7]|[\u0C01-\u0C03]|[\u0C41-\u0C44]|[\u0C82-\u0C83]|[\u0CBE-\u0CBE]|[\u0CC0-\u0CC4]|[\u0CC7-\u0CC8]|[\u0CCA-\u0CCB]|[\u0CD5-\u0CD6]|[\u0D02-\u0D03]|[\u0D3E-\u0D40]|[\u0D46-\u0D48]|[\u0D4A-\u0D4C]|[\u0D57-\u0D57]|[\u0F3E-\u0F3F]|[\u0F7F-\u0F7F]/,Nd:/[\u0030-\u0039]|[\u0660-\u0669]|[\u06F0-\u06F9]|[\u0966-\u096F]|[\u09E6-\u09EF]|[\u0A66-\u0A6F]|[\u0AE6-\u0AEF]|[\u0B66-\u0B6F]|[\u0BE7-\u0BEF]|[\u0C66-\u0C6F]|[\u0CE6-\u0CEF]|[\u0D66-\u0D6F]|[\u0E50-\u0E59]|[\u0ED0-\u0ED9]|[\u0F20-\u0F29]|[\uFF10-\uFF19]/,Pc:/[\u005F-\u005F]|[\u203F-\u2040]|[\u30FB-\u30FB]|[\uFE33-\uFE34]|[\uFE4D-\uFE4F]|[\uFF3F-\uFF3F]|[\uFF65-\uFF65]/,Zs:/[\u2000-\u200B]|[\u3000-\u3000]/}},{}]},{},[28])(28)}); diff --git a/examples/math/index.html b/examples/math/index.html index ae124f7f..9f99826a 100644 --- a/examples/math/index.html +++ b/examples/math/index.html @@ -333,7 +333,24 @@ PriExp_neg: function(_, e) { return ['neg', e.asLisp]; }, ident: function(_, _) { return this.interval.contents; }, number: function(_) { return this.interval.contents; }, - _default: ohm.actions.passThrough // TODO: Explain _default. + + /* + You can optionally provide a _default semantic action that will be invoked when the action + dictionary does not have a method that corresponds to the type of a CST node. The receiver + (`this`) of the _default method is that CST node, _default's only argument is an array that + contains the children of that node. + */ + _default: function(children) { + if (children.length === 1) { + // If this node only has one child, just return the Lisp tree of its child. This lets us avoid + // writing semantic actions for the Exp, AddExp, MulExp, ExpExp, and PriExp rules. + return children[0].asLisp; + } else { + // Hmm, this probably means that we forgot to write a semantic action for one of the rules. + // We'll throw an exception so we'll know that it's missing. + throw new Error("Uh-oh, missing semantic action for " + this.constructor); + } + } }); /* @@ -363,8 +380,7 @@ PriExp_pos: function(sign, e) { return elt('pos', sign.toTree(), e.toTree()); }, PriExp_neg: function(sign, e) { return elt('neg', sign.toTree(), e.toTree()); }, ident: function(_, _) { return elt('ident', this.interval.contents); }, - number: function(_) { return elt('number', this.interval.contents); }, - _terminal: ohm.actions.getPrimitiveValue // TODO: explain _terminal, ohm...getPrimitiveValue + number: function(_) { return elt('number', this.interval.contents); } }); // ------------------------------------------------------------------------------------------------- @@ -387,9 +403,12 @@ PriExp_neg: function(sign, e) { return elt('neg', sign.toTwoD(), e.toTwoD()); }, ident: function(_, _) { var text = this.interval.contents; return elt('ident', text === 'pi' ? '\u03C0' : text); }, - number: function(_) { return elt('number', this.interval.contents); }, - _terminal: ohm.actions.getPrimitiveValue, - _default: ohm.actions.passThrough + number: function(_) { return elt('number', this.interval.contents); } + + // Remember the _default semantic action that we wrote for the `interpret` operation above? Turns + // out that's so convenient that the Ohm people decided to give it to you "for free", i.e., if you + // don't write a _default semantic action, you get that one automatically. Of course you're free + // to override it if that's not what you want, but in this case, it's exactly what we want. }); diff --git a/examples/viz/index.html b/examples/viz/index.html index ea715c12..0111909d 100644 --- a/examples/viz/index.html +++ b/examples/viz/index.html @@ -276,8 +276,7 @@ keyword_false: function(_) { add('prim', 'false'); }, - Prop: function(n, _, p) {}, - _terminal: ohm.actions.getPrimitiveValue + Prop: function(n, _, p) {} }); s.addOperation('vizChoice', { diff --git a/src/Grammar.js b/src/Grammar.js index a287737a..86508618 100644 --- a/src/Grammar.js +++ b/src/Grammar.js @@ -86,6 +86,12 @@ Grammar.prototype = { _terminal: function() { this._node.parent = stack[stack.length - 1]; }, + _iter: function(children) { + stack.push(this._node); + children.forEach(function(child) { child.setParents(); }); + stack.pop(); + this._node.parent = stack[stack.length - 1]; + }, _default: function(children) { stack.push(this._node); children.forEach(function(child) { child.setParents(); }); @@ -123,7 +129,7 @@ Grammar.prototype = { // a function of the correct arity. If not, throw an exception. _checkTopDownActionDict: function(what, name, actionDict) { function isSpecialAction(name) { - return name === '_terminal' || name === '_default'; + return name === '_terminal' || name === '_iter' || name === '_default'; } var problems = []; @@ -157,7 +163,7 @@ Grammar.prototype = { // Return the expected arity for a semantic action named `actionName`, which // is either a rule name or a special action name like '_default'. _topDownActionArity: function(actionName) { - if (actionName === '_default') { + if (actionName === '_default' || actionName === '_iter') { return 1; } else if (actionName === '_terminal') { return 0; diff --git a/src/Semantics.js b/src/Semantics.js index 19b328e7..4bc43399 100644 --- a/src/Semantics.js +++ b/src/Semantics.js @@ -181,7 +181,37 @@ Semantics.prototype.addOperationOrAttribute = function(type, name, actionDict) { var Ctor = type === 'operation' ? Operation : Attribute; this.assertNewName(name, type); - this[typePlural][name] = new Ctor(name, actionDict); + + // Create the action dictionary for this operation / attribute. We begin by defining the default + // behavior of terminal and iteration nodes, and add a '_default' action that throws an error if + // a rule in the grammar doesn't have a corresponding action in this operation / attribute... + var realActionDict = { + _terminal: function() { + return this.primitiveValue; + }, + _iter: function(children) { + // This CST node corresponds to an iteration expression in the grammar (*, +, or ?). The + // default behavior is to map this operation or attribute over all of its child nodes. + var thisSemantics = this._semantics; + var thisThing = thisSemantics[typePlural][name]; + return children.map(function(child) { return thisThing.execute(thisSemantics, child); }); + }, + _default: function(children) { + if (children.length === 1) { + var thisSemantics = this._semantics; + var thisThing = thisSemantics[typePlural][name]; + return thisThing.execute(thisSemantics, children[0]); + } + throw new Error('missing semantic action for ' + this.ctorName + ' in ' + name + ' ' + type); + } + }; + // ... and add in the actions supplied by the programmer, which may override some or all of the + // default ones. + Object.keys(actionDict).forEach(function(name) { + realActionDict[name] = actionDict[name]; + }); + + this[typePlural][name] = new Ctor(name, realActionDict); // The following check is not strictly necessary (it will happen later anyway) but it's better to // catch errors early. @@ -310,19 +340,6 @@ Semantics.createSemantics = function(grammar, optSuperSemantics) { return proxy; }; -// ----------------- Default semantic actions ----------------- - -var actions = { - getPrimitiveValue: function() { - return this.primitiveValue; - }, - passThrough: function(childNode) { - throw new Error('BUG: ohm.actions.passThrough should never be called'); - } -}; - -Semantics.actions = actions; - // ----------------- Operation ----------------- // An Operation represents a function to be applied to a concrete syntax tree (CST) -- it's very @@ -344,34 +361,19 @@ Operation.prototype.checkActionDict = function(grammar) { // Execute this operation on the CST node associated with `nodeWrapper` in the context of the given // Semantics instance. Operation.prototype.execute = function(semantics, nodeWrapper) { - if (nodeWrapper.isIteration()) { - // This CST node corresponds to an iteration expression in the grammar (*, +, or ?), so we map - // this operation over all of its child nodes. - var results = []; - for (var idx = 0; idx < nodeWrapper._node.numChildren(); idx++) { - results.push(this.execute(semantics, nodeWrapper.child(idx))); - } - return results; - } - // Look for a semantic action whose name matches the node's constructor name, which is either the - // name of a rule in the grammar, or the special value '_terminal'. + // name of a rule in the grammar, or '_terminal' (for a terminal node), or '_iter' (for an + // iteration node). In the latter case, the action function receives a single argument, which is + // an array containing all of the children of the CST node. var actionFn = this.actionDict[nodeWrapper._node.ctorName]; if (actionFn) { - return this.doAction(semantics, nodeWrapper, actionFn); + return this.doAction(semantics, nodeWrapper, actionFn, nodeWrapper.isIteration()); } // The action dictionary does not contain a semantic action for this specific type of node, so - // invoke the '_default' semantic action if it exists (but only if this node is not a terminal). - var defaultActionFn = this.actionDict._default; - if (defaultActionFn && !nodeWrapper.isTerminal()) { - return this.doAction(semantics, nodeWrapper, defaultActionFn, true); - } - - // The programmer hasn't written a semantic action for this type of node yet. - throw new Error( - 'missing semantic action for ' + nodeWrapper._node.ctorName + ' in ' + this.name + ' ' + - this.typeName); + // invoke the '_default' semantic action. The built-in implementation of the `_default` semantic + // action just throws an error, but the programmer may have overridden it. + return this.doAction(semantics, nodeWrapper, this.actionDict._default, true); }; // Invoke `actionFn` on the CST node that corresponds to `nodeWrapper`, in the context of @@ -379,9 +381,6 @@ Operation.prototype.execute = function(semantics, nodeWrapper) { // argument, which is an array of wrappers. Otherwise, the number of arguments to `actionFn` will // be equal to the number of children in the CST node. Operation.prototype.doAction = function(semantics, nodeWrapper, actionFn, optPassChildrenAsArray) { - if (actionFn === actions.passThrough) { - return this.execute(semantics, nodeWrapper._onlyChild()); - } return optPassChildrenAsArray ? actionFn.call(nodeWrapper, nodeWrapper._children()) : actionFn.apply(nodeWrapper, nodeWrapper._children()); diff --git a/src/main.js b/src/main.js index 90b66c11..97da7971 100644 --- a/src/main.js +++ b/src/main.js @@ -9,7 +9,6 @@ var Builder = require('./Builder'); var Grammar = require('./Grammar'); var Namespace = require('./Namespace'); -var Semantics = require('./Semantics'); var UnicodeCategories = require('../third_party/unicode').UnicodeCategories; var common = require('./common'); var errors = require('./errors'); @@ -275,10 +274,7 @@ function buildGrammar(match, namespace, optOhmGrammarForTesting) { }, ListOf_none: function() { return []; - }, - - _terminal: Semantics.actions.getPrimitiveValue, - _default: Semantics.actions.passThrough + } }); return helpers(match).visit(); } @@ -379,7 +375,6 @@ function makeRecipe(recipeFn) { // Stuff that users should know about module.exports = { - actions: Semantics.actions, createNamespace: Namespace.createNamespace, error: errors, grammar: grammar, diff --git a/test/ohm-spec.js b/test/ohm-spec.js index 0f47aa7b..fa70e3f5 100644 --- a/test/ohm-spec.js +++ b/test/ohm-spec.js @@ -53,8 +53,7 @@ function buildTreeNodeWithUniqueId(g) { _default: function(children) { return ['id', nextId++, this.ctorName] .concat(children.map(function(child) { return child.tree; })); - }, - _terminal: ohm.actions.getPrimitiveValue + } }); function makeTree(node) { return s(node).tree; } @@ -229,10 +228,7 @@ test('primitive patterns', function(t) { }); it('semantic actions', function() { - var s = m.semantics().addAttribute('v', { - _: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue - }); + var s = m.semantics().addAttribute('v', {}); t.equal(s(m.match(5, '_')).v, 5); t.equal(s(m.match(null, '_')).v, null); }); @@ -246,10 +242,7 @@ test('primitive patterns', function(t) { }); it('semantic actions', function() { - var s = m.semantics().addAttribute('v', { - _: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue - }); + var s = m.semantics().addAttribute('v', {}); t.equal(s(m.match('5', '_')).v, '5'); }); t.end(); @@ -261,10 +254,7 @@ test('primitive patterns', function(t) { }); it('semantic actions', function() { - var s = m.semantics().addAttribute('v', { - _: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue - }); + var s = m.semantics().addAttribute('v', {}); t.deepEqual(s(m.match(['123'], '_')).v, ['123']); }); t.end(); @@ -329,13 +319,7 @@ test('primitive patterns', function(t) { }); it('semantic actions', function() { - var s = m.semantics().addAttribute('v', { - five: ohm.actions.passThrough, - _true: ohm.actions.passThrough, - _false: ohm.actions.passThrough, - _null: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue - }); + var s = m.semantics().addAttribute('v', {}); t.equal(s(m.match(5)).v, 5); t.equal(s(m.match(true, '_true')).v, true); t.equal(s(m.match(false, '_false')).v, false); @@ -379,10 +363,7 @@ test('char', function(t) { }); it('semantic actions', function() { - var s = m.semantics().addAttribute('v', { - bang: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue - }); + var s = m.semantics().addAttribute('v', {}); var cst = m.match('!'); t.equal(s(cst).v, '!'); }); @@ -397,10 +378,7 @@ test('char', function(t) { }); it('semantic actions', function() { - var s = m.semantics().addAttribute('v', { - bang: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue - }); + var s = m.semantics().addAttribute('v', {}); var cst = m.match('!'); t.equal(s(cst).v, '!'); }); @@ -421,10 +399,7 @@ test('string', function(t) { }); it('semantic actions', function() { - var s = m.semantics().addAttribute('v', { - foo: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue - }); + var s = m.semantics().addAttribute('v', {}); var cst = m.match('foo\b\n\r\t\\"\u01bcff\x8f'); t.equal(s(cst).v, 'foo\b\n\r\t\\"\u01bcff\x8f'); }); @@ -444,10 +419,7 @@ test('string', function(t) { }); it('semantic actions', function() { - var s = m.semantics().addAttribute('v', { - foo: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue - }); + var s = m.semantics().addAttribute('v', {}); var cst = m.match('foo\b\n\r\t\\"\u01bcff\x8f'); t.equal(s(cst).v, 'foo\b\n\r\t\\"\u01bcff\x8f'); }); @@ -478,10 +450,7 @@ test('regexp', function(t) { }); it('semantic actions', function() { - var s = m.semantics().addAttribute('v', { - myDigit: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue - }); + var s = m.semantics().addAttribute('v', {}); var cst = m.match('4'); t.equal(s(cst).v, '4'); }); @@ -500,10 +469,7 @@ test('regexp', function(t) { }); it('semantic actions', function() { - var s = m.semantics().addAttribute('v', { - myLetter: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue - }); + var s = m.semantics().addAttribute('v', {}); var cst = m.match('a', 'myLetter'); t.equal(s(cst).v, 'a'); }); @@ -523,10 +489,7 @@ test('alt', function(t) { }); it('semantic actions', function() { - var s = m.semantics().addAttribute('v', { - altTest: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue - }); + var s = m.semantics().addAttribute('v', {}); t.equal(s(m.match('a')).v, 'a'); t.equal(s(m.match('b')).v, 'b'); }); @@ -653,8 +616,7 @@ test('kleene-* and kleene-+', function(t) { }, digit: function(expr) { return ['digit', expr.v]; - }, - _terminal: ohm.actions.getPrimitiveValue + } }); t.deepEqual(s(m.match('1234', 'number')).v, [ 'digits', [ @@ -691,8 +653,7 @@ test('opt', function(t) { var s = m.semantics().addAttribute('v', { name: function(title, last) { return [title.children.length === 1 ? title.v[0] : undefined, last.primitiveValue]; - }, - _terminal: ohm.actions.getPrimitiveValue + } }); t.deepEqual(s(m.match('drwarth')).v, ['dr', 'warth']); t.deepEqual(s(m.match('warth')).v, [undefined, 'warth']); @@ -756,9 +717,7 @@ test('arr', function(t) { var s = m.semantics().addAttribute('v', { start: function(_, y, x, _, _) { return [x.v, y.v]; - }, - _: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue + } }); t.deepEqual(s(m.match(['abc', ['d', 'ef'], 'g'])).v, ['d', ['d', 'ef']]); }); @@ -831,8 +790,7 @@ test('obj', function(t) { var s = m.semantics().addAttribute('v', { withStringProps: function(foos, bar) { return [foos.v, bar.v]; - }, - _terminal: ohm.actions.getPrimitiveValue, + } }); t.deepEqual(s(m.match({foos: 'foofoo', bar: 'bar'}, 'withStringProps')).v, [ ['foo', 'foo'], 'bar' @@ -875,8 +833,7 @@ test('apply', function(t) { }, foo: function(expr) { return ['foo', expr.v]; - }, - _terminal: ohm.actions.getPrimitiveValue + } }); t.deepEqual(s(m.match('foo')).v, ['easy', ['foo', 'foo']]); }); @@ -902,23 +859,19 @@ test('apply', function(t) { it('semantic actions', function() { var f = m.match('1234', 'number'); var s = m.semantics().addAttribute('v', { - number: ohm.actions.passThrough, numberRec: function(n, d) { return n.v * 10 + d.v; }, digit: function(expr) { return expr.v.charCodeAt(0) - '0'.charCodeAt(0); - }, - _terminal: ohm.actions.getPrimitiveValue + } }).addAttribute('t', { number: function(expr) { return ['number', expr.t]; }, numberRec: function(n, d) { return ['numberRec', n.t, d.t]; - }, - digit: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue + } }); t.equal(s(f).v, 1234); t.deepEqual(s(f).t, @@ -953,14 +906,9 @@ test('apply', function(t) { it('semantic actions', function() { var s = m.semantics().addAttribute('v', { - add: ohm.actions.passThrough, addRec: function(x, _, y) { return [x.v, '+', y.v]; - }, - pri: ohm.actions.passThrough, - priX: ohm.actions.passThrough, - priY: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue + } }); t.deepEqual(s(m.match('x+y+x', 'add')).v, [['x', '+', 'y'], '+', 'x']); }); @@ -988,17 +936,9 @@ test('apply', function(t) { it('semantic actions', function() { var s = m.semantics().addAttribute('v', { - number: ohm.actions.passThrough, - foo: ohm.actions.passThrough, - bar: ohm.actions.passThrough, - baz: ohm.actions.passThrough, - qux: ohm.actions.passThrough, - quux: ohm.actions.passThrough, numberRec: function(n, d) { return [n.v, d.v]; - }, - digit: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue + } }); t.deepEqual(s(m.match('1234', 'number')).v, [[['1', '2'], '3'], '4']); }); @@ -1039,9 +979,7 @@ test('apply', function(t) { }, mulExpRec: function(x, _, y) { return ['mulExpRec', x.t, y.t]; - }, - priExp: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue + } }).addAttribute('v', { addExp: function(expr) { return expr.v; @@ -1057,19 +995,14 @@ test('apply', function(t) { }, priExp: function(expr) { return parseInt(expr.v); - }, - _terminal: ohm.actions.getPrimitiveValue + } }).addAttribute('p', { - addExp: ohm.actions.passThrough, addExpRec: function(x, _, y) { return '(' + x.p + '+' + y.p + ')'; }, - mulExp: ohm.actions.passThrough, mulExpRec: function(x, _, y) { return '(' + x.p + '*' + y.p + ')'; - }, - priExp: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue + } }); t.deepEqual(s(f).t, ['addExp', @@ -1144,9 +1077,7 @@ test('apply', function(t) { }, mulExpRec: function(x, _, y) { return [x.t, '*', y.t]; - }, - _terminal: ohm.actions.getPrimitiveValue, - _default: ohm.actions.passThrough + } }); t.deepEqual(s(m.match('7+8*9+0')).t, [['7', '+', ['8', '*', '9']], '+', '0']); }); @@ -1186,9 +1117,7 @@ test('apply', function(t) { }, barRec: function(x, y) { return ['barRec', x.t, y.t]; - }, - digit: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue + } }); t.deepEqual(s(f).t, ['tricky', @@ -1292,8 +1221,7 @@ test('inheritance', function(t) { }, digit: function(expr) { return ['digit', expr.v]; - }, - _terminal: ohm.actions.getPrimitiveValue + } }); var expected = ['number', [['digit', 'a'], ['digit', 'b'], ['digit', 'c'], ['digit', 'd']]]; t.deepEqual(s(ns.G2.match('abcd', 'number')).v, expected); @@ -1410,8 +1338,7 @@ test('bindings', function(t) { }, baz: function(expr) { return ['baz', expr.v, id++]; - }, - _terminal: ohm.actions.getPrimitiveValue + } }); t.deepEqual(s(g.match('ab')).v, { x: ['bar', 'a', 0], @@ -1433,8 +1360,7 @@ test('bindings', function(t) { }, baz: function(expr) { return ['baz', expr.v, id++]; - }, - _terminal: ohm.actions.getPrimitiveValue + } }); t.deepEqual(s(g.match('ab')).v, { x: ['bar', 'a', 1], @@ -1468,8 +1394,6 @@ test('inline rule declarations', function(t) { digit: function(expr) { return expr.v.charCodeAt(0) - '0'.charCodeAt(0); }, - _default: ohm.actions.passThrough, - _terminal: ohm.actions.getPrimitiveValue }); return function(node) { return s(node).v; @@ -1767,8 +1691,7 @@ test('bootstrap', function(t) { }, digit: function(expr) { return expr.v.charCodeAt(0) - '0'.charCodeAt(0); - }, - _terminal: ohm.actions.getPrimitiveValue + } }); t.equal(s(Arithmetic.match('10*(2+123)-4/5')).v, 1249.2); }); diff --git a/test/test-parameterized-rules.js b/test/test-parameterized-rules.js index be7093e4..7968fc94 100644 --- a/test/test-parameterized-rules.js +++ b/test/test-parameterized-rules.js @@ -9,7 +9,6 @@ var test = require('tape-catch'); var errors = require('../src/errors'); -var ohm = require('..'); var testUtil = require('./testUtil'); // -------------------------------------------------------------------- @@ -84,9 +83,7 @@ test('simple examples', function(t) { ' Start = Pair\n' + '}'); var s = g.semantics().addOperation('v', { - Pair: function(oparen, x, comma, y, cparen) { return [x.v(), y.v()]; }, - _terminal: ohm.actions.getPrimitiveValue, - _default: ohm.actions.passThrough + Pair: function(oparen, x, comma, y, cparen) { return [x.v(), y.v()]; } }); var cst = g.match('(1,2)', 'Start'); t.deepEqual(s(cst).v(), ['1', '2']); @@ -104,9 +101,7 @@ test('inline rule declarations', function(t) { '}'); var s = g.semantics().addOperation('v', { List_some: function(x, sep, xs) { return [x.v()].concat(xs.v()); }, - List_none: function() { return []; }, - _terminal: ohm.actions.getPrimitiveValue, - _default: ohm.actions.passThrough + List_none: function() { return []; } }); var cst = g.match('x, x,x', 'Start'); t.deepEqual(s(cst).v(), ['x', 'x', 'x']); @@ -124,9 +119,7 @@ test('left recursion', function(t) { '}'); var s = g.semantics().addOperation('v', { LeftAssoc_rec: function(x, op, y) { return [op.v(), x.v(), y.v()]; }, - LeftAssoc_base: function(x) { return x.v(); }, - _terminal: ohm.actions.getPrimitiveValue, - _default: ohm.actions.passThrough + LeftAssoc_base: function(x) { return x.v(); } }); var cst = g.match('1 + 2 + 3', 'Start'); t.deepEqual(s(cst).v(), ['+', ['+', '1', '2'], '3']); @@ -140,9 +133,7 @@ test('complex parameters', function(t) { ' two = x x\n' + '}'); var s = g.semantics().addOperation('v', { - two: function(x, y) { return [x.v(), y.v()]; }, - _terminal: ohm.actions.getPrimitiveValue, - _default: ohm.actions.passThrough + two: function(x, y) { return [x.v(), y.v()]; } }); t.deepEqual(s(g.match('42')).v(), ['4', '2']); t.equal(g.match('45').failed(), true); diff --git a/test/test-semantics.js b/test/test-semantics.js index cf9c25b3..247550de 100644 --- a/test/test-semantics.js +++ b/test/test-semantics.js @@ -37,10 +37,6 @@ test('operations', function(t) { }, digit: function(expr) { return expr.value().charCodeAt(0) - '0'.charCodeAt(0); - }, - _default: ohm.actions.passThrough, - _terminal: function() { - return this.primitiveValue; } }); @@ -57,8 +53,7 @@ test('operations', function(t) { }, number: function(n) { return [n.value()]; - }, - _default: ohm.actions.passThrough + } }); t.deepEqual(s(Arithmetic.match('9')).numberValues(), [9]); t.deepEqual(s(Arithmetic.match('13+10*2*3')).numberValues(), [13, 10, 2, 3]); @@ -86,7 +81,6 @@ test('attributes', function(t) { count++; return expr.value.charCodeAt(0) - '0'.charCodeAt(0); }, - _default: ohm.actions.passThrough, _terminal: function() { count++; return this.primitiveValue; @@ -172,10 +166,9 @@ test('_iter nodes', function(t) { s = g.semantics().addOperation('op', { letter: function(l) { return l.interval.contents; - }, - _default: ohm.actions.passThrough + } }); - t.deepEqual(s(m).op(), ['a', 'b', 'c'], 'works with passThrough'); + t.deepEqual(s(m).op(), ['a', 'b', 'c'], 'works with pass-through default behavior of _default'); s = g.semantics().addOperation('op', { letters: function(ls) { @@ -186,9 +179,7 @@ test('_iter nodes', function(t) { return typeof l.op === 'function'; }), 'children is an array of wrappers'); return ls.children.map(function(l) { return l.op(); }).join(','); - }, - _terminal: ohm.actions.getPrimitiveValue, - _default: ohm.actions.passThrough + } }); t.equal(s(m).op(), 'a,b,c'); @@ -197,19 +188,15 @@ test('_iter nodes', function(t) { test('_terminal nodes', function(t) { var g = ohm.grammar('G { letters = letter* }'); - var s = g.semantics().addOperation('op', { - _terminal: ohm.actions.getPrimitiveValue, - _default: ohm.actions.passThrough - }); + var s = g.semantics().addOperation('op', {}); var m = g.match('abc', 'letters'); - t.deepEqual(s(m).op(), ['a', 'b', 'c'], 'getPrimitiveValue works'); + t.deepEqual(s(m).op(), ['a', 'b', 'c'], 'default behavior is to return `primitiveValue`'); t.throws(function() { g.semantics().addOperation('op', { - _terminal: ohm.actions.passThrough, - _default: ohm.actions.passThrough + _terminal: function(x) {} }); - }, /wrong arity/, 'throws with passThrough'); + }, /wrong arity/); s = g.semantics().addOperation('op', { _terminal: function() { @@ -217,8 +204,7 @@ test('_terminal nodes', function(t) { t.equal(this.ctorName, '_terminal'); t.equal(this.children.length, 0, 'node has no children'); return this.primitiveValue; - }, - _default: ohm.actions.passThrough + } }); t.deepEqual(s(m).op(), ['a', 'b', 'c']); @@ -300,8 +286,7 @@ test('extending semantics', function(t) { var s = ns.G.semantics(). addOperation('value', { one: function(_) { return 1; }, - two: function(_) { return 2; }, - _terminal: ohm.actions.getPrimitiveValue + two: function(_) { return 2; } }). addOperation('valueTimesTwo', { _default: function(children) { return this.value() * 2; } @@ -342,8 +327,7 @@ test('extending semantics', function(t) { s = ns.G.semantics(). addAttribute('value', { one: function(_) { return 1; }, - two: function(_) { return 2; }, - _terminal: ohm.actions.getPrimitiveValue + two: function(_) { return 2; } }). addAttribute('valueTimesTwo', { _default: function(children) { return this.value * 2; }