* bug#70074: 29.1; js-ts-mode doesn't define comment-line-break-function
@ 2024-03-29 15:03 Evan Davis
2024-04-04 12:32 ` Eli Zaretskii
0 siblings, 1 reply; 7+ messages in thread
From: Evan Davis @ 2024-03-29 15:03 UTC (permalink / raw)
To: 70074
[-- Attachment #1: Type: text/plain, Size: 3812 bytes --]
js-ts-mode and js-mode behave differently when calling
default-indent-new-line (M-j) within a multiline comment.
Observed behavior:
- in js-mode, M-j calls c-indent-new-comment-line, which correctly
inserts a newline, indented to the correct column and prefixed with '*'
- in js-ts-mode, M-j calls comment-indent-new-line, which inserts an
indented newline without the prefix.
Expected behavior:
Block comments should be handled the same in both modes.
Steps to reproduce:
1. emacs -Q
2. open a scratch buffer in js-ts-mode and enter text (without quotes) "/*"
3. press M-j
4. observe newline is created without star prefix
Follow the same steps in js-mode to observe the desired behavior.
In GNU Emacs 29.1 (build 1, aarch64-apple-darwin21.6.0, NS
appkit-2113.60 Version 12.6.6 (Build 21G646)) of 2023-08-16 built on
armbob.lan
Windowing system distributor 'Apple', version 10.3.2299
System Description: macOS 13.6.3
Configured using:
'configure --with-ns '--enable-locallisppath=/Library/Application
Support/Emacs/${version}/site-lisp:/Library/Application
Support/Emacs/site-lisp' --with-modules 'CFLAGS=-DFD_SETSIZE=10000
-DDARWIN_UNLIMITED_SELECT' --with-x-toolkit=no'
Configured features:
ACL GLIB GMP GNUTLS JPEG JSON LIBXML2 MODULES NOTIFY KQUEUE NS PDUMPER
PNG RSVG SQLITE3 THREADS TIFF TOOLKIT_SCROLL_BARS TREE_SITTER ZLIB
Important settings:
value of $LC_ALL: en_US.UTF-8
value of $LANG: en_US
locale-coding-system: utf-8-unix
Major mode: JavaScript
Minor modes in effect:
tooltip-mode: t
global-eldoc-mode: t
show-paren-mode: t
electric-indent-mode: t
mouse-wheel-mode: t
tool-bar-mode: t
menu-bar-mode: t
file-name-shadow-mode: t
global-font-lock-mode: t
font-lock-mode: t
blink-cursor-mode: t
line-number-mode: t
indent-tabs-mode: t
transient-mark-mode: t
auto-composition-mode: t
auto-encryption-mode: t
auto-compression-mode: t
Load-path shadows:
None found.
Features:
(shadow sort mail-extr emacsbug message mailcap yank-media puny dired
dired-loaddefs rfc822 mml mml-sec password-cache epa derived epg rfc6068
epg-config gnus-util text-property-search mm-decode mm-bodies mm-encode
mail-parse rfc2231 mailabbrev gmm-utils mailheader sendmail rfc2047
rfc2045 ietf-drums mm-util mail-prsvr mail-utils pp cl-extra cl-print
thingatpt help-fns radix-tree help-mode js c-ts-common treesit cl-seq
json map byte-opt gv bytecomp byte-compile imenu cc-mode cc-fonts
cc-guess cc-menus cc-cmds cc-styles cc-align cc-engine cc-vars cc-defs
time-date subr-x cl-loaddefs cl-lib rmc iso-transl tooltip cconv eldoc
paren electric uniquify ediff-hook vc-hooks lisp-float-type elisp-mode
mwheel term/ns-win ns-win ucs-normalize mule-util term/common-win
tool-bar dnd fontset image regexp-opt fringe tabulated-list replace
newcomment text-mode lisp-mode prog-mode register page tab-bar menu-bar
rfn-eshadow isearch easymenu timer select scroll-bar mouse jit-lock
font-lock syntax font-core term/tty-colors frame minibuffer nadvice seq
simple cl-generic indonesian philippine cham georgian utf-8-lang
misc-lang vietnamese tibetan thai tai-viet lao korean japanese eucjp-ms
cp51932 hebrew greek romanian slovak czech european ethiopic indian
cyrillic chinese composite emoji-zwj charscript charprop case-table
epa-hook jka-cmpr-hook help abbrev obarray oclosure cl-preloaded button
loaddefs theme-loaddefs faces cus-face macroexp files window
text-properties overlay sha1 md5 base64 format env code-pages mule
custom widget keymap hashtable-print-readable backquote threads kqueue
cocoa ns multi-tty make-network-process emacs)
Memory information:
((conses 16 81595 8317)
(symbols 48 8432 0)
(strings 32 26906 1149)
(string-bytes 1 926726)
(vectors 16 16240)
(vector-slots 8 222853 10872)
(floats 8 35 38)
(intervals 56 269 0)
(buffers 984 11))
[-- Attachment #2: Type: text/html, Size: 4314 bytes --]
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#70074: 29.1; js-ts-mode doesn't define comment-line-break-function
2024-03-29 15:03 bug#70074: 29.1; js-ts-mode doesn't define comment-line-break-function Evan Davis
@ 2024-04-04 12:32 ` Eli Zaretskii
2024-04-05 0:28 ` Dmitry Gutov
0 siblings, 1 reply; 7+ messages in thread
From: Eli Zaretskii @ 2024-04-04 12:32 UTC (permalink / raw)
To: Evan Davis, Dmitry Gutov, Yuan Fu; +Cc: 70074
> From: Evan Davis <davis.evan.m@gmail.com>
> Date: Fri, 29 Mar 2024 11:03:10 -0400
>
> js-ts-mode and js-mode behave differently when calling default-indent-new-line (M-j) within a multiline
> comment.
>
> Observed behavior:
> - in js-mode, M-j calls c-indent-new-comment-line, which correctly inserts a newline, indented to the correct
> column and prefixed with '*'
> - in js-ts-mode, M-j calls comment-indent-new-line, which inserts an indented newline without the prefix.
>
> Expected behavior:
> Block comments should be handled the same in both modes.
>
> Steps to reproduce:
> 1. emacs -Q
> 2. open a scratch buffer in js-ts-mode and enter text (without quotes) "/*"
> 3. press M-j
> 4. observe newline is created without star prefix
>
> Follow the same steps in js-mode to observe the desired behavior.
Dmitry, Yuan: any comments or suggestions?
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#70074: 29.1; js-ts-mode doesn't define comment-line-break-function
2024-04-04 12:32 ` Eli Zaretskii
@ 2024-04-05 0:28 ` Dmitry Gutov
2024-04-08 7:10 ` Yuan Fu
0 siblings, 1 reply; 7+ messages in thread
From: Dmitry Gutov @ 2024-04-05 0:28 UTC (permalink / raw)
To: Eli Zaretskii, Evan Davis, Yuan Fu; +Cc: 70074
On 04/04/2024 15:32, Eli Zaretskii wrote:
>> From: Evan Davis<davis.evan.m@gmail.com>
>> Date: Fri, 29 Mar 2024 11:03:10 -0400
>>
>> js-ts-mode and js-mode behave differently when calling default-indent-new-line (M-j) within a multiline
>> comment.
>>
>> Observed behavior:
>> - in js-mode, M-j calls c-indent-new-comment-line, which correctly inserts a newline, indented to the correct
>> column and prefixed with '*'
>> - in js-ts-mode, M-j calls comment-indent-new-line, which inserts an indented newline without the prefix.
>>
>> Expected behavior:
>> Block comments should be handled the same in both modes.
>>
>> Steps to reproduce:
>> 1. emacs -Q
>> 2. open a scratch buffer in js-ts-mode and enter text (without quotes) "/*"
>> 3. press M-j
>> 4. observe newline is created without star prefix
>>
>> Follow the same steps in js-mode to observe the desired behavior.
> Dmitry, Yuan: any comments or suggestions?
I suppose following in js-mode's footsteps and reusing this part of CC
Mode is the obvious solution.
I haven't looked at the implementation closely enough to suggest
something else, but it'd of course be nice to be able to provide a
self-contained, shorter re-implementation instead.
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#70074: 29.1; js-ts-mode doesn't define comment-line-break-function
2024-04-05 0:28 ` Dmitry Gutov
@ 2024-04-08 7:10 ` Yuan Fu
2024-04-20 7:44 ` Eli Zaretskii
0 siblings, 1 reply; 7+ messages in thread
From: Yuan Fu @ 2024-04-08 7:10 UTC (permalink / raw)
To: Dmitry Gutov; +Cc: Eli Zaretskii, 70074, Evan Davis
> On Apr 4, 2024, at 5:28 PM, Dmitry Gutov <dmitry@gutov.dev> wrote:
>
> On 04/04/2024 15:32, Eli Zaretskii wrote:
>>> From: Evan Davis<davis.evan.m@gmail.com>
>>> Date: Fri, 29 Mar 2024 11:03:10 -0400
>>>
>>> js-ts-mode and js-mode behave differently when calling default-indent-new-line (M-j) within a multiline
>>> comment.
>>>
>>> Observed behavior:
>>> - in js-mode, M-j calls c-indent-new-comment-line, which correctly inserts a newline, indented to the correct
>>> column and prefixed with '*'
>>> - in js-ts-mode, M-j calls comment-indent-new-line, which inserts an indented newline without the prefix.
>>>
>>> Expected behavior:
>>> Block comments should be handled the same in both modes.
>>>
>>> Steps to reproduce:
>>> 1. emacs -Q
>>> 2. open a scratch buffer in js-ts-mode and enter text (without quotes) "/*"
>>> 3. press M-j
>>> 4. observe newline is created without star prefix
>>>
>>> Follow the same steps in js-mode to observe the desired behavior.
>> Dmitry, Yuan: any comments or suggestions?
>
> I suppose following in js-mode's footsteps and reusing this part of CC Mode is the obvious solution.
>
> I haven't looked at the implementation closely enough to suggest something else, but it'd of course be nice to be able to provide a self-contained, shorter re-implementation instead.
Sounds good. I wasn’t aware of this command before. Let me add it to c-ts-common.el.
Yuan
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#70074: 29.1; js-ts-mode doesn't define comment-line-break-function
2024-04-08 7:10 ` Yuan Fu
@ 2024-04-20 7:44 ` Eli Zaretskii
2024-04-22 4:35 ` Yuan Fu
0 siblings, 1 reply; 7+ messages in thread
From: Eli Zaretskii @ 2024-04-20 7:44 UTC (permalink / raw)
To: Yuan Fu; +Cc: dmitry, 70074, davis.evan.m
Ping! Yuan, can we make some progress here?
> From: Yuan Fu <casouri@gmail.com>
> Date: Mon, 8 Apr 2024 00:10:32 -0700
> Cc: Eli Zaretskii <eliz@gnu.org>,
> Evan Davis <davis.evan.m@gmail.com>,
> 70074@debbugs.gnu.org
>
>
>
> > On Apr 4, 2024, at 5:28 PM, Dmitry Gutov <dmitry@gutov.dev> wrote:
> >
> > On 04/04/2024 15:32, Eli Zaretskii wrote:
> >>> From: Evan Davis<davis.evan.m@gmail.com>
> >>> Date: Fri, 29 Mar 2024 11:03:10 -0400
> >>>
> >>> js-ts-mode and js-mode behave differently when calling default-indent-new-line (M-j) within a multiline
> >>> comment.
> >>>
> >>> Observed behavior:
> >>> - in js-mode, M-j calls c-indent-new-comment-line, which correctly inserts a newline, indented to the correct
> >>> column and prefixed with '*'
> >>> - in js-ts-mode, M-j calls comment-indent-new-line, which inserts an indented newline without the prefix.
> >>>
> >>> Expected behavior:
> >>> Block comments should be handled the same in both modes.
> >>>
> >>> Steps to reproduce:
> >>> 1. emacs -Q
> >>> 2. open a scratch buffer in js-ts-mode and enter text (without quotes) "/*"
> >>> 3. press M-j
> >>> 4. observe newline is created without star prefix
> >>>
> >>> Follow the same steps in js-mode to observe the desired behavior.
> >> Dmitry, Yuan: any comments or suggestions?
> >
> > I suppose following in js-mode's footsteps and reusing this part of CC Mode is the obvious solution.
> >
> > I haven't looked at the implementation closely enough to suggest something else, but it'd of course be nice to be able to provide a self-contained, shorter re-implementation instead.
>
> Sounds good. I wasn’t aware of this command before. Let me add it to c-ts-common.el.
>
> Yuan
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#70074: 29.1; js-ts-mode doesn't define comment-line-break-function
2024-04-20 7:44 ` Eli Zaretskii
@ 2024-04-22 4:35 ` Yuan Fu
[not found] ` <CAMojjrcdN9Yk61Rh6Pen1LWJrZZieJ+-QQCELT=yu4svNh1Tdg@mail.gmail.com>
0 siblings, 1 reply; 7+ messages in thread
From: Yuan Fu @ 2024-04-22 4:35 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: dmitry, 70074, davis.evan.m
> On Apr 20, 2024, at 12:44 AM, Eli Zaretskii <eliz@gnu.org> wrote:
>
> Ping! Yuan, can we make some progress here?
>
>> From: Yuan Fu <casouri@gmail.com>
>> Date: Mon, 8 Apr 2024 00:10:32 -0700
>> Cc: Eli Zaretskii <eliz@gnu.org>,
>> Evan Davis <davis.evan.m@gmail.com>,
>> 70074@debbugs.gnu.org
>>
>>
>>
>>> On Apr 4, 2024, at 5:28 PM, Dmitry Gutov <dmitry@gutov.dev> wrote:
>>>
>>> On 04/04/2024 15:32, Eli Zaretskii wrote:
>>>>> From:Evan Davis<davis.evan.m@gmail.com>
>>>>> Date: Fri, 29 Mar 2024 11:03:10 -0400
>>>>>
>>>>> js-ts-mode and js-mode behave differently when calling default-indent-new-line (M-j) within a multiline
>>>>> comment.
>>>>>
>>>>> Observed behavior:
>>>>> - in js-mode, M-j calls c-indent-new-comment-line, which correctly inserts a newline, indented to the correct
>>>>> column and prefixed with '*'
>>>>> - in js-ts-mode, M-j calls comment-indent-new-line, which inserts an indented newline without the prefix.
>>>>>
>>>>> Expected behavior:
>>>>> Block comments should be handled the same in both modes.
>>>>>
>>>>> Steps to reproduce:
>>>>> 1. emacs -Q
>>>>> 2. open a scratch buffer in js-ts-mode and enter text (without quotes) "/*"
>>>>> 3. press M-j
>>>>> 4. observe newline is created without star prefix
>>>>>
>>>>> Follow the same steps in js-mode to observe the desired behavior.
>>>> Dmitry, Yuan: any comments or suggestions?
>>>
>>> I suppose following in js-mode's footsteps and reusing this part of CC Mode is the obvious solution.
>>>
>>> I haven't looked at the implementation closely enough to suggest something else, but it'd of course be nice to be able to provide a self-contained, shorter re-implementation instead.
>>
>> Sounds good. I wasn’t aware of this command before. Let me add it to c-ts-common.el.
>>
>> Yuan
I looked at the implementation of c-indent-new-comment-line, it’s 178 lines of complicated control flow, handling all sorts of edge cases that I don’t understand. Sadly it’s pretty keeping coupled with the whole cc framework, so it’ll be pretty hard to take it out and reuse for c-ts-common.el.
So I added a new function c-ts-common-comment-indent-new-line. It’s probably nothing compare to c-indent-new-comment-line’s capabilities, but it can at least handle the usual cases that I can think of: indenting after //, after /*, after * inside a block comment, and after | inside a block comment.
For more advanced use-cases, we can wait until someone asks for them.
Evan, if you pull the latest master, M-j should now just work for js-ts-mode.
Yuan
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#70074: 29.1; js-ts-mode doesn't define comment-line-break-function
[not found] ` <CAMojjrcdN9Yk61Rh6Pen1LWJrZZieJ+-QQCELT=yu4svNh1Tdg@mail.gmail.com>
@ 2024-04-23 4:27 ` Yuan Fu
0 siblings, 0 replies; 7+ messages in thread
From: Yuan Fu @ 2024-04-23 4:27 UTC (permalink / raw)
To: Evan Davis; +Cc: 70074-done
> On Apr 22, 2024, at 12:06 PM, Evan Davis <davis.evan.m@gmail.com> wrote:
>
> Confirmed, works as expected. Thanks!
Great! Closing this.
Yuan
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2024-04-23 4:27 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-03-29 15:03 bug#70074: 29.1; js-ts-mode doesn't define comment-line-break-function Evan Davis
2024-04-04 12:32 ` Eli Zaretskii
2024-04-05 0:28 ` Dmitry Gutov
2024-04-08 7:10 ` Yuan Fu
2024-04-20 7:44 ` Eli Zaretskii
2024-04-22 4:35 ` Yuan Fu
[not found] ` <CAMojjrcdN9Yk61Rh6Pen1LWJrZZieJ+-QQCELT=yu4svNh1Tdg@mail.gmail.com>
2024-04-23 4:27 ` 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).