Skip to content

Commit

Permalink
Merge pull request #34 from ony3000/fix-core-parts
Browse files Browse the repository at this point in the history
Modify core parts to handle different combinations of target braces that can exist on a single line
  • Loading branch information
ony3000 authored May 15, 2024
2 parents 2586045 + 81862fd commit e9ad1e6
Show file tree
Hide file tree
Showing 25 changed files with 839 additions and 91 deletions.
184 changes: 93 additions & 91 deletions src/packages/core-parts/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -38,54 +38,36 @@ function parseLineByLine(
rangeStartOfLine <= rangeStartOfBrace && rangeEndOfBrace <= rangeEndOfLine,
);
const parts: LinePart[] = [];
let maybeLastPart: LinePart | null = null;

const offset = indentUnit.length * indentLevel;
const trimmedLine = line.slice(offset); // base of 'mutableLine'
let mutableLine = trimmedLine;

if (braceNodesInCurrentLine.length === 0) {
let temporaryRangeEnd = rangeEndOfLine;

for (let index = braceNodesInCurrentLine.length - 1; index >= 0; index -= 1) {
const braceNode = braceNodesInCurrentLine[index];
const [rangeStartOfBrace, rangeEndOfBrace] = braceNode.range;

parts.push({
type: 'Text',
body: mutableLine,
body: formattedText.slice(rangeEndOfBrace, temporaryRangeEnd),
});
} else {
const lastBraceNodeInCurrentLine = braceNodesInCurrentLine.pop()!;

if (
lastBraceNodeInCurrentLine.type === BraceType.OB ||
lastBraceNodeInCurrentLine.type === BraceType.OBTO
) {
maybeLastPart = {
type: lastBraceNodeInCurrentLine.type,
body: formattedText.slice(lastBraceNodeInCurrentLine.range[0], rangeEndOfLine),
};
mutableLine = formattedText.slice(
rangeStartOfLine + offset,
lastBraceNodeInCurrentLine.range[0],
);
} else {
braceNodesInCurrentLine.push(lastBraceNodeInCurrentLine);
}

if (braceNodesInCurrentLine.length) {
parts.push({
type: BraceType.CB,
body: '}',
});
mutableLine = mutableLine.slice(1);
}

if (mutableLine) {
parts.push({
type: 'Text',
body: mutableLine,
});
}

if (maybeLastPart) {
parts.push(maybeLastPart);
}
parts.push({
type: braceNode.type,
body: formattedText.slice(rangeStartOfBrace, rangeEndOfBrace),
});
temporaryRangeEnd = rangeStartOfBrace;
}
parts.push({
type: 'Text',
body: formattedText.slice(rangeStartOfLine, temporaryRangeEnd).slice(offset),
});
parts.reverse();

if (parts.length > 1 && parts[0].body === '') {
parts.shift();
}
if (parts.length > 1 && parts[parts.length - 1].body === '') {
parts.pop();
}

rangeStartOfLine = rangeEndOfLine + EOL.length;
Expand All @@ -98,63 +80,83 @@ function parseLineByLine(
}

/**
* If `Text` exists after `ClosingBrace`, add a line break between `ClosingBrace` and `Text`.
* Add a line break after `ClosingBrace`.
*/
function splitLineStartingWithClosingBrace(lineNodes: LineNode[]) {
for (let index = lineNodes.length - 1; index >= 0; index -= 1) {
const { indentLevel, parts } = lineNodes[index];
const firstPart = parts.at(0);

if (firstPart?.type === BraceType.CB) {
const secondPart = parts.at(1);

if (secondPart) {
lineNodes.splice(
index,
1,
{ indentLevel, parts: [firstPart] },
{
indentLevel,
parts: [
{ type: secondPart.type, body: secondPart.body.trimStart() },
...parts.slice(2),
],
},
);
function splitLineContainingClosingBrace(lineNodes: LineNode[]) {
for (let lineIndex = lineNodes.length - 1; lineIndex >= 0; lineIndex -= 1) {
const { indentLevel, parts } = lineNodes[lineIndex];
const temporaryLineNodes: LineNode[] = [];

let temporaryPartIndex = 0;

for (let partIndex = 0; partIndex < parts.length; partIndex += 1) {
const currentPart = parts[partIndex];

if (currentPart.type === BraceType.CB) {
temporaryLineNodes.push({
indentLevel,
parts: parts.slice(temporaryPartIndex, partIndex + 1),
});
temporaryPartIndex = partIndex + 1;

const rightPart = parts.at(partIndex + 1);

if (rightPart) {
rightPart.body = rightPart.body.trimStart();
}
}
}
temporaryLineNodes.push({
indentLevel,
parts: parts.slice(temporaryPartIndex),
});

lineNodes.splice(
lineIndex,
1,
...temporaryLineNodes.filter((lineNode) => lineNode.parts.length),
);
}
}

/**
* If `Text` exists before `OpeningBrace`, add a line break between `OpeningBrace` and `Text`.
* Add a line break before `OpeningBrace`.
*/
function splitLineEndingWithOpeningBrace(lineNodes: LineNode[]) {
for (let index = lineNodes.length - 1; index >= 0; index -= 1) {
const { indentLevel, parts } = lineNodes[index];
const lastPart = parts.at(-1);

if (lastPart?.type === BraceType.OB || lastPart?.type === BraceType.OBTO) {
const secondLastPart = parts.at(-2);

if (secondLastPart) {
lineNodes.splice(
index,
1,
{
indentLevel,
parts: [
...parts.slice(0, -2),
{ type: secondLastPart.type, body: secondLastPart.body.trimEnd() },
],
},
{
indentLevel: lastPart?.type === BraceType.OBTO ? indentLevel + 1 : indentLevel,
parts: [lastPart],
},
);
function splitLineContainingOpeningBrace(lineNodes: LineNode[]) {
for (let lineIndex = lineNodes.length - 1; lineIndex >= 0; lineIndex -= 1) {
const { indentLevel, parts } = lineNodes[lineIndex];
const temporaryLineNodes: LineNode[] = [];

let temporaryPartIndex = parts.length;

for (let partIndex = parts.length - 1; partIndex >= 0; partIndex -= 1) {
const currentPart = parts[partIndex];

if (currentPart.type === BraceType.OB || currentPart.type === BraceType.OBTO) {
temporaryLineNodes.push({
indentLevel: currentPart.type === BraceType.OBTO ? indentLevel + 1 : indentLevel,
parts: parts.slice(partIndex, temporaryPartIndex),
});
temporaryPartIndex = partIndex;

const leftPart = parts.at(partIndex - 1);

if (leftPart) {
leftPart.body = leftPart.body.trimEnd();
}
}
}
temporaryLineNodes.push({
indentLevel,
parts: parts.slice(0, temporaryPartIndex),
});
temporaryLineNodes.reverse();

lineNodes.splice(
lineIndex,
1,
...temporaryLineNodes.filter((lineNode) => lineNode.parts.length),
);
}
}

Expand Down Expand Up @@ -197,10 +199,10 @@ export function parseLineByLineAndAssemble(

const lineNodes = parseLineByLine(formattedText, indentUnit, targetBraceNodes);

splitLineStartingWithClosingBrace(lineNodes);
splitLineContainingClosingBrace(lineNodes);

if (options.braceStyle === 'allman') {
splitLineEndingWithOpeningBrace(lineNodes);
splitLineContainingOpeningBrace(lineNodes);
}

return assembleLine(lineNodes, indentUnit);
Expand Down
28 changes: 28 additions & 0 deletions tests/v2-test/astro/issue-25/1tbs.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,34 @@ const foo = {
bar: {},
};
</script>
`,
},
{
name: 'destructuring assignment with default value',
input: `
---
const renderComponent = ({handleSubmit = () => {}, errors}) => {
return null;
};
---
<script>
const renderComponent = ({handleSubmit = () => {}, errors}) => {
return null;
};
</script>
`,
output: `---
const renderComponent = ({ handleSubmit = () => {}, errors }) => {
return null;
};
---
<script>
const renderComponent = ({ handleSubmit = () => {}, errors }) => {
return null;
};
</script>
`,
},
{
Expand Down
32 changes: 32 additions & 0 deletions tests/v2-test/astro/issue-25/allman.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,38 @@ const foo = {
bar: {},
};
</script>
`,
},
{
name: 'destructuring assignment with default value',
input: `
---
const renderComponent = ({handleSubmit = () => {}, errors}) => {
return null;
};
---
<script>
const renderComponent = ({handleSubmit = () => {}, errors}) => {
return null;
};
</script>
`,
output: `---
const renderComponent = ({ handleSubmit = () =>
{}, errors }) =>
{
return null;
};
---
<script>
const renderComponent = ({ handleSubmit = () =>
{}, errors }) =>
{
return null;
};
</script>
`,
},
{
Expand Down
28 changes: 28 additions & 0 deletions tests/v2-test/astro/issue-25/stroustrup.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,34 @@ const foo = {
bar: {},
};
</script>
`,
},
{
name: 'destructuring assignment with default value',
input: `
---
const renderComponent = ({handleSubmit = () => {}, errors}) => {
return null;
};
---
<script>
const renderComponent = ({handleSubmit = () => {}, errors}) => {
return null;
};
</script>
`,
output: `---
const renderComponent = ({ handleSubmit = () => {}, errors }) => {
return null;
};
---
<script>
const renderComponent = ({ handleSubmit = () => {}, errors }) => {
return null;
};
</script>
`,
},
{
Expand Down
24 changes: 24 additions & 0 deletions tests/v2-test/babel/issue-25/1tbs.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,30 @@ const foo = {
output: `const foo = {
bar: {},
};
`,
},
{
name: 'destructuring assignment with default value',
input: `
const renderComponent = ({handleSubmit = () => {}, errors}) => {
const ref = React.createRef();
return render(
<StyleErrorsContextProvider initialState={errors}>
<PublishButton formRef={ref} handleSubmit={handleSubmit} />
</StyleErrorsContextProvider>
);
};
`,
output: `const renderComponent = ({ handleSubmit = () => {}, errors }) => {
const ref = React.createRef();
return render(
<StyleErrorsContextProvider initialState={errors}>
<PublishButton formRef={ref} handleSubmit={handleSubmit} />
</StyleErrorsContextProvider>,
);
};
`,
},
{
Expand Down
26 changes: 26 additions & 0 deletions tests/v2-test/babel/issue-25/allman.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,32 @@ const foo = {
output: `const foo = {
bar: {},
};
`,
},
{
name: 'destructuring assignment with default value',
input: `
const renderComponent = ({handleSubmit = () => {}, errors}) => {
const ref = React.createRef();
return render(
<StyleErrorsContextProvider initialState={errors}>
<PublishButton formRef={ref} handleSubmit={handleSubmit} />
</StyleErrorsContextProvider>
);
};
`,
output: `const renderComponent = ({ handleSubmit = () =>
{}, errors }) =>
{
const ref = React.createRef();
return render(
<StyleErrorsContextProvider initialState={errors}>
<PublishButton formRef={ref} handleSubmit={handleSubmit} />
</StyleErrorsContextProvider>,
);
};
`,
},
{
Expand Down
Loading

0 comments on commit e9ad1e6

Please sign in to comment.