-
Notifications
You must be signed in to change notification settings - Fork 12.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Refactor removes whitespace #27294
Comments
This really is super annoying, so much that the much awaited "Move to new file" is practically useless - I prefer cutting & pasting manually to preserve formatting.. How large of a job is this to fix? Is it something that is doable for a one-time-contributor or would one need a deep understanding of parser, AST and emitter? |
An adequate shortcut I've found is to add two simple steps:
This leaves the minor problem of whitespace preservation around |
@RyanCavanaugh spoke offline with @mjbvz and I - while this doesn't seem like the desired behavior, this is going to involve a larger amount of work than it might seem since we're not equipped in our current refactoring machinery. |
@DanielRosenwasser does that mean that it's not going to happen? It really is too bad, since "the editor understanding and working with the code" is one of the selling points for typescript over javascript, at least for me. Great refactoring support is where typescript could really shine. |
No, I didn't mean to imply it wasn't going to happen, just that it's not happening in 3.8. |
I want to note that refactors not only removes blank lines, but alters other whitespace as well: Before: function Foo({ label }: { label: string }) {
return (
<div
id="time-label-top-container">
<div
id="time-label-container"
style={{
marginRight: '10px',
border: 'none',
}}
>
<div className="currentTimeLabel">{label}</div>
</div>
</div>
);
} After (move to a new file): import React from "react";
function Foo({ label }: {
label: string;
}) {
return (<div id="time-label-top-container">
<div id="time-label-container" style={{
marginRight: '10px',
border: 'none',
}}>
<div className="currentTimeLabel">{label}</div>
</div>
</div>);
} If I'm reading the proposed fix correctly, it will only provide newlines. Other formatting will still get lost. |
That is a correct-ish reading of the fix, but the example you just provided is really all about newlines. That said, this example works horribly in my branch, exposing some bugs in the implementation, so I’ll incorporate this as a test case. |
@andrewbranch Yeah, kind of realized after I posted, but there is also indentation and the added newlines in the function parameters. Glad I could provide a test case. Is it possible for me to try your branch with VS Code refactorings? |
FYI @jessetrinity working on a related class of bugs |
if (true) console.log('On the same line'); becomes if (true)
console.log('On the same line'); Does this PR handle this issue? I used TS 3.9 as @mjbvz recommended in this comment, the empty lines issue is solved, but the moving to the next line isn't. Should I create a new issue with this? |
Please try out https://marketplace.visualstudio.com/items?itemName=ms-vscode.vscode-typescript-next and file a separate issue with repro steps if that doesn't fix it. |
Refactors, like 'move to a new file', butchers formatting by removing empty lines in code. As refactors are meant to improve code style and structure, I should not manually have to reformat my code after I've applied one.
TypeScript Version: 3.1.0-dev.20180922
Search Terms:
Move to new file removes newlines, refactor removes newlines, removes whitespace, removes trivia
Code
Select function and 'move to a new file' in VS Code:
Expected behavior:
Same formatting:
Actual behavior:
Blank lines removed:
Related Issues:
Perhaps related to #843
The text was updated successfully, but these errors were encountered: