GNU bug report logs - #78159
shell-script indent regression in Emacs 30

Previous Next

Package: emacs;

Reported by: john.ciolfi.32 <at> gmail.com

Date: Wed, 30 Apr 2025 06:57:02 UTC

Severity: normal

Full log


View this message in rfc822 format

From: John C <john.ciolfi.32 <at> gmail.com>
To: 78159 <at> debbugs.gnu.org
Subject: bug#78159: shell-script indent regression in Emacs 30
Date: Wed, 30 Apr 2025 09:15:59 -0400
[Message part 1 (text/plain, inline)]
Hi

One more observation is that it's the subshell, code in parens, that's not
handled correctly. In the following example, the indentation in haveid3 is
incorrect so the issue is not due to the std handle redirects.

#!/bin/bash

haveid1 () {
    (id) 2> /dev/null 1>&2
         if [ $? -eq 0 ]; then
             echo "haveid1: yes"
         else
             echo "haveid1: no"
         fi
         x = 1

}

haveid2 () {
    id 2> /dev/null 1>&2
    if [ $? -eq 0 ]; then
        echo "haveid2: yes"
    else
        echo "haveid2: no"
    fi
}

haveid3 () {
    (id)
        if [ $? -eq 0 ]; then
            echo "haveid2: yes"
        else
            echo "haveid2: no"
        fi
}



On Wed, Apr 30, 2025 at 8:49 AM John C <john.ciolfi.32 <at> gmail.com> wrote:

> Hi
>
> I debugged this a little and see the regression occurred when
> sh-script.el  sh-font-lock-paren was changed in Emacs 30 to have:
>
>                     ;; Also recognize OpenBSD's case X { ... } (bug#55764).
>                     (and (looking-at ";\\(?:;&?\\|[&|]\\)\\|\\_<in\\|.{")
>
> where the Emacs 29 had:
>
>
>                     (and (looking-at ";[;&]\\|\\_<in")
>
> when I modify Emacs 30 sh-script.el to revert this one line back to the
> Emacs 29 content, we get the correct answer. I suspect reverting this line
> is not the right thing to do. Rather, I hope it helps someone find the
> solution.
>
> Thanks
> John
>
[Message part 2 (text/html, inline)]

This bug report was last modified 43 days ago.

Previous Next


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