move logic to flow plugin

This commit is contained in:
Vladimir Kurchatkin 2016-06-24 20:23:02 +03:00
parent d5f75cb2f0
commit f0c7660980
2 changed files with 15 additions and 6 deletions

View File

@ -621,6 +621,10 @@ pp.isClassProperty = function () {
return this.match(tt.eq) || this.isLineTerminator();
};
pp.isClassMutatorStarter = function () {
return false;
};
pp.parseClassBody = function (node) {
// class bodies are implicitly strict
let oldStrict = this.state.strict;
@ -658,7 +662,6 @@ pp.parseClassBody = function (node) {
let isGenerator = this.eat(tt.star);
let isGetSet = false;
let isAsync = false;
let isGeneric = false;
this.parsePropertyName(method);
@ -693,13 +696,9 @@ pp.parseClassBody = function (node) {
if (!method.computed) {
let { key } = method;
if (this.hasPlugin("flow") && this.isRelational("<")) {
isGeneric = true;
}
// handle get/set methods
// eg. class Foo { get bar() {} set bar() {} }
if (!isAsync && !isGenerator && !isGeneric && key.type === "Identifier" && !this.match(tt.parenL) && (key.name === "get" || key.name === "set")) {
if (!isAsync && !isGenerator && !this.isClassMutatorStarter() && key.type === "Identifier" && !this.match(tt.parenL) && (key.name === "get" || key.name === "set")) {
isGetSet = true;
method.kind = key.name;
key = this.parsePropertyName(method);

View File

@ -1075,4 +1075,14 @@ export default function (instance) {
return inner.call(this, node);
};
});
instance.extend("isClassMutatorStarter", function (inner) {
return function () {
if (this.isRelational("<")) {
return true;
} else {
return inner.call(this);
}
};
});
}