Spaces:
Running
Running
/* Generated by `npm run build`, do not edit! */ | |
var acorn = require("acorn") | |
if (false) { | |
throw new Error(("acorn-private-class-elements requires acorn@^6.1.0, not " + (acorn.version))) | |
} | |
var tt = acorn.tokTypes | |
var TokenType = acorn.TokenType | |
module.exports = function(Parser) { | |
// Only load this plugin once. | |
if (Parser.prototype.parsePrivateName) { | |
return Parser | |
} | |
// Make sure `Parser` comes from the same acorn as our `tt`, | |
// otherwise the comparisons fail. | |
var cur = Parser | |
while (cur && cur !== acorn.Parser) { | |
cur = cur.__proto__ | |
} | |
if (cur !== acorn.Parser) { | |
throw new Error("acorn-private-class-elements does not support mixing different acorn copies") | |
} | |
Parser = /*@__PURE__*/(function (Parser) { | |
function Parser_ () { | |
Parser.apply(this, arguments); | |
} | |
if ( Parser ) Parser_.__proto__ = Parser; | |
Parser_.prototype = Object.create( Parser && Parser.prototype ); | |
Parser_.prototype.constructor = Parser_; | |
Parser_.prototype._branch = function _branch () { | |
this.__branch = this.__branch || new Parser({ecmaVersion: this.options.ecmaVersion}, this.input) | |
this.__branch.end = this.end | |
this.__branch.pos = this.pos | |
this.__branch.type = this.type | |
this.__branch.value = this.value | |
this.__branch.containsEsc = this.containsEsc | |
return this.__branch | |
}; | |
Parser_.prototype.parsePrivateClassElementName = function parsePrivateClassElementName (element) { | |
element.computed = false | |
element.key = this.parsePrivateName() | |
if (element.key.name == "constructor") { this.raise(element.key.start, "Classes may not have a private element named constructor") } | |
var accept = {get: "set", set: "get"}[element.kind] | |
var privateBoundNames = this._privateBoundNamesStack[this._privateBoundNamesStack.length - 1] | |
if (Object.prototype.hasOwnProperty.call(privateBoundNames, element.key.name) && privateBoundNames[element.key.name] !== accept) { | |
this.raise(element.start, "Duplicate private element") | |
} | |
privateBoundNames[element.key.name] = element.kind || true | |
delete this._unresolvedPrivateNamesStack[this._unresolvedPrivateNamesStack.length - 1][element.key.name] | |
return element.key | |
}; | |
Parser_.prototype.parsePrivateName = function parsePrivateName () { | |
var node = this.startNode() | |
node.name = this.value | |
this.next() | |
this.finishNode(node, "PrivateName") | |
if (this.options.allowReserved == "never") { this.checkUnreserved(node) } | |
return node | |
}; | |
// Parse # token | |
Parser_.prototype.getTokenFromCode = function getTokenFromCode (code) { | |
if (code === 35) { | |
++this.pos | |
var word = this.readWord1() | |
return this.finishToken(this.privateNameToken, word) | |
} | |
return Parser.prototype.getTokenFromCode.call(this, code) | |
}; | |
// Manage stacks and check for undeclared private names | |
Parser_.prototype.parseClass = function parseClass (node, isStatement) { | |
this._privateBoundNamesStack = this._privateBoundNamesStack || [] | |
var privateBoundNames = Object.create(this._privateBoundNamesStack[this._privateBoundNamesStack.length - 1] || null) | |
this._privateBoundNamesStack.push(privateBoundNames) | |
this._unresolvedPrivateNamesStack = this._unresolvedPrivateNamesStack || [] | |
var unresolvedPrivateNames = Object.create(null) | |
this._unresolvedPrivateNamesStack.push(unresolvedPrivateNames) | |
var _return = Parser.prototype.parseClass.call(this, node, isStatement) | |
this._privateBoundNamesStack.pop() | |
this._unresolvedPrivateNamesStack.pop() | |
if (!this._unresolvedPrivateNamesStack.length) { | |
var names = Object.keys(unresolvedPrivateNames) | |
if (names.length) { | |
names.sort(function (n1, n2) { return unresolvedPrivateNames[n1] - unresolvedPrivateNames[n2]; }) | |
this.raise(unresolvedPrivateNames[names[0]], "Usage of undeclared private name") | |
} | |
} else { Object.assign(this._unresolvedPrivateNamesStack[this._unresolvedPrivateNamesStack.length - 1], unresolvedPrivateNames) } | |
return _return | |
}; | |
// Parse private element access | |
Parser_.prototype.parseSubscript = function parseSubscript (base, startPos, startLoc, noCalls, maybeAsyncArrow) { | |
if (!this.eat(tt.dot)) { | |
return Parser.prototype.parseSubscript.call(this, base, startPos, startLoc, noCalls, maybeAsyncArrow) | |
} | |
var node = this.startNodeAt(startPos, startLoc) | |
node.object = base | |
node.computed = false | |
if (this.type == this.privateNameToken) { | |
node.property = this.parsePrivateName() | |
if (!this._privateBoundNamesStack.length || !this._privateBoundNamesStack[this._privateBoundNamesStack.length - 1][node.property.name]) { | |
this._unresolvedPrivateNamesStack[this._unresolvedPrivateNamesStack.length - 1][node.property.name] = node.property.start | |
} | |
} else { | |
node.property = this.parseIdent(true) | |
} | |
return this.finishNode(node, "MemberExpression") | |
}; | |
// Prohibit delete of private class elements | |
Parser_.prototype.parseMaybeUnary = function parseMaybeUnary (refDestructuringErrors, sawUnary) { | |
var _return = Parser.prototype.parseMaybeUnary.call(this, refDestructuringErrors, sawUnary) | |
if (_return.operator == "delete") { | |
if (_return.argument.type == "MemberExpression" && _return.argument.property.type == "PrivateName") { | |
this.raise(_return.start, "Private elements may not be deleted") | |
} | |
} | |
return _return | |
}; | |
return Parser_; | |
}(Parser)) | |
Parser.prototype.privateNameToken = new TokenType("privateName") | |
return Parser | |
} | |