- 
                Notifications
    You must be signed in to change notification settings 
- Fork 141
[Request for Feedback] Add ontype formatting support #980
base: main
Are you sure you want to change the base?
[Request for Feedback] Add ontype formatting support #980
Conversation
| Hi @onno-vos-dev sorry for the late reply. Personally I don't have a problem merging this, especially if it's disabled by default initially. So, if you get a basic test in place and squash, I think we're good! Unless @gomoripeti, @alanz or others have a different opinion... | 
| very nice! | 
9f0a78c    to
    284ec99      
    Compare
  
    Co-authored-by: Andreas Hasselberg <[email protected]> Delete iostr.erl Fix linter complaints Fix proper error Fix typespec Maybe make Dialyzer happy? Temp fixes to get dialyzer to run Add spec Better fix for dialyzer errors Add config to enable on type formatting, defaulting to false Skip formatting if . is on a commented out line
284ec99    to
    b97266f      
    Compare
  
    | Opened: https://github.com/AdRoll/rebar3_format/issues/295 as that's the biggest bug that exists as of now. I haven't forgotten about this PR... Now let me go back and hide in a corner ashamed that this PR has been rotting away for so long... | 
| FWIW I think much bigger issue with  | 
| 
 Yeah I noticed that issue as well when trying to find if my issue was already reported but since the formatter currently doesn't support  | 
| The issue is not in defines, but in any usages of  -define(MUL(A, B), A * B).
test() -> ?MUL((1 + 2), (3 + 4)).the formatter will produce: -define(MUL(A, B), A * B).
test() -> ?MUL(1 + 2, 3 + 4).changing the result of  And while this example is fairly convoluted, there are frequently "guard-safe" macros using  | 
| Seems to me that  | 
[Request for Feedback]
Description
This PR adds on-type formatting support. The way this works is that it is triggered by adding a
.. This PR is a DRAFT PR which means we @anha0825 and myself are looking for feedback on this work.The feature is disabled by default but can be enabled by adding
format_on_type: trueto yourerlang_ls.config.No tests have been added as of yet as I'm not sure how tests for this sort of feature can be written? Considering that BSP will take care of formatting going forward, this should be more or less an "interim" solution anyway.