-
Notifications
You must be signed in to change notification settings - Fork 41
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Make xstate-layout string placement more robust to changes #287
base: main
Are you sure you want to change the base?
Conversation
|
const proximity = | ||
this.machineCallResult.callee.loc!.start.line - comment.loc!.end.line; | ||
|
||
return Math.abs(proximity) <= 2; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not quite sure why we test this._fileAst.comments
in the first place. Perhaps it's to "simplify" the logic to locate it when it's put above the variable declaration. I don't think this is the best solution here though.
We should rely more on .leadingComments
- we don't have to loop through all existing comments in the file if we can rely on more local ones. And when we take a look at how .leadingComments
behave then we can notice that they can actually be far away from the node, as long as there are no AST nodes in between the comment and the node. Based on that, I don't think we want to test proximity here.
What we should do here is something like this:
// this might not be easily available right now because we might only get access to Node and not to the NodePath
// Nodes do not hold a reference to their parent in the Babel's AST (in TS they have access to that)
const callExpression = this.machineCallResult.callee.parent;
const callComment = (callExpression.leadingComments || []).findLast((comment) =>
comment.value.includes("xstate-layout")
);
if (callComment) {
// construct the return value
return {};
}
if (t.isVariableDeclarator(callExpression.parent)) {
const declaratorComment = (
callExpression.parent.leadingComments || []
).findLast((comment) => comment.value.includes("xstate-layout"));
if (declaratorComment) {
// construct the return value
return {};
}
// TODO: what should happen if there are multiple matching comments above the declaration?
const declarationComment = (
callExpression.parent.parent.leadingComments || []
).findLast((comment) => comment.value.includes("xstate-layout"));
if (declarationComment) {
// construct the return value
return {};
}
return undefined;
}
if (t.isAssignmentExpression(callExpression.parent)) {
const assignmentComment = (
callExpression.parent.leadingComments || []
).findLast((comment) => comment.value.includes("xstate-layout"));
if (assignmentComment) {
// construct the return value
return {};
}
return undefined;
}
return undefined;
This PR ensures that the machine extractor will detect the layout string even if it's not directly above the const declaration. This potentially solves the multiple layout string issues found here: