-
Notifications
You must be signed in to change notification settings - Fork 120
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
Support for range format #212
Comments
I don't understand how your proposal is supposed to work. Can you explain further? |
Sorry for not be specific, I think my suggestion is missing the end range. You can see above an example where (my-func (|foo a
b
c|)) clojure-lsp would call: (cljfmt.core/reformat-string full-text 1 12 3 16) would result formatting only the selected range: (my-func (foo a
b
c))
Does that makes sense? |
Why is the |
hahaha, yes, sorry, GitHub indentation is weird, fixed! |
If implemented, this should be a separate function, e.g. Have you considered pulling out just the current top level form, adding some unique markers to mark the start and end of the region, formatting and then snipping out the relevent area using the markers? |
That's how we do ATM, we format the whole top level form, but if we format only the parent form of the selected range, it will ignore the spacing |
I don't understand what this means. Can you provide an example? |
Sure, so, as I said it here, If I format the code with the selected range between the (a
(b
|(c
(+ 2 3)|))) I'd expect to be formatted as: (a
(b
(c
(+ 2 3)))) But when we call (a
(b
(c
(+ 2 3)))) You can see that the spacing before That's why I suggested having a new function on cljfmt that we pass the whole text, the range and cljfmt take care of formatting only the range specified. |
Okay. How do you envision this new I'm also curious as to why formatting the top level form doesn't give you the performance you need. How large are the forms that you're having problems with? Do you have examples? |
For the regions that cut off at syntax boundaries, cljfmt could just get the parent form of the start line/col maybe? The initial issue use simple forms, but I could not repro that, I can repro that on forms like this though, If I try to slurp/barf a parent, it'll call later the rangeFormatting of clojure-lsp, and for this case takes about 6s to format this top level form! |
So, I just found that this could be a cljfmt/reformat-node issue, if I tell cljfmt to format this whole file, it takes about I didn't make a benchmark, those are numbers from clojure-lsp server <-> editor client request time, so probably it's adding some ms to that, even so, 6s seems too much to a reformat-node, am I wrong? |
Yeah, that's taking way too long. It should be a few milliseconds at most. There must be something that's causing it issues. |
assuming there's no problem with reformat-node, for the proposal, I think it would help to introduce a function like It could jump to a cursor position and call clj-rewrite should be able to then reformat the enclosing node followed by pushing each subsequent line some number of spaces (or tabs) to the right according to the rules. Right now, clients have to operate on a top level form because they don't know the indent rules for nested forms. Operating on the top level form of, say, big edn files can be pretty painful for clients that are autoindenting. |
That's fine, but the first step should be fixing the performance issue, as extra functions may be unnecessary if the existing functions are made to be performant. |
Hello, on clojure-lsp, we use
cljfmt
as our format feature and it works well for most cases, thank you for your work!There is an issue though related to performance with huge buffers. The LSP protocol allows two kind of format requests: format the whole buffer and format a ranged code.
clojure-lsp
implement both but the range format seems to have some performance issues with large buffers since we don't correctly format the range code but the whole form likedefn
,def
etc.Here is how we format ATM, the
reformat-node
is not enough for us as if I select only thebar
function of the code below, the spacings will not be correct:(cljfmt/reformat-node foo-node)
This happens because cljfmt doesn't know about the previous code before the foo node.
My suggestion is to add another function on cljfmt that accept a line and column to format, just like we call to the full buffer format:
(cljfmt.core/reformat-string text line column)
WDYT?
The text was updated successfully, but these errors were encountered: