Thank you Fabian. This new patch also fixes this problem in my tests. Can you please try it in your use cases? There would be some other things to fix as well, but maybe it would be better to do it in emacs 31. What do you think Eli? Vincenzo In data domenica 23 marzo 2025 20:20:56 Ora standard dell’Europa centrale, Fabian Brosda ha scritto: > Hi Vincenzo, > > all right, thanks for taking care of it. Just in case you don't already > know and maybe interesting, if the indentation should in fact be exactly > the same as in js-mode, I noticed, that your arrow function example is > indented differently. > > In js-mode: > > const Geek = (a, b) => > { > return (a + " " + b); > } > > > In js-ts-mode: > > const Geek = (a, b) => > { > return (a + " " + b); > } > > js-indent-level is set to 4 in both cases. Looks like js-mode in general > aligns the part of a variable declaration, with the start of the > variable if you add a line break somewhere. > > Fabian > > Vincenzo Pupillo writes: > > Ciao Fabian, thank you. > > In fact, there are other cases where it does not work, and especially the > > behavior is different from js-mode. I need to think about this a bit > > more.. > > > > Vincenzo > > > > In data domenica 23 marzo 2025 11:18:02 Ora standard dell’Europa centrale, > > > > Fabian Brosda ha scritto: > >> Hi, > >> thanks for the explanation and the patch. The result from the patch is > >> a GNU-style indentation, where only the braces for functions are not > >> indented, while braces for other blocks (if/else, loops, arrow > >> functions) are indented. > >> > >> What I would like to have is Allman style indentation, where the braces > >> for blocks like if/else indent the same as for functions. This also > >> seems the default behavior in the old js-mode. In this case I think it > >> would be correct to not indent the brace for the arrow function. For > >> reference, I found an issue in eslint regarding this indentation: > >> > >> https://github.com/eslint/eslint/issues/8493 > >> > >> Would it be possible to also support the later? > >> > >> Fabian > >> > >> Vincenzo Pupillo writes: > >> > Ciao, > >> > a rule like this: > >> > ((node-is "statement_block") parent-bol 0) > >> > > >> > works for function but brakes the indentation of expressione like this: > >> > const Geek = (a, b) => > >> > > >> > { > >> > > >> > return (a + " " + b); > >> > > >> > } > >> > > >> > In the attached patch, I have added a new rule specifically for this > >> > case. > >> > > >> > Vincenzo > >> > > >> > In data sabato 22 marzo 2025 13:24:16 Ora standard dell’Europa > >> > centrale, > >> > Eli> > >> > > >> > Zaretskii ha scritto: > >> >> Ping! Juri and Vincenzo, please chime in. > >> >> > >> >> > Cc: 76704@debbugs.gnu.org > >> >> > Date: Sun, 09 Mar 2025 12:00:16 +0200 > >> >> > From: Eli Zaretskii > >> >> > > >> >> > > Date: Sun, 02 Mar 2025 20:44:39 +0100 > >> >> > > From: Fabian Brosda via "Bug reports for GNU Emacs, > >> >> > > > >> >> > > the Swiss army knife of text editors" > >> >> > > > >> >> > > Hi, > >> >> > > > >> >> > > when using js-ts-mode instead of js-mode, braces, which are put on > >> >> > > a > >> >> > > separate line are indented one level too much. Here is a simple > >> >> > > example > >> >> > > of how the indentation looks like, after using indent-region on > >> >> > > the > >> >> > > whole function: > >> >> > > > >> >> > > ``` > >> >> > > function test(x) > >> >> > > > >> >> > > { > >> >> > > > >> >> > > if(x) > >> >> > > > >> >> > > { > >> >> > > > >> >> > > return a; > >> >> > > > >> >> > > } > >> >> > > > >> >> > > else > >> >> > > > >> >> > > { > >> >> > > > >> >> > > return b; > >> >> > > > >> >> > > } > >> >> > > > >> >> > > } > >> >> > > > >> >> > > ``` > >> >> > > > >> >> > > The used tree-sitter grammar is downloaded from > >> >> > > https://github.com/tree-sitter/tree-sitter-javascript. > >> >> > > > >> >> > > Having braces on a separate line is probably not the most common > >> >> > > for > >> >> > > javascript, but using indent-region in the js-mode, does yield the > >> >> > > expected result. The js.el file does already contain a comment > >> >> > > mentioning braces in js--treesit-indent-rules. But even based on > >> >> > > the > >> >> > > git history it is not clear to me, what exactly is meant: > >> >> > > > >> >> > > ``` > >> >> > > > >> >> > > ;; "{" on the newline. > >> >> > > ((node-is "statement_block") parent-bol js-indent-level) > >> >> > > > >> >> > > ``` > >> >> > > > >> >> > > Link: > >> >> > > https://github.com/emacs-mirror/emacs/blob/master/lisp/progmodes/j > >> >> > > s.e > >> >> > > l# > >> >> > > L3457 > >> >> > > > >> >> > > If I replace 'js-indent-level' with '0' in this line, the > >> >> > > indentation > >> >> > > would > >> >> > > be correct, but this might have unwanted side-effects I > >> >> > > overlooked. > >> >> > > > >> >> > > My current emacs version: > >> >> > > > >> >> > > GNU Emacs 30.1 (build 2, x86_64-pc-linux-gnu, GTK+ Version > >> >> > > 3.24.48, > >> >> > > cairo version 1.18.2) > >> >> > > > >> >> > > Thanks for looking into this. > >> >> > > >> >> > Juri and Vincenzo, any comments? > >> > > >> > From 56f0bfe99b0c4cda1e36686e48c58d0d017bda21 Mon Sep 17 00:00:00 2001 > >> > From: Vincenzo Pupillo > >> > Date: Sat, 22 Mar 2025 23:43:52 +0100 > >> > Subject: [PATCH] Fix indentation of "{" when on a new line of a > >> > function > >> > > >> > declaration. > >> > > >> > * lisp/progmodes/js.el > >> > (js--treesit-indent-rules): New rule for the indentation of "{" when > >> > of a new line of a function declaration. (bug#76704) > >> > --- > >> > > >> > lisp/progmodes/js.el | 5 ++++- > >> > 1 file changed, 4 insertions(+), 1 deletion(-) > >> > > >> > diff --git a/lisp/progmodes/js.el b/lisp/progmodes/js.el > >> > index 3e789218fde..6943ffc2d28 100644 > >> > --- a/lisp/progmodes/js.el > >> > +++ b/lisp/progmodes/js.el > >> > @@ -3464,7 +3464,10 @@ js--treesit-indent-rules > >> > > >> > ((parent-is "ternary_expression") parent-bol js-indent-level) > >> > ((parent-is "member_expression") parent-bol js-indent-level) > >> > ((node-is ,switch-case) parent-bol 0) > >> > > >> > - ;; "{" on the newline. > >> > + ;; "{" on the newline for functions. > >> > + ((query "(function_declaration body: (statement_block \"{\") > >> > @indent)") + parent-bol 0) > >> > + ;; "{" on the newline in other cases. > >> > > >> > ((node-is "statement_block") parent-bol js-indent-level) > >> > ((parent-is "named_imports") parent-bol js-indent-level) > >> > ((parent-is "statement_block") parent-bol js-indent-level)