6.0.0
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:
@@ -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"
|
||||
}
|
||||
}
|
||||
@@ -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);
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user