GNU bug report logs -
#59251
29.0.50; Fix-some-inconsistencies-in-ts-modes
Previous Next
Reported by: Theodor Thornhill <theo <at> thornhill.no>
Date: Sun, 13 Nov 2022 20:43:01 UTC
Severity: normal
Tags: patch
Found in version 29.0.50
Done: Stefan Kangas <stefankangas <at> gmail.com>
Bug is archived. No further changes may be made.
To add a comment to this bug, you must first unarchive it, by sending
a message to control AT debbugs.gnu.org, with unarchive 59251 in the body.
You can then email your comments to 59251 AT debbugs.gnu.org in the normal way.
Toggle the display of automated, internal messages from the tracker.
Report forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#59251
; Package
emacs
.
(Sun, 13 Nov 2022 20:43:01 GMT)
Full text and
rfc822 format available.
Acknowledgement sent
to
Theodor Thornhill <theo <at> thornhill.no>
:
New bug report received and forwarded. Copy sent to
bug-gnu-emacs <at> gnu.org
.
(Sun, 13 Nov 2022 20:43:01 GMT)
Full text and
rfc822 format available.
Message #5 received at submit <at> debbugs.gnu.org (full text, mbox):
[Message part 1 (text/plain, inline)]
Hi Yuan!
I've make some changes to my *-ts-modes, and would appreciate a second
opinion as well as a push to the feature/tree-sitter branch :-)
I've extracted some of the relevant mode-init variables into defcustoms
so that users can tweak their behavior. It also seems I forgot some
electric indent configs in some of the other files, so I added that
aswell.
BTW, should we do the same thing we did with js-mode - add a js-ts-mode
and don't change the js.el file at all? We could either go the same
route as c-ts-mode, where we define both c and c++ in the same file, or
keep them separate. What do you think?
Theo
[0001-Fix-some-inconsistencies-in-ts-modes.patch (text/x-diff, attachment)]
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#59251
; Package
emacs
.
(Sun, 13 Nov 2022 22:17:01 GMT)
Full text and
rfc822 format available.
Message #8 received at 59251 <at> debbugs.gnu.org (full text, mbox):
[Message part 1 (text/plain, inline)]
Added a few more finishes.
Theo
[0001-Fix-some-inconsistencies-in-ts-modes.patch (text/x-diff, attachment)]
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#59251
; Package
emacs
.
(Sun, 13 Nov 2022 23:03:02 GMT)
Full text and
rfc822 format available.
Message #11 received at 59251 <at> debbugs.gnu.org (full text, mbox):
[Message part 1 (text/plain, inline)]
Theodor Thornhill <theo <at> thornhill.no> writes:
> Added a few more finishes.
Aaand another. Last one for now. I promise...
Theo
[0001-Fix-some-inconsistencies-in-ts-modes.patch (text/x-diff, attachment)]
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#59251
; Package
emacs
.
(Mon, 14 Nov 2022 00:53:02 GMT)
Full text and
rfc822 format available.
Message #14 received at 59251 <at> debbugs.gnu.org (full text, mbox):
> On Nov 13, 2022, at 3:01 PM, Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors <bug-gnu-emacs <at> gnu.org> wrote:
>
> Theodor Thornhill <theo <at> thornhill.no> writes:
>
>> Added a few more finishes.
>
> Aaand another. Last one for now. I promise…
Cool! Some comments:
+(defcustom c-ts-mode-font-lock-feature-list
+ '((comment preprocessor operator constant string literal keyword)
+ (type definition expression statement)
+ ())
+ "Language constructs to font-lock.
+
+See `treesit-font-lock-feature-list' for description of how to
+use this variable. Supported features are as defined in
+`c-ts-mode--font-lock-settings'."
+ :version "29.1"
+ :type 'list
+ :safe 'listp
+ :group 'c)
+
I think Stefan M’s opinion is to make feature-list private, and let users add/remove features. Right now they can add/remove features with treesit-recompute-feature-list. I guess we can keep them as defvar’s for now, so people as the option to redefine this list should they want to. (One argument against having them as custom options is that, if a user sets it as a custom option, they will miss out on future changes to this variable.)
+ (setq-local comment-style c-ts-mode-comment-style)
Why don’t we let users set comment style themselves? Does cc-mode have a similar variable?
Yuan
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#59251
; Package
emacs
.
(Mon, 14 Nov 2022 07:07:02 GMT)
Full text and
rfc822 format available.
Message #17 received at 59251 <at> debbugs.gnu.org (full text, mbox):
[Message part 1 (text/plain, inline)]
Yuan Fu <casouri <at> gmail.com> writes:
>> On Nov 13, 2022, at 3:01 PM, Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors <bug-gnu-emacs <at> gnu.org> wrote:
>>
>> Theodor Thornhill <theo <at> thornhill.no> writes:
>>
>>> Added a few more finishes.
>>
>> Aaand another. Last one for now. I promise…
>
> Cool! Some comments:
>
> +(defcustom c-ts-mode-font-lock-feature-list
> + '((comment preprocessor operator constant string literal keyword)
> + (type definition expression statement)
> + ())
> + "Language constructs to font-lock.
> +
> +See `treesit-font-lock-feature-list' for description of how to
> +use this variable. Supported features are as defined in
> +`c-ts-mode--font-lock-settings'."
> + :version "29.1"
> + :type 'list
> + :safe 'listp
> + :group 'c)
> +
>
> I think Stefan M’s opinion is to make feature-list private, and let
> users add/remove features. Right now they can add/remove features with
> treesit-recompute-feature-list. I guess we can keep them as defvar’s
> for now, so people as the option to redefine this list should they
> want to. (One argument against having them as custom options is that,
> if a user sets it as a custom option, they will miss out on future
> changes to this variable.)
>
>
> + (setq-local comment-style c-ts-mode-comment-style)
>
> Why don’t we let users set comment style themselves? Does cc-mode have a similar variable?
>
You have a point. Simplified the patch.
Theo
[0001-Fix-some-inconsistencies-in-ts-modes.patch (text/x-diff, attachment)]
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#59251
; Package
emacs
.
(Mon, 14 Nov 2022 09:26:01 GMT)
Full text and
rfc822 format available.
Message #20 received at 59251 <at> debbugs.gnu.org (full text, mbox):
> On Nov 13, 2022, at 11:06 PM, Theodor Thornhill <theo <at> thornhill.no> wrote:
>
> Yuan Fu <casouri <at> gmail.com> writes:
>
>>> On Nov 13, 2022, at 3:01 PM, Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors <bug-gnu-emacs <at> gnu.org> wrote:
>>>
>>> Theodor Thornhill <theo <at> thornhill.no> writes:
>>>
>>>> Added a few more finishes.
>>>
>>> Aaand another. Last one for now. I promise…
>>
>> Cool! Some comments:
>>
>> +(defcustom c-ts-mode-font-lock-feature-list
>> + '((comment preprocessor operator constant string literal keyword)
>> + (type definition expression statement)
>> + ())
>> + "Language constructs to font-lock.
>> +
>> +See `treesit-font-lock-feature-list' for description of how to
>> +use this variable. Supported features are as defined in
>> +`c-ts-mode--font-lock-settings'."
>> + :version "29.1"
>> + :type 'list
>> + :safe 'listp
>> + :group 'c)
>> +
>>
>> I think Stefan M’s opinion is to make feature-list private, and let
>> users add/remove features. Right now they can add/remove features with
>> treesit-recompute-feature-list. I guess we can keep them as defvar’s
>> for now, so people as the option to redefine this list should they
>> want to. (One argument against having them as custom options is that,
>> if a user sets it as a custom option, they will miss out on future
>> changes to this variable.)
>>
>>
>> + (setq-local comment-style c-ts-mode-comment-style)
>>
>> Why don’t we let users set comment style themselves? Does cc-mode have a similar variable?
>>
>
> You have a point. Simplified the patch.
>
> Theo
>
> <0001-Fix-some-inconsistencies-in-ts-modes.patch>
Thanks, merged and pushed.
Yuan
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#59251
; Package
emacs
.
(Mon, 14 Nov 2022 19:00:02 GMT)
Full text and
rfc822 format available.
Message #23 received at 59251 <at> debbugs.gnu.org (full text, mbox):
> Cc: casouri <at> gmail.com
> Date: Sun, 13 Nov 2022 21:42:19 +0100
> From: Theodor Thornhill via "Bug reports for GNU Emacs,
> the Swiss army knife of text editors" <bug-gnu-emacs <at> gnu.org>
>
> BTW, should we do the same thing we did with js-mode - add a js-ts-mode
> and don't change the js.el file at all? We could either go the same
> route as c-ts-mode, where we define both c and c++ in the same file, or
> keep them separate. What do you think?
From my POV, it is best not to introduce new modes if that is
possible. That way, we minimize confusion and allow users to adapt
more easily. Only where the new mode is radically different from the
old one and cannot be easily be an optional addition to the old one,
is a completely new mode justified.
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#59251
; Package
emacs
.
(Mon, 14 Nov 2022 19:03:01 GMT)
Full text and
rfc822 format available.
Message #26 received at 59251 <at> debbugs.gnu.org (full text, mbox):
> Cc: 59251 <at> debbugs.gnu.org
> From: Yuan Fu <casouri <at> gmail.com>
> Date: Sun, 13 Nov 2022 16:51:52 -0800
>
> + (setq-local comment-style c-ts-mode-comment-style)
>
> Why don’t we let users set comment style themselves? Does cc-mode have a similar variable?
It's a minor mode there, see "C-c C-k" (c-toggle-comment-style).
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#59251
; Package
emacs
.
(Mon, 14 Nov 2022 19:13:01 GMT)
Full text and
rfc822 format available.
Message #29 received at 59251 <at> debbugs.gnu.org (full text, mbox):
Eli Zaretskii <eliz <at> gnu.org> writes:
>> Cc: casouri <at> gmail.com
>> Date: Sun, 13 Nov 2022 21:42:19 +0100
>> From: Theodor Thornhill via "Bug reports for GNU Emacs,
>> the Swiss army knife of text editors" <bug-gnu-emacs <at> gnu.org>
>>
>> BTW, should we do the same thing we did with js-mode - add a js-ts-mode
>> and don't change the js.el file at all? We could either go the same
>> route as c-ts-mode, where we define both c and c++ in the same file, or
>> keep them separate. What do you think?
>
> From my POV, it is best not to introduce new modes if that is
> possible. That way, we minimize confusion and allow users to adapt
> more easily. Only where the new mode is radically different from the
> old one and cannot be easily be an optional addition to the old one,
> is a completely new mode justified.
Then I think we should do something like one of the first suggestions I
made weeks ago - separate the inits so that as little as possible is
shared between them. If we do that, then it would at least make sense
to merge css and javascript.
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#59251
; Package
emacs
.
(Tue, 15 Nov 2022 12:23:02 GMT)
Full text and
rfc822 format available.
Message #32 received at 59251 <at> debbugs.gnu.org (full text, mbox):
> Cc: 59251 <at> debbugs.gnu.org
> Date: Mon, 14 Nov 2022 08:06:31 +0100
> From: Theodor Thornhill via "Bug reports for GNU Emacs,
> the Swiss army knife of text editors" <bug-gnu-emacs <at> gnu.org>
>
> > + (setq-local comment-style c-ts-mode-comment-style)
> >
> > Why don’t we let users set comment style themselves? Does cc-mode have a similar variable?
> >
>
> You have a point. Simplified the patch.
This still makes it a fixed value that cannot be easily customized?
Or did I miss something?
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#59251
; Package
emacs
.
(Tue, 15 Nov 2022 14:23:02 GMT)
Full text and
rfc822 format available.
Message #35 received at 59251 <at> debbugs.gnu.org (full text, mbox):
On 15 November 2022 13:22:38 CET, Eli Zaretskii <eliz <at> gnu.org> wrote:
>> Cc: 59251 <at> debbugs.gnu.org
>> Date: Mon, 14 Nov 2022 08:06:31 +0100
>> From: Theodor Thornhill via "Bug reports for GNU Emacs,
>> the Swiss army knife of text editors" <bug-gnu-emacs <at> gnu.org>
>>
>> > + (setq-local comment-style c-ts-mode-comment-style)
>> >
>> > Why don’t we let users set comment style themselves? Does cc-mode have a similar variable?
>> >
>>
>> You have a point. Simplified the patch.
>
>This still makes it a fixed value that cannot be easily customized?
>Or did I miss something?
You could set it through the defcustom that was included
Added tag(s) patch.
Request was from
Stefan Kangas <stefankangas <at> gmail.com>
to
control <at> debbugs.gnu.org
.
(Thu, 24 Nov 2022 18:38:02 GMT)
Full text and
rfc822 format available.
Reply sent
to
Stefan Kangas <stefankangas <at> gmail.com>
:
You have taken responsibility.
(Sun, 23 Feb 2025 01:33:02 GMT)
Full text and
rfc822 format available.
Notification sent
to
Theodor Thornhill <theo <at> thornhill.no>
:
bug acknowledged by developer.
(Sun, 23 Feb 2025 01:33:02 GMT)
Full text and
rfc822 format available.
Message #42 received at 59251-done <at> debbugs.gnu.org (full text, mbox):
Yuan Fu <casouri <at> gmail.com> writes:
> Thanks, merged and pushed.
It seems like this was never closed. I'm therefore closing this bug
report.
Information forwarded
to
bug-gnu-emacs <at> gnu.org
:
bug#59251
; Package
emacs
.
(Sun, 23 Feb 2025 05:17:02 GMT)
Full text and
rfc822 format available.
Message #45 received at 59251-done <at> debbugs.gnu.org (full text, mbox):
> On Feb 22, 2025, at 5:32 PM, Stefan Kangas <stefankangas <at> gmail.com> wrote:
>
> Yuan Fu <casouri <at> gmail.com> writes:
>
>> Thanks, merged and pushed.
>
> It seems like this was never closed. I'm therefore closing this bug
> report.
Thanks Stefan
bug archived.
Request was from
Debbugs Internal Request <help-debbugs <at> gnu.org>
to
internal_control <at> debbugs.gnu.org
.
(Sun, 23 Mar 2025 11:24:42 GMT)
Full text and
rfc822 format available.
This bug report was last modified 86 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.