I'm encountering the following error message while editing bash shell scripts (sh-script-mode) and have font-lock-mode enabled:
Error during redisplay: (error No match 6 in highlight (6 font-lock-builtin- face)) In addition, not all of the shell keywords get fontified. For example, try the following script: #!/usr/bin/bash while true; do if false; then echo "Hello" else break fi done You may see the "while", "do", ... keywords get fontified briefly before they revert to their un-fontified appearance. I've tracked down the problem to line 1440 of lisp/progmodes/sh-script.el: 1426: (defun sh-font-lock-keywords-1 (&optional builtins) 1427: "Function to get better fontification including keywords." 1428: (let ((keywords (concat "\\([;(){}`|&]\\|^\\)[ \t]*\\(\\(" 1429: (regexp-opt (sh-feature sh-leading-keywords) t) 1430: "[ \t]+\\)?" 1431: (regexp-opt (append (sh-feature sh-leading-keywords) 1432: (sh-feature sh-other-keywords)) 1433: t)))) 1434: (sh-font-lock-keywords 1435: `(,@(if builtins 1436: `((,(concat keywords "[ \t]+\\)?" 1437: (regexp-opt (sh-feature sh-builtins) t) 1438: "\\>") 1439: (2 font-lock-keyword-face nil t) 1440: (6 font-lock-builtin-face)) 1441: ,@(sh-feature sh-font-lock-keywords-var-2))) 1442: (,(concat keywords "\\)\\>") 1443: 2 font-lock-keyword-face) 1444: ,@(sh-feature sh-font-lock-keywords-var-1))))) If I comment that line out (and insert the necessary closing paren), my scripts are fontified properly and there are no error messages generated. I'm not able to decypher what the line intended to do so I'm not sure how to fix it. One thing I did notice was that in 2001 the regexp-opt was added to build the regexp for the builtins where previously (an inefficient) mapconcat expression had been used. That could result in a change in the number of subpattern expressions (thus the 6th expression was no longer what it used to be). However, undoing that change leads to no good in Mudville. So I'm running with the line commented out, but ask that someone more familiar with the intent of that code take a look. (Assuming others can duplicate my experience). Since the code runs under jit-lock, I'm wondering if the recent tweaking of that code may have exacerbated this underlying issue... I'm running a week old CVS snapshot on w32 (GNU Emacs 22.0.50.1 (i386-mingw- nt5.1.2600) of 2005-10-09 on MMAUGXP). Thanks _______________________________________________ Emacs-devel mailing list Emacs-devel@gnu.org http://lists.gnu.org/mailman/listinfo/emacs-devel