GNU bug report logs - #75154
31.0.50; java-ts-mode. Issues with Indentation

Previous Next

Package: emacs;

Reported by: Artem <snake05865 <at> gmail.com>

Date: Sat, 28 Dec 2024 04:38:02 UTC

Severity: minor

Found in version 31.0.50

Full log


Message #28 received at 75154 <at> debbugs.gnu.org (full text, mbox):

From: Artem Bliznetsov <snake05865 <at> gmail.com>
To: Yuan Fu <casouri <at> gmail.com>
Cc: 75154 <at> debbugs.gnu.org, Eli Zaretskii <eliz <at> gnu.org>,
 Theodor Thornhill <theo <at> thornhill.no>, Stefan Kangas <stefankangas <at> gmail.com>
Subject: Re: bug#75154: 31.0.50; java-ts-mode. Issues with Indentation
Date: Sun, 02 Mar 2025 01:34:05 +0300
> Ok, I attached a patch-set, if you apply this patch-set on top of _latest master_, most of the fixable problems in this report should be fixed/improved. Now, let me reply each item:

Thank you for your patch. I have tested your changes.
During compilation, I encountered the following warning:

In java-ts-mode--first-line-on-multi-line-string:
java-ts-mode.el:105:68: Warning: Unused lexical argument ‘bol’

However, everything seems to be working fine. 

> 1. In the patch I added java-ts-mode-method-chaining-indent-offset,
>    defaults to 8

Thank you! That’s great. Most users accustomed to 8-space indentation
will find the default setting comfortable. Those who prefer
4 spaces are also taken into account.

> 2. Set electric-indent-chars to nil so it doesn’t indent the current
>    line when you press RET.

Actually, setting electric-indent-chars to nil disables all automatic
indentation. Now, I’m reconsidering whether the initial example I
provided was perhaps misguided and beyond what should be expected.

2) Inner Classes
Example 1:
public class Outer {
class Inner {| <-- cursor here moves Inner class unexpectedly

    }
}
Example 2:
public class Outer {
    class Inner { // ???
        | <-- cursor here.           
    }
}

Again, I compared this behavior with IntelliJ IDEA and
wondered why it shouldn't work the same way here. Essentially,
what are we violating if we write

public class Outer {
class Inner {}
}

