Skip to content

Commit

Permalink
fix: plugin-transform-object-rest-spread param with default value
Browse files Browse the repository at this point in the history
  • Loading branch information
christophehurpeau authored and loganfsmyth committed Jan 15, 2017
1 parent 1ab58d6 commit 4a19655
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 7 deletions.
19 changes: 12 additions & 7 deletions packages/babel-plugin-transform-object-rest-spread/src/index.js
Expand Up @@ -42,19 +42,23 @@ export default function ({ types: t }) {
];
}

function replaceRestProperty(paramsPath, i, numParams) {
if (paramsPath.isObjectPattern() && hasRestProperty(paramsPath)) {
const parentPath = paramsPath.parentPath;
function replaceRestProperty(parentPath, paramPath, i, numParams) {
if (paramPath.isAssignmentPattern()) {
replaceRestProperty(parentPath, paramPath.get("left"), i, numParams);
return;
}

if (paramPath.isObjectPattern() && hasRestProperty(paramPath)) {
const uid = parentPath.scope.generateUidIdentifier("ref");

const declar = t.variableDeclaration("let", [
t.variableDeclarator(paramsPath.node, uid)
t.variableDeclarator(paramPath.node, uid)
]);
declar._blockHoist = i ? numParams - i : 1;

parentPath.ensureBlock();
parentPath.get("body").unshiftContainer("body", declar);
paramsPath.replaceWith(uid);
paramPath.replaceWith(uid);
}
}

Expand All @@ -67,7 +71,7 @@ export default function ({ types: t }) {
Function(path) {
const params = path.get("params");
for (let i = 0; i < params.length; i++) {
replaceRestProperty(params[i], i, params.length);
replaceRestProperty(params[i].parentPath, params[i], i, params.length);
}
},
// adapted from transform-es2015-destructuring/src/index.js#pushObjectRest
Expand Down Expand Up @@ -141,7 +145,8 @@ export default function ({ types: t }) {
},
// try {} catch ({a, ...b}) {}
CatchClause(path) {
replaceRestProperty(path.get("param"));
const paramPath = path.get("param");
replaceRestProperty(paramPath.parentPath, paramPath);
},
// ({a, ...b} = c);
AssignmentExpression(path, file) {
Expand Down
Expand Up @@ -4,6 +4,7 @@ function a3({a2, b2, ...c2}) {}
function a4({a3, ...c3}, {a5, ...c5}) {}
function a5({a3, b2: { ba1, ...ba2 }, ...c3}) {}
function a6({a3, b2: { ba1, ...ba2 } }) {}
function a7({a1 = 1, ...b1} = {}) {}
// Unchanged
function b(a) {}
function b2(a, ...b) {}
Expand Down
Expand Up @@ -24,6 +24,10 @@ function a6(_ref7) {
let { a3, b2: { ba1 } } = _ref7;
let ba2 = babelHelpers.objectWithoutProperties(_ref7.b2, ["ba1"]);
}
function a7(_ref8 = {}) {
let { a1 = 1 } = _ref8;
let b1 = babelHelpers.objectWithoutProperties(_ref8, ["a1"]);
}
// Unchanged
function b(a) {}
function b2(a, ...b) {}
Expand Down

0 comments on commit 4a19655

Please sign in to comment.