Extract module-sh defuns into defuns-sh.el
This commit is contained in:
parent
8c2bf7c691
commit
3b7c727aff
2 changed files with 50 additions and 41 deletions
45
modules/lib/defuns-sh.el
Normal file
45
modules/lib/defuns-sh.el
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
;;; defuns-sh.el
|
||||||
|
|
||||||
|
(defvar sh-extra-font-lock--keywords
|
||||||
|
'((narf/sh-extra-font-lock--match-var-in-double-quoted-string
|
||||||
|
(2 font-lock-variable-name-face prepend))))
|
||||||
|
|
||||||
|
;;;###autoload
|
||||||
|
(defun narf/sh-extra-font-lock--is-in-double-quoted-string ()
|
||||||
|
"Non-nil if point in inside a double-quoted string."
|
||||||
|
(let ((state (syntax-ppss)))
|
||||||
|
(eq (nth 3 state) ?\")))
|
||||||
|
|
||||||
|
;;;###autoload
|
||||||
|
(defun narf/sh-extra-font-lock--match-var-in-double-quoted-string (limit)
|
||||||
|
"Search for variables in double-quoted strings bounded by LIMIT."
|
||||||
|
(let (res)
|
||||||
|
(while
|
||||||
|
(and (setq res
|
||||||
|
(re-search-forward
|
||||||
|
"\\$\\({#?\\)?\\([[:alpha:]_][[:alnum:]_]*\\|[-#?@!]\\)"
|
||||||
|
limit t))
|
||||||
|
(not (narf/sh-extra-font-lock--is-in-double-quoted-string))))
|
||||||
|
res))
|
||||||
|
|
||||||
|
;;;###autoload
|
||||||
|
(defun narf|sh-extra-font-lock-activate ()
|
||||||
|
"Activate sh-extra-font-lock."
|
||||||
|
(interactive)
|
||||||
|
(font-lock-add-keywords nil sh-extra-font-lock--keywords)
|
||||||
|
(if (fboundp 'font-lock-flush)
|
||||||
|
(font-lock-flush)
|
||||||
|
(when font-lock-mode
|
||||||
|
(with-no-warnings
|
||||||
|
(font-lock-fontify-buffer)))))
|
||||||
|
|
||||||
|
;;;###autoload
|
||||||
|
(defun narf/inf-shell ()
|
||||||
|
(let* ((dest-sh (symbol-name sh-shell))
|
||||||
|
(sh-shell-file dest-sh))
|
||||||
|
(sh-shell-process t)
|
||||||
|
(with-current-buffer "*shell*"
|
||||||
|
(rename-buffer (format "*shell [%s]*" dest-sh)))))
|
||||||
|
|
||||||
|
(provide 'defuns-sh)
|
||||||
|
;;; defuns-sh.el ends here
|
|
@ -1,51 +1,15 @@
|
||||||
;;; module-sh.el --- description
|
;;; module-sh.el --- description
|
||||||
|
|
||||||
(after! sh-script
|
(after! sh-script
|
||||||
(define-repl! sh-mode narf-inf-shell)
|
|
||||||
(add-hook! sh-mode 'flycheck-mode)
|
|
||||||
|
|
||||||
(defun sh-extra-font-lock--is-in-double-quoted-string ()
|
|
||||||
"Non-nil if point in inside a double-quoted string."
|
|
||||||
(let ((state (syntax-ppss)))
|
|
||||||
(eq (nth 3 state) ?\")))
|
|
||||||
|
|
||||||
(defun sh-extra-font-lock--match-var-in-double-quoted-string (limit)
|
|
||||||
"Search for variables in double-quoted strings bounded by LIMIT."
|
|
||||||
(let (res)
|
|
||||||
(while
|
|
||||||
(and (setq res
|
|
||||||
(re-search-forward
|
|
||||||
"\\$\\({#?\\)?\\([[:alpha:]_][[:alnum:]_]*\\|[-#?@!]\\)"
|
|
||||||
limit t))
|
|
||||||
(not (sh-extra-font-lock--is-in-double-quoted-string))))
|
|
||||||
res))
|
|
||||||
|
|
||||||
(defvar sh-extra-font-lock--keywords
|
|
||||||
'((sh-extra-font-lock--match-var-in-double-quoted-string
|
|
||||||
(2 font-lock-variable-name-face prepend))))
|
|
||||||
|
|
||||||
(defun sh-extra-font-lock-activate ()
|
|
||||||
"Activate sh-extra-font-lock."
|
|
||||||
(interactive)
|
|
||||||
(font-lock-add-keywords nil sh-extra-font-lock--keywords)
|
|
||||||
(if (fboundp 'font-lock-flush)
|
|
||||||
(font-lock-flush)
|
|
||||||
(when font-lock-mode
|
|
||||||
(with-no-warnings
|
|
||||||
(font-lock-fontify-buffer)))))
|
|
||||||
|
|
||||||
(add-hook 'sh-mode-hook 'sh-script-extra-font-lock-activate)
|
|
||||||
|
|
||||||
;; [pedantry intensifies]
|
;; [pedantry intensifies]
|
||||||
(defadvice sh-mode (after sh-mode-rename-modeline activate)
|
(defadvice sh-mode (after sh-mode-rename-modeline activate)
|
||||||
(setq mode-name "sh"))
|
(setq mode-name "sh"))
|
||||||
|
|
||||||
(defun narf-inf-shell ()
|
(define-repl! sh-mode narf/inf-shell)
|
||||||
(let* ((dest-sh (symbol-name sh-shell))
|
(add-hook! sh-mode 'flycheck-mode)
|
||||||
(sh-shell-file dest-sh))
|
|
||||||
(sh-shell-process t)
|
;; Fontify variables in strings
|
||||||
(with-current-buffer "*shell*"
|
(add-hook 'sh-mode-hook 'narf|sh-extra-font-lock-activate))
|
||||||
(rename-buffer (format "*shell [%s]*" dest-sh))))))
|
|
||||||
|
|
||||||
(provide 'module-sh)
|
(provide 'module-sh)
|
||||||
;;; module-sh.el ends here
|
;;; module-sh.el ends here
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue