* bug#59763: 29.0.60; Filling for c-ts-mode
@ 2022-12-02 5:33 Yuan Fu
2022-12-02 14:58 ` Eli Zaretskii
` (4 more replies)
0 siblings, 5 replies; 13+ messages in thread
From: Yuan Fu @ 2022-12-02 5:33 UTC (permalink / raw)
To: 59763
IMO For c-ts-mode to be usable we need to have at least a basic filling
function. Below is the function I have in my init.el, could someone have
a look and see if it’s good? Alternatively we could copy out the comment
and fill it in a temp buffer with c-mode, but I didn’t have the time to try
it out and see how well it works.
(defun ts-c-fill-paragraph (&optional arg)
(interactive)
(let* ((node (treesit-node-at (point)))
(start (treesit-node-start node))
(end (treesit-node-end node))
(pstart (save-excursion
(forward-paragraph -1)
(skip-syntax-forward "-")
(point)))
(pend (save-excursion
(forward-paragraph 1)
(point))))
(when (equal (treesit-node-type node) "comment")
(fill-region (max start pstart) (min end pend)))
t))
Yuan
^ permalink raw reply [flat|nested] 13+ messages in thread
* bug#59763: 29.0.60; Filling for c-ts-mode
2022-12-02 5:33 bug#59763: 29.0.60; Filling for c-ts-mode Yuan Fu
@ 2022-12-02 14:58 ` Eli Zaretskii
2022-12-03 0:54 ` Yuan Fu
2022-12-24 8:36 ` Yuan Fu
` (3 subsequent siblings)
4 siblings, 1 reply; 13+ messages in thread
From: Eli Zaretskii @ 2022-12-02 14:58 UTC (permalink / raw)
To: Yuan Fu; +Cc: 59763
> From: Yuan Fu <casouri@gmail.com>
> Date: Thu, 1 Dec 2022 21:33:06 -0800
>
>
> IMO For c-ts-mode to be usable we need to have at least a basic filling
> function. Below is the function I have in my init.el, could someone have
> a look and see if it’s good? Alternatively we could copy out the comment
> and fill it in a temp buffer with c-mode, but I didn’t have the time to try
> it out and see how well it works.
Thanks.
From quick testing, I see a problem:
. Visit dispnew.c and go to the comment that starts on line 324. Delete
the newline between the two lines of the comment, and invoke the
function. Observe how the first non-blank character of the comment's
second line is aligned with the "/*" on the previous line, not with the
text after "/*" as I'd expect.
Btw, this command should be bound to M-q in ts-c-mode.
^ permalink raw reply [flat|nested] 13+ messages in thread
* bug#59763: 29.0.60; Filling for c-ts-mode
2022-12-02 14:58 ` Eli Zaretskii
@ 2022-12-03 0:54 ` Yuan Fu
2022-12-05 11:47 ` Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors
0 siblings, 1 reply; 13+ messages in thread
From: Yuan Fu @ 2022-12-03 0:54 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: Theodor Thornhill, 59763
> On Dec 2, 2022, at 6:58 AM, Eli Zaretskii <eliz@gnu.org> wrote:
>
>> From: Yuan Fu <casouri@gmail.com>
>> Date: Thu, 1 Dec 2022 21:33:06 -0800
>>
>>
>> IMO For c-ts-mode to be usable we need to have at least a basic filling
>> function. Below is the function I have in my init.el, could someone have
>> a look and see if it’s good? Alternatively we could copy out the comment
>> and fill it in a temp buffer with c-mode, but I didn’t have the time to try
>> it out and see how well it works.
>
> Thanks.
>
> From quick testing, I see a problem:
>
> . Visit dispnew.c and go to the comment that starts on line 324. Delete
> the newline between the two lines of the comment, and invoke the
> function. Observe how the first non-blank character of the comment's
> second line is aligned with the "/*" on the previous line, not with the
> text after "/*" as I'd expect.
I see. I’ll need to look at how cc-mode fill comments.
>
> Btw, this command should be bound to M-q in ts-c-mode.
Will do, once our fill function works well. BTW, Theo, if you have any idea, don’t hesitate to go ahead :-) No obligations, of course.
Yuan
^ permalink raw reply [flat|nested] 13+ messages in thread
* bug#59763: 29.0.60; Filling for c-ts-mode
2022-12-03 0:54 ` Yuan Fu
@ 2022-12-05 11:47 ` Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors
0 siblings, 0 replies; 13+ messages in thread
From: Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2022-12-05 11:47 UTC (permalink / raw)
To: Yuan Fu, Eli Zaretskii; +Cc: 59763
Yuan Fu <casouri@gmail.com> writes:
>> On Dec 2, 2022, at 6:58 AM, Eli Zaretskii <eliz@gnu.org> wrote:
>>
>>> From: Yuan Fu <casouri@gmail.com>
>>> Date: Thu, 1 Dec 2022 21:33:06 -0800
>>>
>>>
>>> IMO For c-ts-mode to be usable we need to have at least a basic filling
>>> function. Below is the function I have in my init.el, could someone have
>>> a look and see if it’s good? Alternatively we could copy out the comment
>>> and fill it in a temp buffer with c-mode, but I didn’t have the time to try
>>> it out and see how well it works.
>>
>> Thanks.
>>
>> From quick testing, I see a problem:
>>
>> . Visit dispnew.c and go to the comment that starts on line 324. Delete
>> the newline between the two lines of the comment, and invoke the
>> function. Observe how the first non-blank character of the comment's
>> second line is aligned with the "/*" on the previous line, not with the
>> text after "/*" as I'd expect.
>
> I see. I’ll need to look at how cc-mode fill comments.
>
>>
>> Btw, this command should be bound to M-q in ts-c-mode.
>
> Will do, once our fill function works well. BTW, Theo, if you have any
> idea, don’t hesitate to go ahead :-) No obligations, of course.
>
> Yuan
Sure! Added to my list :) I had a function at some point that used
c-mode to do this. I'll see if I can polish it a little.
Theo
^ permalink raw reply [flat|nested] 13+ messages in thread
* bug#59763: 29.0.60; Filling for c-ts-mode
2022-12-02 5:33 bug#59763: 29.0.60; Filling for c-ts-mode Yuan Fu
2022-12-02 14:58 ` Eli Zaretskii
@ 2022-12-24 8:36 ` Yuan Fu
2022-12-24 8:42 ` Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors
2022-12-25 1:30 ` Yuan Fu
` (2 subsequent siblings)
4 siblings, 1 reply; 13+ messages in thread
From: Yuan Fu @ 2022-12-24 8:36 UTC (permalink / raw)
To: Theodor Thornhill; +Cc: Eli Zaretskii, 59763
Theodor Thornhill <theo@thornhill.no> writes:
> Yuan Fu <casouri@gmail.com> writes:
>
>>> On Dec 2, 2022, at 6:58 AM, Eli Zaretskii <eliz@gnu.org> wrote:
>>>
>>>> From: Yuan Fu <casouri@gmail.com>
>>>> Date: Thu, 1 Dec 2022 21:33:06 -0800
>>>>
>>>>
>>>> IMO For c-ts-mode to be usable we need to have at least a basic filling
>>>> function. Below is the function I have in my init.el, could someone have
>>>> a look and see if it’s good? Alternatively we could copy out the comment
>>>> and fill it in a temp buffer with c-mode, but I didn’t have the time to try
>>>> it out and see how well it works.
>>>
>>> Thanks.
>>>
>>> From quick testing, I see a problem:
>>>
>>> . Visit dispnew.c and go to the comment that starts on line 324. Delete
>>> the newline between the two lines of the comment, and invoke the
>>> function. Observe how the first non-blank character of the comment's
>>> second line is aligned with the "/*" on the previous line, not with the
>>> text after "/*" as I'd expect.
>>
>> I see. I’ll need to look at how cc-mode fill comments.
>>
>>>
>>> Btw, this command should be bound to M-q in ts-c-mode.
>>
>> Will do, once our fill function works well. BTW, Theo, if you have any
>> idea, don’t hesitate to go ahead :-) No obligations, of course.
>>
>> Yuan
>
> Sure! Added to my list :) I had a function at some point that used
> c-mode to do this. I'll see if I can polish it a little.
I did some work in filling, it should work like cc-mode in like 90% of
the cases now, yay!
Yuan
^ permalink raw reply [flat|nested] 13+ messages in thread
* bug#59763: 29.0.60; Filling for c-ts-mode
2022-12-24 8:36 ` Yuan Fu
@ 2022-12-24 8:42 ` Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors
0 siblings, 0 replies; 13+ messages in thread
From: Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2022-12-24 8:42 UTC (permalink / raw)
To: Yuan Fu; +Cc: Eli Zaretskii, 59763
On 24 December 2022 09:36:21 CET, Yuan Fu <casouri@gmail.com> wrote:
>
>Theodor Thornhill <theo@thornhill.no> writes:
>
>> Yuan Fu <casouri@gmail.com> writes:
>>
>>>> On Dec 2, 2022, at 6:58 AM, Eli Zaretskii <eliz@gnu.org> wrote:
>>>>
>>>>> From: Yuan Fu <casouri@gmail.com>
>>>>> Date: Thu, 1 Dec 2022 21:33:06 -0800
>>>>>
>>>>>
>>>>> IMO For c-ts-mode to be usable we need to have at least a basic filling
>>>>> function. Below is the function I have in my init.el, could someone have
>>>>> a look and see if it’s good? Alternatively we could copy out the comment
>>>>> and fill it in a temp buffer with c-mode, but I didn’t have the time to try
>>>>> it out and see how well it works.
>>>>
>>>> Thanks.
>>>>
>>>> From quick testing, I see a problem:
>>>>
>>>> . Visit dispnew.c and go to the comment that starts on line 324. Delete
>>>> the newline between the two lines of the comment, and invoke the
>>>> function. Observe how the first non-blank character of the comment's
>>>> second line is aligned with the "/*" on the previous line, not with the
>>>> text after "/*" as I'd expect.
>>>
>>> I see. I’ll need to look at how cc-mode fill comments.
>>>
>>>>
>>>> Btw, this command should be bound to M-q in ts-c-mode.
>>>
>>> Will do, once our fill function works well. BTW, Theo, if you have any
>>> idea, don’t hesitate to go ahead :-) No obligations, of course.
>>>
>>> Yuan
>>
>> Sure! Added to my list :) I had a function at some point that used
>> c-mode to do this. I'll see if I can polish it a little.
>
>I did some work in filling, it should work like cc-mode in like 90% of
>the cases now, yay!
>
>Yuan
Nice! For all cc-ts-modes?
Theo
^ permalink raw reply [flat|nested] 13+ messages in thread
* bug#59763: 29.0.60; Filling for c-ts-mode
2022-12-02 5:33 bug#59763: 29.0.60; Filling for c-ts-mode Yuan Fu
2022-12-02 14:58 ` Eli Zaretskii
2022-12-24 8:36 ` Yuan Fu
@ 2022-12-25 1:30 ` Yuan Fu
2022-12-25 7:33 ` Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors
2022-12-26 21:31 ` Yuan Fu
2023-01-07 23:11 ` Yuan Fu
4 siblings, 1 reply; 13+ messages in thread
From: Yuan Fu @ 2022-12-25 1:30 UTC (permalink / raw)
To: Theodor Thornhill; +Cc: eliz, 59763
Theodor Thornhill <theo@thornhill.no> writes:
> On 24 December 2022 09:36:21 CET, Yuan Fu <casouri@gmail.com> wrote:
>>
>>Theodor Thornhill <theo@thornhill.no> writes:
>>
>>> Yuan Fu <casouri@gmail.com> writes:
>>>
>>>>> On Dec 2, 2022, at 6:58 AM, Eli Zaretskii <eliz@gnu.org> wrote:
>>>>>
>>>>>> From: Yuan Fu <casouri@gmail.com>
>>>>>> Date: Thu, 1 Dec 2022 21:33:06 -0800
>>>>>>
>>>>>>
>>>>>> IMO For c-ts-mode to be usable we need to have at least a basic filling
>>>>>> function. Below is the function I have in my init.el, could someone have
>>>>>> a look and see if it’s good? Alternatively we could copy out the comment
>>>>>> and fill it in a temp buffer with c-mode, but I didn’t have the time to try
>>>>>> it out and see how well it works.
>>>>>
>>>>> Thanks.
>>>>>
>>>>> From quick testing, I see a problem:
>>>>>
>>>>> . Visit dispnew.c and go to the comment that starts on line 324. Delete
>>>>> the newline between the two lines of the comment, and invoke the
>>>>> function. Observe how the first non-blank character of the comment's
>>>>> second line is aligned with the "/*" on the previous line, not with the
>>>>> text after "/*" as I'd expect.
>>>>
>>>> I see. I’ll need to look at how cc-mode fill comments.
>>>>
>>>>>
>>>>> Btw, this command should be bound to M-q in ts-c-mode.
>>>>
>>>> Will do, once our fill function works well. BTW, Theo, if you have any
>>>> idea, don’t hesitate to go ahead :-) No obligations, of course.
>>>>
>>>> Yuan
>>>
>>> Sure! Added to my list :) I had a function at some point that used
>>> c-mode to do this. I'll see if I can polish it a little.
>>
>>I did some work in filling, it should work like cc-mode in like 90% of
>>the cases now, yay!
>>
>>Yuan
>
> Nice! For all cc-ts-modes?
I only added for c and c++, but support for other modes should be
identical. And I think we should have something equivalent to cc-mode’s
init which sets up things that are the same in all C-like languages,
basically comments and filling.
But I wonder where should we put it, I guess it’s fine to leave it in
c-ts-mode, since there really isn’t much code. Having other modes to
require c-ts-mode shouldn’t be a big problem, I think?
Yuan
^ permalink raw reply [flat|nested] 13+ messages in thread
* bug#59763: 29.0.60; Filling for c-ts-mode
2022-12-25 1:30 ` Yuan Fu
@ 2022-12-25 7:33 ` Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors
0 siblings, 0 replies; 13+ messages in thread
From: Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2022-12-25 7:33 UTC (permalink / raw)
To: Yuan Fu; +Cc: eliz, 59763
On 25 December 2022 02:30:35 CET, Yuan Fu <casouri@gmail.com> wrote:
>
>Theodor Thornhill <theo@thornhill.no> writes:
>
>> On 24 December 2022 09:36:21 CET, Yuan Fu <casouri@gmail.com> wrote:
>>>
>>>Theodor Thornhill <theo@thornhill.no> writes:
>>>
>>>> Yuan Fu <casouri@gmail.com> writes:
>>>>
>>>>>> On Dec 2, 2022, at 6:58 AM, Eli Zaretskii <eliz@gnu.org> wrote:
>>>>>>
>>>>>>> From: Yuan Fu <casouri@gmail.com>
>>>>>>> Date: Thu, 1 Dec 2022 21:33:06 -0800
>>>>>>>
>>>>>>>
>>>>>>> IMO For c-ts-mode to be usable we need to have at least a basic filling
>>>>>>> function. Below is the function I have in my init.el, could someone have
>>>>>>> a look and see if it’s good? Alternatively we could copy out the comment
>>>>>>> and fill it in a temp buffer with c-mode, but I didn’t have the time to try
>>>>>>> it out and see how well it works.
>>>>>>
>>>>>> Thanks.
>>>>>>
>>>>>> From quick testing, I see a problem:
>>>>>>
>>>>>> . Visit dispnew.c and go to the comment that starts on line 324. Delete
>>>>>> the newline between the two lines of the comment, and invoke the
>>>>>> function. Observe how the first non-blank character of the comment's
>>>>>> second line is aligned with the "/*" on the previous line, not with the
>>>>>> text after "/*" as I'd expect.
>>>>>
>>>>> I see. I’ll need to look at how cc-mode fill comments.
>>>>>
>>>>>>
>>>>>> Btw, this command should be bound to M-q in ts-c-mode.
>>>>>
>>>>> Will do, once our fill function works well. BTW, Theo, if you have any
>>>>> idea, don’t hesitate to go ahead :-) No obligations, of course.
>>>>>
>>>>> Yuan
>>>>
>>>> Sure! Added to my list :) I had a function at some point that used
>>>> c-mode to do this. I'll see if I can polish it a little.
>>>
>>>I did some work in filling, it should work like cc-mode in like 90% of
>>>the cases now, yay!
>>>
>>>Yuan
>>
>> Nice! For all cc-ts-modes?
>
>I only added for c and c++, but support for other modes should be
>identical. And I think we should have something equivalent to cc-mode’s
>init which sets up things that are the same in all C-like languages,
>basically comments and filling.
>
>But I wonder where should we put it, I guess it’s fine to leave it in
>c-ts-mode, since there really isn’t much code. Having other modes to
>require c-ts-mode shouldn’t be a big problem, I think?
>
>Yuan
How about just having treesit-utils.el, or something like that? There are probably many things in the future that will be common among modes, yet won't really warrant inheritance. I think we have such an example in js/typescript too, iirc.
^ permalink raw reply [flat|nested] 13+ messages in thread
* bug#59763: 29.0.60; Filling for c-ts-mode
2022-12-02 5:33 bug#59763: 29.0.60; Filling for c-ts-mode Yuan Fu
` (2 preceding siblings ...)
2022-12-25 1:30 ` Yuan Fu
@ 2022-12-26 21:31 ` Yuan Fu
2022-12-26 22:03 ` Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors
2023-01-07 23:11 ` Yuan Fu
4 siblings, 1 reply; 13+ messages in thread
From: Yuan Fu @ 2022-12-26 21:31 UTC (permalink / raw)
To: Theodor Thornhill; +Cc: eliz, 59763
Theodor Thornhill <theo@thornhill.no> writes:
> On 25 December 2022 02:30:35 CET, Yuan Fu <casouri@gmail.com> wrote:
>>
>>Theodor Thornhill <theo@thornhill.no> writes:
>>
>>> On 24 December 2022 09:36:21 CET, Yuan Fu <casouri@gmail.com> wrote:
>>>>
>>>>Theodor Thornhill <theo@thornhill.no> writes:
>>>>
>>>>> Yuan Fu <casouri@gmail.com> writes:
>>>>>
>>>>>>> On Dec 2, 2022, at 6:58 AM, Eli Zaretskii <eliz@gnu.org> wrote:
>>>>>>>
>>>>>>>> From: Yuan Fu <casouri@gmail.com>
>>>>>>>> Date: Thu, 1 Dec 2022 21:33:06 -0800
>>>>>>>>
>>>>>>>>
>>>>>>>> IMO For c-ts-mode to be usable we need to have at least a basic filling
>>>>>>>> function. Below is the function I have in my init.el, could someone have
>>>>>>>> a look and see if it’s good? Alternatively we could copy out the comment
>>>>>>>> and fill it in a temp buffer with c-mode, but I didn’t have the time to try
>>>>>>>> it out and see how well it works.
>>>>>>>
>>>>>>> Thanks.
>>>>>>>
>>>>>>> From quick testing, I see a problem:
>>>>>>>
>>>>>>> . Visit dispnew.c and go to the comment that starts on line 324. Delete
>>>>>>> the newline between the two lines of the comment, and invoke the
>>>>>>> function. Observe how the first non-blank character of the comment's
>>>>>>> second line is aligned with the "/*" on the previous line, not with the
>>>>>>> text after "/*" as I'd expect.
>>>>>>
>>>>>> I see. I’ll need to look at how cc-mode fill comments.
>>>>>>
>>>>>>>
>>>>>>> Btw, this command should be bound to M-q in ts-c-mode.
>>>>>>
>>>>>> Will do, once our fill function works well. BTW, Theo, if you have any
>>>>>> idea, don’t hesitate to go ahead :-) No obligations, of course.
>>>>>>
>>>>>> Yuan
>>>>>
>>>>> Sure! Added to my list :) I had a function at some point that used
>>>>> c-mode to do this. I'll see if I can polish it a little.
>>>>
>>>>I did some work in filling, it should work like cc-mode in like 90% of
>>>>the cases now, yay!
>>>>
>>>>Yuan
>>>
>>> Nice! For all cc-ts-modes?
>>
>>I only added for c and c++, but support for other modes should be
>>identical. And I think we should have something equivalent to cc-mode’s
>>init which sets up things that are the same in all C-like languages,
>>basically comments and filling.
I added indent and filling for other C-like modes.
>>But I wonder where should we put it, I guess it’s fine to leave it in
>>c-ts-mode, since there really isn’t much code. Having other modes to
>>require c-ts-mode shouldn’t be a big problem, I think?
>>
>>Yuan
>
> How about just having treesit-utils.el, or something like that? There
> are probably many things in the future that will be common among
> modes, yet won't really warrant inheritance. I think we have such an
> example in js/typescript too, iirc.
If it’s shared across all tree-sitter modes, it should be in treesit.el,
of course. We are talking about things shared by tree-sitter C-like
modes, so the scope is smaller.
Since right now it’s only a handful functions, I made other modes
require c-ts-mode.el. In the future if things accumulate, we can put
things into a separate file (c-ts-mode-common.el or something).
Yuan
^ permalink raw reply [flat|nested] 13+ messages in thread
* bug#59763: 29.0.60; Filling for c-ts-mode
2022-12-26 21:31 ` Yuan Fu
@ 2022-12-26 22:03 ` Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors
2022-12-26 22:51 ` Yuan Fu
0 siblings, 1 reply; 13+ messages in thread
From: Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2022-12-26 22:03 UTC (permalink / raw)
To: Yuan Fu; +Cc: eliz, 59763
Yuan Fu <casouri@gmail.com> writes:
> Theodor Thornhill <theo@thornhill.no> writes:
>
>> On 25 December 2022 02:30:35 CET, Yuan Fu <casouri@gmail.com> wrote:
>>>
>>>Theodor Thornhill <theo@thornhill.no> writes:
>>>
>>>> On 24 December 2022 09:36:21 CET, Yuan Fu <casouri@gmail.com> wrote:
>>>>>
>>>>>Theodor Thornhill <theo@thornhill.no> writes:
>>>>>
>>>>>> Yuan Fu <casouri@gmail.com> writes:
>>>>>>
>>>>>>>> On Dec 2, 2022, at 6:58 AM, Eli Zaretskii <eliz@gnu.org> wrote:
>>>>>>>>
>>>>>>>>> From: Yuan Fu <casouri@gmail.com>
>>>>>>>>> Date: Thu, 1 Dec 2022 21:33:06 -0800
>>>>>>>>>
>>>>>>>>>
>>>>>>>>> IMO For c-ts-mode to be usable we need to have at least a basic filling
>>>>>>>>> function. Below is the function I have in my init.el, could someone have
>>>>>>>>> a look and see if it’s good? Alternatively we could copy out the comment
>>>>>>>>> and fill it in a temp buffer with c-mode, but I didn’t have the time to try
>>>>>>>>> it out and see how well it works.
>>>>>>>>
>>>>>>>> Thanks.
>>>>>>>>
>>>>>>>> From quick testing, I see a problem:
>>>>>>>>
>>>>>>>> . Visit dispnew.c and go to the comment that starts on line 324. Delete
>>>>>>>> the newline between the two lines of the comment, and invoke the
>>>>>>>> function. Observe how the first non-blank character of the comment's
>>>>>>>> second line is aligned with the "/*" on the previous line, not with the
>>>>>>>> text after "/*" as I'd expect.
>>>>>>>
>>>>>>> I see. I’ll need to look at how cc-mode fill comments.
>>>>>>>
>>>>>>>>
>>>>>>>> Btw, this command should be bound to M-q in ts-c-mode.
>>>>>>>
>>>>>>> Will do, once our fill function works well. BTW, Theo, if you have any
>>>>>>> idea, don’t hesitate to go ahead :-) No obligations, of course.
>>>>>>>
>>>>>>> Yuan
>>>>>>
>>>>>> Sure! Added to my list :) I had a function at some point that used
>>>>>> c-mode to do this. I'll see if I can polish it a little.
>>>>>
>>>>>I did some work in filling, it should work like cc-mode in like 90% of
>>>>>the cases now, yay!
>>>>>
>>>>>Yuan
>>>>
>>>> Nice! For all cc-ts-modes?
>>>
>>>I only added for c and c++, but support for other modes should be
>>>identical. And I think we should have something equivalent to cc-mode’s
>>>init which sets up things that are the same in all C-like languages,
>>>basically comments and filling.
>
> I added indent and filling for other C-like modes.
>
>>>But I wonder where should we put it, I guess it’s fine to leave it in
>>>c-ts-mode, since there really isn’t much code. Having other modes to
>>>require c-ts-mode shouldn’t be a big problem, I think?
>>>
>>>Yuan
>>
>> How about just having treesit-utils.el, or something like that? There
>> are probably many things in the future that will be common among
>> modes, yet won't really warrant inheritance. I think we have such an
>> example in js/typescript too, iirc.
>
> If it’s shared across all tree-sitter modes, it should be in treesit.el,
> of course. We are talking about things shared by tree-sitter C-like
> modes, so the scope is smaller.
>
> Since right now it’s only a handful functions, I made other modes
> require c-ts-mode.el. In the future if things accumulate, we can put
> things into a separate file (c-ts-mode-common.el or something).
>
Sure. I just don't like it when these namespaces blend too much. But
your call :-)
Theo
^ permalink raw reply [flat|nested] 13+ messages in thread
* bug#59763: 29.0.60; Filling for c-ts-mode
2022-12-26 22:03 ` Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors
@ 2022-12-26 22:51 ` Yuan Fu
2022-12-26 23:00 ` Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors
0 siblings, 1 reply; 13+ messages in thread
From: Yuan Fu @ 2022-12-26 22:51 UTC (permalink / raw)
To: Theodor Thornhill; +Cc: Eli Zaretskii, 59763
> On Dec 26, 2022, at 2:03 PM, Theodor Thornhill <theo@thornhill.no> wrote:
>
> Yuan Fu <casouri@gmail.com> writes:
>
>> Theodor Thornhill <theo@thornhill.no> writes:
>>
>>> On 25 December 2022 02:30:35 CET, Yuan Fu <casouri@gmail.com> wrote:
>>>>
>>>> Theodor Thornhill <theo@thornhill.no> writes:
>>>>
>>>>> On 24 December 2022 09:36:21 CET, Yuan Fu <casouri@gmail.com> wrote:
>>>>>>
>>>>>> Theodor Thornhill <theo@thornhill.no> writes:
>>>>>>
>>>>>>> Yuan Fu <casouri@gmail.com> writes:
>>>>>>>
>>>>>>>>> On Dec 2, 2022, at 6:58 AM, Eli Zaretskii <eliz@gnu.org> wrote:
>>>>>>>>>
>>>>>>>>>> From: Yuan Fu <casouri@gmail.com>
>>>>>>>>>> Date: Thu, 1 Dec 2022 21:33:06 -0800
>>>>>>>>>>
>>>>>>>>>>
>>>>>>>>>> IMO For c-ts-mode to be usable we need to have at least a basic filling
>>>>>>>>>> function. Below is the function I have in my init.el, could someone have
>>>>>>>>>> a look and see if it’s good? Alternatively we could copy out the comment
>>>>>>>>>> and fill it in a temp buffer with c-mode, but I didn’t have the time to try
>>>>>>>>>> it out and see how well it works.
>>>>>>>>>
>>>>>>>>> Thanks.
>>>>>>>>>
>>>>>>>>> From quick testing, I see a problem:
>>>>>>>>>
>>>>>>>>> . Visit dispnew.c and go to the comment that starts on line 324. Delete
>>>>>>>>> the newline between the two lines of the comment, and invoke the
>>>>>>>>> function. Observe how the first non-blank character of the comment's
>>>>>>>>> second line is aligned with the "/*" on the previous line, not with the
>>>>>>>>> text after "/*" as I'd expect.
>>>>>>>>
>>>>>>>> I see. I’ll need to look at how cc-mode fill comments.
>>>>>>>>
>>>>>>>>>
>>>>>>>>> Btw, this command should be bound to M-q in ts-c-mode.
>>>>>>>>
>>>>>>>> Will do, once our fill function works well. BTW, Theo, if you have any
>>>>>>>> idea, don’t hesitate to go ahead :-) No obligations, of course.
>>>>>>>>
>>>>>>>> Yuan
>>>>>>>
>>>>>>> Sure! Added to my list :) I had a function at some point that used
>>>>>>> c-mode to do this. I'll see if I can polish it a little.
>>>>>>
>>>>>> I did some work in filling, it should work like cc-mode in like 90% of
>>>>>> the cases now, yay!
>>>>>>
>>>>>> Yuan
>>>>>
>>>>> Nice! For all cc-ts-modes?
>>>>
>>>> I only added for c and c++, but support for other modes should be
>>>> identical. And I think we should have something equivalent to cc-mode’s
>>>> init which sets up things that are the same in all C-like languages,
>>>> basically comments and filling.
>>
>> I added indent and filling for other C-like modes.
>>
>>>> But I wonder where should we put it, I guess it’s fine to leave it in
>>>> c-ts-mode, since there really isn’t much code. Having other modes to
>>>> require c-ts-mode shouldn’t be a big problem, I think?
>>>>
>>>> Yuan
>>>
>>> How about just having treesit-utils.el, or something like that? There
>>> are probably many things in the future that will be common among
>>> modes, yet won't really warrant inheritance. I think we have such an
>>> example in js/typescript too, iirc.
>>
>> If it’s shared across all tree-sitter modes, it should be in treesit.el,
>> of course. We are talking about things shared by tree-sitter C-like
>> modes, so the scope is smaller.
>>
>> Since right now it’s only a handful functions, I made other modes
>> require c-ts-mode.el. In the future if things accumulate, we can put
>> things into a separate file (c-ts-mode-common.el or something).
>>
>
> Sure. I just don't like it when these namespaces blend too much. But
> your call :-)
It can be treesit-c-common.el or something. We’ll figure it out when the time comes ;-)
Yuan
^ permalink raw reply [flat|nested] 13+ messages in thread
* bug#59763: 29.0.60; Filling for c-ts-mode
2022-12-26 22:51 ` Yuan Fu
@ 2022-12-26 23:00 ` Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors
0 siblings, 0 replies; 13+ messages in thread
From: Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2022-12-26 23:00 UTC (permalink / raw)
To: Yuan Fu; +Cc: Eli Zaretskii, 59763
Yuan Fu <casouri@gmail.com> writes:
>> On Dec 26, 2022, at 2:03 PM, Theodor Thornhill <theo@thornhill.no> wrote:
>>
>> Yuan Fu <casouri@gmail.com> writes:
>>
>>> Theodor Thornhill <theo@thornhill.no> writes:
>>>
>>>> On 25 December 2022 02:30:35 CET, Yuan Fu <casouri@gmail.com> wrote:
>>>>>
>>>>> Theodor Thornhill <theo@thornhill.no> writes:
>>>>>
>>>>>> On 24 December 2022 09:36:21 CET, Yuan Fu <casouri@gmail.com> wrote:
>>>>>>>
>>>>>>> Theodor Thornhill <theo@thornhill.no> writes:
>>>>>>>
>>>>>>>> Yuan Fu <casouri@gmail.com> writes:
>>>>>>>>
>>>>>>>>>> On Dec 2, 2022, at 6:58 AM, Eli Zaretskii <eliz@gnu.org> wrote:
>>>>>>>>>>
>>>>>>>>>>> From: Yuan Fu <casouri@gmail.com>
>>>>>>>>>>> Date: Thu, 1 Dec 2022 21:33:06 -0800
>>>>>>>>>>>
>>>>>>>>>>>
>>>>>>>>>>> IMO For c-ts-mode to be usable we need to have at least a basic filling
>>>>>>>>>>> function. Below is the function I have in my init.el, could someone have
>>>>>>>>>>> a look and see if it’s good? Alternatively we could copy out the comment
>>>>>>>>>>> and fill it in a temp buffer with c-mode, but I didn’t have the time to try
>>>>>>>>>>> it out and see how well it works.
>>>>>>>>>>
>>>>>>>>>> Thanks.
>>>>>>>>>>
>>>>>>>>>> From quick testing, I see a problem:
>>>>>>>>>>
>>>>>>>>>> . Visit dispnew.c and go to the comment that starts on line 324. Delete
>>>>>>>>>> the newline between the two lines of the comment, and invoke the
>>>>>>>>>> function. Observe how the first non-blank character of the comment's
>>>>>>>>>> second line is aligned with the "/*" on the previous line, not with the
>>>>>>>>>> text after "/*" as I'd expect.
>>>>>>>>>
>>>>>>>>> I see. I’ll need to look at how cc-mode fill comments.
>>>>>>>>>
>>>>>>>>>>
>>>>>>>>>> Btw, this command should be bound to M-q in ts-c-mode.
>>>>>>>>>
>>>>>>>>> Will do, once our fill function works well. BTW, Theo, if you have any
>>>>>>>>> idea, don’t hesitate to go ahead :-) No obligations, of course.
>>>>>>>>>
>>>>>>>>> Yuan
>>>>>>>>
>>>>>>>> Sure! Added to my list :) I had a function at some point that used
>>>>>>>> c-mode to do this. I'll see if I can polish it a little.
>>>>>>>
>>>>>>> I did some work in filling, it should work like cc-mode in like 90% of
>>>>>>> the cases now, yay!
>>>>>>>
>>>>>>> Yuan
>>>>>>
>>>>>> Nice! For all cc-ts-modes?
>>>>>
>>>>> I only added for c and c++, but support for other modes should be
>>>>> identical. And I think we should have something equivalent to cc-mode’s
>>>>> init which sets up things that are the same in all C-like languages,
>>>>> basically comments and filling.
>>>
>>> I added indent and filling for other C-like modes.
>>>
>>>>> But I wonder where should we put it, I guess it’s fine to leave it in
>>>>> c-ts-mode, since there really isn’t much code. Having other modes to
>>>>> require c-ts-mode shouldn’t be a big problem, I think?
>>>>>
>>>>> Yuan
>>>>
>>>> How about just having treesit-utils.el, or something like that? There
>>>> are probably many things in the future that will be common among
>>>> modes, yet won't really warrant inheritance. I think we have such an
>>>> example in js/typescript too, iirc.
>>>
>>> If it’s shared across all tree-sitter modes, it should be in treesit.el,
>>> of course. We are talking about things shared by tree-sitter C-like
>>> modes, so the scope is smaller.
>>>
>>> Since right now it’s only a handful functions, I made other modes
>>> require c-ts-mode.el. In the future if things accumulate, we can put
>>> things into a separate file (c-ts-mode-common.el or something).
>>>
>>
>> Sure. I just don't like it when these namespaces blend too much. But
>> your call :-)
>
> It can be treesit-c-common.el or something. We’ll figure it out when the time comes ;-)
>
Yep :)
Theo
^ permalink raw reply [flat|nested] 13+ messages in thread
* bug#59763: 29.0.60; Filling for c-ts-mode
2022-12-02 5:33 bug#59763: 29.0.60; Filling for c-ts-mode Yuan Fu
` (3 preceding siblings ...)
2022-12-26 21:31 ` Yuan Fu
@ 2023-01-07 23:11 ` Yuan Fu
4 siblings, 0 replies; 13+ messages in thread
From: Yuan Fu @ 2023-01-07 23:11 UTC (permalink / raw)
To: Theodor Thornhill; +Cc: 59763-done
Theodor Thornhill <theo@thornhill.no> writes:
> Yuan Fu <casouri@gmail.com> writes:
>
>>> On Dec 26, 2022, at 2:03 PM, Theodor Thornhill <theo@thornhill.no> wrote:
>>>
>>> Yuan Fu <casouri@gmail.com> writes:
>>>
>>>> Theodor Thornhill <theo@thornhill.no> writes:
>>>>
>>>>> On 25 December 2022 02:30:35 CET, Yuan Fu <casouri@gmail.com> wrote:
>>>>>>
>>>>>> Theodor Thornhill <theo@thornhill.no> writes:
>>>>>>
>>>>>>> On 24 December 2022 09:36:21 CET, Yuan Fu <casouri@gmail.com> wrote:
>>>>>>>>
>>>>>>>> Theodor Thornhill <theo@thornhill.no> writes:
>>>>>>>>
>>>>>>>>> Yuan Fu <casouri@gmail.com> writes:
>>>>>>>>>
>>>>>>>>>>> On Dec 2, 2022, at 6:58 AM, Eli Zaretskii <eliz@gnu.org> wrote:
>>>>>>>>>>>
>>>>>>>>>>>> From: Yuan Fu <casouri@gmail.com>
>>>>>>>>>>>> Date: Thu, 1 Dec 2022 21:33:06 -0800
>>>>>>>>>>>>
>>>>>>>>>>>>
>>>>>>>>>>>> IMO For c-ts-mode to be usable we need to have at least a basic filling
>>>>>>>>>>>> function. Below is the function I have in my init.el, could someone have
>>>>>>>>>>>> a look and see if it’s good? Alternatively we could copy out the comment
>>>>>>>>>>>> and fill it in a temp buffer with c-mode, but I didn’t have the time to try
>>>>>>>>>>>> it out and see how well it works.
>>>>>>>>>>>
>>>>>>>>>>> Thanks.
>>>>>>>>>>>
>>>>>>>>>>> From quick testing, I see a problem:
>>>>>>>>>>>
>>>>>>>>>>> . Visit dispnew.c and go to the comment that starts on line 324. Delete
>>>>>>>>>>> the newline between the two lines of the comment, and invoke the
>>>>>>>>>>> function. Observe how the first non-blank character of the comment's
>>>>>>>>>>> second line is aligned with the "/*" on the previous line, not with the
>>>>>>>>>>> text after "/*" as I'd expect.
>>>>>>>>>>
>>>>>>>>>> I see. I’ll need to look at how cc-mode fill comments.
>>>>>>>>>>
>>>>>>>>>>>
>>>>>>>>>>> Btw, this command should be bound to M-q in ts-c-mode.
>>>>>>>>>>
>>>>>>>>>> Will do, once our fill function works well. BTW, Theo, if you have any
>>>>>>>>>> idea, don’t hesitate to go ahead :-) No obligations, of course.
>>>>>>>>>>
>>>>>>>>>> Yuan
>>>>>>>>>
>>>>>>>>> Sure! Added to my list :) I had a function at some point that used
>>>>>>>>> c-mode to do this. I'll see if I can polish it a little.
>>>>>>>>
>>>>>>>> I did some work in filling, it should work like cc-mode in like 90% of
>>>>>>>> the cases now, yay!
>>>>>>>>
>>>>>>>> Yuan
>>>>>>>
>>>>>>> Nice! For all cc-ts-modes?
>>>>>>
>>>>>> I only added for c and c++, but support for other modes should be
>>>>>> identical. And I think we should have something equivalent to cc-mode’s
>>>>>> init which sets up things that are the same in all C-like languages,
>>>>>> basically comments and filling.
>>>>
>>>> I added indent and filling for other C-like modes.
>>>>
>>>>>> But I wonder where should we put it, I guess it’s fine to leave it in
>>>>>> c-ts-mode, since there really isn’t much code. Having other modes to
>>>>>> require c-ts-mode shouldn’t be a big problem, I think?
>>>>>>
>>>>>> Yuan
>>>>>
>>>>> How about just having treesit-utils.el, or something like that? There
>>>>> are probably many things in the future that will be common among
>>>>> modes, yet won't really warrant inheritance. I think we have such an
>>>>> example in js/typescript too, iirc.
>>>>
>>>> If it’s shared across all tree-sitter modes, it should be in treesit.el,
>>>> of course. We are talking about things shared by tree-sitter C-like
>>>> modes, so the scope is smaller.
>>>>
>>>> Since right now it’s only a handful functions, I made other modes
>>>> require c-ts-mode.el. In the future if things accumulate, we can put
>>>> things into a separate file (c-ts-mode-common.el or something).
>>>>
>>>
>>> Sure. I just don't like it when these namespaces blend too much. But
>>> your call :-)
>>
>> It can be treesit-c-common.el or something. We’ll figure it out when the time comes ;-)
>>
>
> Yep :)
> Theo
I’ve added this to other modes, closing this report.
Yuan
^ permalink raw reply [flat|nested] 13+ messages in thread
end of thread, other threads:[~2023-01-07 23:11 UTC | newest]
Thread overview: 13+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-12-02 5:33 bug#59763: 29.0.60; Filling for c-ts-mode Yuan Fu
2022-12-02 14:58 ` Eli Zaretskii
2022-12-03 0:54 ` Yuan Fu
2022-12-05 11:47 ` Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors
2022-12-24 8:36 ` Yuan Fu
2022-12-24 8:42 ` Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors
2022-12-25 1:30 ` Yuan Fu
2022-12-25 7:33 ` Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors
2022-12-26 21:31 ` Yuan Fu
2022-12-26 22:03 ` Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors
2022-12-26 22:51 ` Yuan Fu
2022-12-26 23:00 ` Theodor Thornhill via Bug reports for GNU Emacs, the Swiss army knife of text editors
2023-01-07 23:11 ` Yuan Fu
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).