unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#15826: 24.3.50; SMIE hangs in sh-mode
@ 2013-11-07  3:55 Aaron Ecay
  2013-11-08  4:34 ` Stefan Monnier
  0 siblings, 1 reply; 4+ messages in thread
From: Aaron Ecay @ 2013-11-07  3:55 UTC (permalink / raw)
  To: 15826


I observe hangs when using sh-mode in recent trunk emacs (latest commit
Tue Nov 5 18:36:37 2013 +0200).  Recipe to reproduce:

- emacs -Q
- C-x C-f foo.sh
- type “for i in”
- immediately after entering the ‘n’, emacs will hang

Setting debug-on-quit to t and quitting yields the following backtrace:
Debugger entered--Lisp error: (quit)
  re-search-backward("\\(?:\\(?:^\\|[^\\]\\)\\(?:\\\\\\\\\\)*\\(\\(?:&&\\|;\\(?:;&\\|[&;]\\)\\||[&|]\\|[&;|]\\)\\)\\)\\=" 1 t)
  looking-back("\\(?:^\\|[^\\]\\)\\(?:\\\\\\\\\\)*\\(\\(?:&&\\|;\\(?:;&\\|[&;]\\)\\||[&|]\\|[&;|]\\)\\)" 1 greedy)
  sh-smie-sh-backward-token()
  sh-smie--sh-keyword-in-p()
  sh-smie--sh-keyword-p("in")
  sh-smie-sh-backward-token()
  smie-blink-matching-open()
  self-insert-command(1)
  call-interactively(self-insert-command nil nil)
  command-execute(self-insert-command)

Thanks,
Aaron



In GNU Emacs 24.3.50.1 (x86_64-unknown-linux-gnu, GTK+ Version 3.10.2)
 of 2013-11-05 on haize
Windowing system distributor `The X.Org Foundation', version 11.0.11404000
Configured using:
 `configure --prefix=/usr --sysconfdir=/etc --localstatedir=/var
 --libexecdir=/usr/lib --mandir=/usr/share/man --without-sound
 --with-xft --with-x-toolkit=gtk --with-gif=no 'CFLAGS=-march=x86-64
 -mtune=generic -O2 -pipe -fstack-protector --param=ssp-buffer-size=4'
 CPPFLAGS=-D_FORTIFY_SOURCE=2
 LDFLAGS=-Wl,-O1,--sort-common,--as-needed,-z,relro'

Important settings:
  value of $LC_COLLATE: C
  value of $LANG: en_US.UTF-8
  locale-coding-system: utf-8-unix
  default enable-multibyte-characters: t

-- 
Aaron Ecay





^ permalink raw reply	[flat|nested] 4+ messages in thread

* bug#15826: 24.3.50; SMIE hangs in sh-mode
  2013-11-07  3:55 bug#15826: 24.3.50; SMIE hangs in sh-mode Aaron Ecay
@ 2013-11-08  4:34 ` Stefan Monnier
  2013-11-09 20:01   ` Aaron Ecay
  0 siblings, 1 reply; 4+ messages in thread
From: Stefan Monnier @ 2013-11-08  4:34 UTC (permalink / raw)
  To: Aaron Ecay; +Cc: 15826-done

> - emacs -Q
> - C-x C-f foo.sh
> - type “for i in”
> - immediately after entering the ‘n’, emacs will hang

Indeed, thank you.  I installed the patch below which should fix it.


        Stefan


=== modified file 'lisp/progmodes/sh-script.el'
--- lisp/progmodes/sh-script.el	2013-10-24 21:16:20 +0000
+++ lisp/progmodes/sh-script.el	2013-11-08 04:31:52 +0000
@@ -1730,7 +1730,7 @@
 like a keyword, then it is a keyword."
   (let ((prev (funcall smie-backward-token-function)))
     (if (zerop (length prev))
-        (looking-back "\\s(" (1- (point)))
+        (looking-back "\\`\\|\\s(" (1- (point)))
       (assoc prev smie-grammar))))
 
 (defun sh-smie--newline-semi-p (&optional tok)
@@ -1804,12 +1804,14 @@
       (setq prev (funcall smie-backward-token-function))
       (cond
        ((zerop (length prev))
-        (if newline
-            (progn (cl-assert words) (setq res 'word))
+	(cond
+	 (newline (cl-assert words) (setq res 'word))
+	 ((bobp) (setq res 'word))
+	 (t
           (setq words t)
           (condition-case nil
               (forward-sexp -1)
-            (scan-error (setq res 'unknown)))))
+            (scan-error (setq res 'unknown))))))
        ((equal prev ";")
         (if words (setq newline t)
           (setq res 'keyword)))






^ permalink raw reply	[flat|nested] 4+ messages in thread

* bug#15826: 24.3.50; SMIE hangs in sh-mode
  2013-11-08  4:34 ` Stefan Monnier
@ 2013-11-09 20:01   ` Aaron Ecay
  2013-11-10 13:49     ` Stefan Monnier
  0 siblings, 1 reply; 4+ messages in thread
From: Aaron Ecay @ 2013-11-09 20:01 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: 15826-done

2013ko azaroak 7an, Stefan Monnier-ek idatzi zuen:
>
> Indeed, thank you.  I installed the patch below which should fix it.

It is indeed fixed.  BTW, the (new?) highlighting of for/done, if/fi,
etc. in show-paren-mode is very nifty.

Thanks,

--
Aaron Ecay





^ permalink raw reply	[flat|nested] 4+ messages in thread

* bug#15826: 24.3.50; SMIE hangs in sh-mode
  2013-11-09 20:01   ` Aaron Ecay
@ 2013-11-10 13:49     ` Stefan Monnier
  0 siblings, 0 replies; 4+ messages in thread
From: Stefan Monnier @ 2013-11-10 13:49 UTC (permalink / raw)
  To: Aaron Ecay; +Cc: 15826-done

>> Indeed, thank you.  I installed the patch below which should fix it.
> It is indeed fixed.  BTW, the (new?) highlighting of for/done, if/fi,
> etc. in show-paren-mode is very nifty.

Thanks, I'm glad you like it,


        Stefan





^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2013-11-10 13:49 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2013-11-07  3:55 bug#15826: 24.3.50; SMIE hangs in sh-mode Aaron Ecay
2013-11-08  4:34 ` Stefan Monnier
2013-11-09 20:01   ` Aaron Ecay
2013-11-10 13:49     ` Stefan Monnier

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).