There are no syntax errors, but class Inner is not indented.
Yes, the indentation appears when pressing RET after {, but if we
then remove the spaces before class Inner and press RET again
after {, electric-indent corrects the indentation.

On one hand, this seems reasonable. On the other hand, shouldn’t this
be handled by an external formatter? This is a minor issue and may
not require any changes.

> 3. The indentation is fixed once you type a valid statement, this is
>    because tree-sitter needs something to generate a parse-tree. We
>    can add some heuristics that gives a more intuitive indentation
>    when the line is empty, eg, "if prev line is while and current line
>    is empty, indent one level", etc. But that’s a more complicated
>    feature and I’ll defer to Theo.

>
> 4.
> - Triple quote support in electric-pair-mode -> let’s open a separate
>   bug report for it and have electric-pair-mode maintainer take a
>   look.

Should I classify this as a bug report? I didn’t notice any feature
request category in the bug tracker. This is a small improvement that
would add some convenience. Triple-quoted text blocks are not
exclusive to Java; many other languages use them as well.

> - In general, TAB in Emacs prog modes indent to a fixed point, rather
>   than just inserting a tab.

I wasn’t aware of how this works. I briefly tested python-ts-mode and
noticed that TAB behaves more freely there.

>I added a indent rule such that aligns a
>   line in a string block to the previous line, for the first line, it indents one level.
>

> 6. For the parameter indentation, I recently added
>    c-ts-common-baseline-indent-rules that can handle it correctly. So
>    if we remove the existing indent rule for the parameters and add
>    c-ts-common-baseline-indent-rules at the end so the indentation
>    falls back to it, the indentation would look like this:
>
> public class TextBlocks {
>     public record StudentRecord(String firstName,
>                                 String lastName,
>                                 Long studentId,
>                                 String email) {
>
>     }
>
>
>     public String filterData(@RequestParam(required = false) String name,
>                              @RequestParam(required = false) String name,
>                              @RequestParam(required = false) Integer age
>     )
> }
>
> Seems fair? Theo, WDYT?

I tested it, and it works. But do you see how it behaves?
I’m not sure how to describe it correctly, but it feels a bit odd.
If issue #3 gets resolved, everything should look much better.

>> - Annotations (@Annotations)
> It seems to work fine? What’s the problem that you see?

That was my mistake. I didn’t check which face was being used—or
whether there was one at all. By default, java-mode uses
c-annotation-face,while java-ts-mode uses font-lock-constant-face.
One inherits from the other. I use the Modus theme, so something may
have changed there.I only noticed it because, without any additional
configuration, java-mode highlighted annotations by default.

Anyway, it’s not that important now.

>> - Diamond Brackets (<>)
> Same as above, what’s the desired behavior?

I just tested it with emacs -q and didn’t see any specific face for <>
in java-mode. I use the popular package rainbow-delimiters.el,
which does highlight <> in java-mode, but it hasn’t been updated in
a while and doesn’t work with java-ts-mode.Currently, java-ts-mode
applies font-lock-operator-face to <>, =, ->, &&, and possibly other
symbols.That doesn’t seem quite right—should all operators really be
highlighted this way? Some users might prefer extensive syntax
highlighting, but it feels excessive to me.

For reference, IntelliJ IDEA also doesn’t highlight <> by default.
It requires a third-party plugin for that. So I’m not sure whether
this should be added or not. If it is, that would be a nice improvement.

>> - Constants, Static Variables, Enum Variables should be highlighted with
>> distinct colors and optionally italic font
>
> For constants, they aren’t highlighted in constant face because rules
> for ‘definition’ and ‘expression’ feature overrides them with
> variable-name face. We can fix this by either moving the ‘constant’
> face after ‘definition’ and ‘expression’ feature, or remove the
> :override flag for ‘definition’ and ‘expression’ feature. Theo, any
> suggestions here?

That would be great to implement! I’m not sure how to show you exactly
how it "should" look. Is it possible to attach images here?
Although, Theo might have IntelliJ IDEA CE installed, so he likely
already knows how it can look visually appealing.

>> - Unused Variables or Classes (Grayed Out)
>> - Unused variables, unused classes, etc., highlighted in gray. Not
>     sure if this can be achieved
>
> Tree-sitter can’t do this. So the only option is to use eglot for it.

Thanks for the clarification! I’ll try to look into this.

----
By the way, I discovered something else today. In
java-ts-mode--keywords, the following keywords are missing:
boolean, byte, char, const, double, float,
goto, int, long, short, super, this, void, permits, var, when, yield, _.
According to the Java Language Specification
https://docs.oracle.com/javase/specs/jls/se23/html/jls-3.html#jls-3.9,
the keyword @interface should be removed since annotations are already
handled separately, and interface is already in the list.

> Finally, some suggestions on communication. As you said on reddit,
> you’re not a native English speaker, so I can’t blame you, but some
> minor changes to wording can make your message sound a lot kinder :)
> For example, short and imperative sentences like "you understand?"
> sounds harsh and condescending; OTOH something like "I hope you can
> understand/get that..." is a lot better. As a rule of thumb, the less
> certain and the longer your expression is, the softer it sounds ;-)
>
> Yuan

Yes, it is true that English is not my native language. However, upon
reviewing my messages,I understand that in certain instances, I was not
sufficiently polite. I will make an effort to improve this.
I regret that this occurred.




This bug report was last modified 60 days ago.

Previous Next


GNU bug tracking system
Copyright (C) 1999 Darren O. Benham, 1997,2003 nCipher Corporation Ltd, 1994-97 Ian Jackson.