GNU bug report logs -
#55764
29.0.50; sh-mode: Support mksh's alternate case brace syntax
Previous Next
Reported by: Visuwesh <visuweshm <at> gmail.com>
Date: Thu, 2 Jun 2022 13:35:02 UTC
Severity: wishlist
Tags: patch
Found in version 29.0.50
Done: Stefan Monnier <monnier <at> iro.umontreal.ca>
Bug is archived. No further changes may be made.
Full log
Message #5 received at submit <at> debbugs.gnu.org (full text, mbox):
[Message part 1 (text/plain, inline)]
mksh and OpenBSD's ksh support an alternative case syntax for historical
reasons [1],
case $i {
*pattern) do ;;
*pattern2) do2 ;;
}
Currently, sh-mode cannot handle this and the easy way out of writing a
semicolon after $i is out since,
% case "foo"; { *o) echo 1;; }
/bin/mksh: syntax error: unexpected ';'
I came with the attached patch after a bit of trial and error but I'm
not sure if it is the right way to do it.
[mksh-braces.patch (text/x-diff, inline)]
diff --git a/lisp/progmodes/sh-script.el b/lisp/progmodes/sh-script.el
index 4d2554c087..588d9038e5 100644
--- a/lisp/progmodes/sh-script.el
+++ b/lisp/progmodes/sh-script.el
@@ -1971,9 +1971,10 @@
(sh-var-value 'sh-indent-for-case-label)))
(`(:before . ,(or "(" "{" "[" "while" "if" "for" "case"))
(cond
- ((and (equal token "{") (smie-rule-parent-p "for"))
+ ((and (equal token "{") (or (smie-rule-parent-p "for")
+ (smie-rule-parent-p "case")))
(let ((data (smie-backward-sexp "in")))
- (when (equal (nth 2 data) "for")
+ (when (member (nth 2 data) '("for" "case"))
`(column . ,(smie-indent-virtual)))))
((not (smie-rule-prev-p "&&" "||" "|"))
(when (smie-rule-hanging-p)
[Message part 3 (text/plain, inline)]
--
[1] Here's what the mksh manual says,
For historical reasons, open and close braces may be used instead
of in and esac, for example: “case $foo { (ba[rz]|blah) date ;; }”
and OpenBSD's ksh manual says,
For historical reasons, open and close braces may be used instead of
in and esac e.g. case $foo { *) echo bar; }.
This bug report was last modified 1 year and 215 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.