I'm extremely stupid and didn't commit as I go. To anyone reading this
I'm extremely sorry. A lot of these changes are very broad and I plan on
releasing Babel 6.0.0 today live on stage at Ember Camp London so I'm
afraid I couldn't wait. If you're ever in London I'll buy you a beer
(or assorted beverage!) to make up for it, also I'll kiss your feet and
give you a back massage, maybe.
This commit is contained in:
Sebastian McKenzie
2015-10-29 17:51:24 +00:00
parent 3974dd762d
commit ae7d5367f1
1501 changed files with 16477 additions and 19786 deletions

View File

@@ -1,11 +1,15 @@
{
"name": "babel-plugin-transform-class-properties",
"version": "1.0.0",
"version": "5.10.32",
"description": "",
"repository": "babel/babel",
"license": "MIT",
"main": "lib/index.js",
"keywords": [
"babel-plugin"
]
}
],
"dependencies": {
"babel-plugin-syntax-class-properties": "^5.10.32",
"babel-runtime": "^5.10.32"
}
}

View File

@@ -1,7 +1,141 @@
export default function () {
// todo: define instead of assign
export default function ({ types: t }) {
let findBareSupers = {
Super(path) {
if (path.parentPath.isCallExpression({ callee: path.node })) {
this.push(path.parentPath);
}
}
};
let referenceVisitor = {
ReferencedIdentifier(path) {
if (this.scope.hasOwnBinding(path.node.name)) {
this.collision = true;
path.skip();
}
}
};
return {
inherits: require("babel-plugin-syntax-class-properties"),
visitor: {
// your visitor methods go here
Class(path) {
let isDerived = !!path.node.superClass;
let constructor;
let props = [];
let body = path.get("body");
for (let path of body.get("body")) {
if (path.isClassProperty()) {
props.push(path);
} else if (path.isClassMethod({ kind: "constructor" })) {
constructor = path;
}
}
if (!props.length) return;
let nodes = [];
let ref;
if (path.isClassExpression()) {
ref = path.scope.generateUidIdentifier();
} else { // path.isClassDeclaration()
ref = path.node.id;
}
let instanceBody = [];
for (let prop of props) {
let propNode = prop.node;
if (propNode.decorators) continue;
if (!propNode.value) continue;
let isStatic = propNode.static;
if (isStatic) {
nodes.push(t.expressionStatement(
t.assignmentExpression("=", t.memberExpression(ref, propNode.key), propNode.value)
));
} else {
instanceBody.push(t.expressionStatement(
t.assignmentExpression("=", t.memberExpression(t.thisExpression(), propNode.key), propNode.value)
));
}
}
if (instanceBody.length) {
if (!constructor) {
let newConstructor = t.classMethod("constructor", t.identifier("constructor"), [], t.blockStatement([]));
if (isDerived) {
newConstructor.params = [t.restElement(t.identifier("args"))];
newConstructor.body.body.push(
t.returnStatement(
t.callExpression(
t.super(),
[t.spreadElement(t.identifier("args"))]
)
)
);
}
[constructor] = body.unshiftContainer("body", newConstructor);
}
let collisionState = {
collision: false,
scope: constructor.scope
};
for (let prop of props) {
prop.traverse(referenceVisitor, collisionState);
if (collisionState.collision) break;
}
if (collisionState.collision) {
let initialisePropsRef = path.scope.generateUidIdentifier("initialiseProps");
nodes.push(t.variableDeclaration("var", [
t.variableDeclarator(
initialisePropsRef,
t.functionExpression(null, [], t.blockStatement(instanceBody))
)
]));
instanceBody = [
t.expressionStatement(
t.callExpression(t.memberExpression(initialisePropsRef, t.identifier("call")), [t.thisExpression()])
)
];
}
//
if (isDerived) {
let bareSupers = []
constructor.traverse(findBareSupers, bareSupers);
for (let bareSuper of bareSupers) {
bareSuper.insertAfter(instanceBody);
}
} else {
constructor.get("body").unshiftContainer("body", instanceBody);
}
}
for (let prop of props) {
prop.remove();
}
if (!nodes.length) return;
if (path.isClassExpression()) {
nodes.push(t.expressionStatement(ref));
}
path.insertAfter(nodes);
}
}
};
}