-
Notifications
You must be signed in to change notification settings - Fork 24
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
[feat] Add --wrap n
option to change the length at which lines get wrapped
#38
Comments
Yes this is a good suggestion, I will work on it soon! |
Implemented in a6177f0, let me know if it works as expected. Thanks for your helpful suggestions! |
It works as expected! (Including with the recent ability to customise parameters to Thanks for implementing this so quickly! It doesn't wrap as tightly to the 120-character rule as the Rewrap extension for VS Code, but that's maybe due to the minimum line length setting. And I understand that you're using the |
That's right, see #6 for a discussion of this. I should mention that I'm not sure that |
I wonder if there could be a dynamic "minimum length" which takes into account the current indent of the line that is being wrapped... I'll have a think to see if I can come up with a working idea. Maintaining |
The problem is that where you choose to wrap the line also affects the indentation level (you might wrap it before a closing bracket, for example). |
Ah yes indeed. One (not so nice) solution would be to do several local iterations. (I say this without knowing how the initial multi-pass framework was implemented.) My thought is: when a line should be wrapped, split it into several lines and queue them all for re-indentation. As the code iterates through the queued lines, it corrects the indentation if need be, and if that requires wrapping again, then it merges the trailing word(s) with the next line on the queue (if there is one), computes the new wrapping point, and submits the remaining line for re-indentation (if there is one). This feels like it should converge to a stable combination of indentation and tight wrapping, but feeling never takes care of all the edge cases. |
This is almost what the current implementation does, with a queue of lines which require processing (possibly multiple times), but without merging trailing words. This would require us to keep track of where line breaks are in the original file too, and I think this is a little complicated for now. I'll close the issue since I fixed the main request of the |
It could be nice to let the user choose the length at which lines get wrapped, with the default remaining 80 as it is now, and
--wrap 0
being the equivalent of--keep
.The text was updated successfully, but these errors were encountered: