* 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
[parent not found: <CAMojjrcdN9Yk61Rh6Pen1LWJrZZieJ+-QQCELT=yu4svNh1Tdg@mail.gmail.com>]
* 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).