Make exportIdentifiers and array so that base object properties are not accounted (#137)

This commit is contained in:
Daniel Tschinder
2016-09-22 22:00:39 +02:00
committed by Henry Zhu
parent 3210bbbce0
commit 952d50faf9
4 changed files with 107 additions and 4 deletions

View File

@@ -939,10 +939,10 @@ pp.checkExport = function (node, checkNames, isDefault) {
};
pp.checkDuplicateExports = function(node, name, isDefault) {
if (this.state.exportedIdentifiers[name]) {
if (this.state.exportedIdentifiers.indexOf(name) > -1) {
this.raiseDuplicateExportError(node, name, isDefault);
}
this.state.exportedIdentifiers[name] = true;
this.state.exportedIdentifiers.push(name);
};
pp.raiseDuplicateExportError = function(node, name, isDefault) {

View File

@@ -43,7 +43,7 @@ export default class State {
this.containsEsc = this.containsOctal = false;
this.octalPosition = null;
this.exportedIdentifiers = {};
this.exportedIdentifiers = [];
return this;
}
@@ -123,7 +123,7 @@ export default class State {
// Names of exports store. `default` is stored as a name for both
// `export default foo;` and `export { foo as default };`.
exportedIdentifiers: {[id:string]: boolean};
exportedIdentifiers: Array<string>;
curPosition() {
return new Position(this.curLine, this.pos - this.lineStart);