diff options
| author | Stefan Monnier <monnier@iro.umontreal.ca> | 2013-11-05 21:10:18 -0500 | 
|---|---|---|
| committer | Stefan Monnier <monnier@iro.umontreal.ca> | 2013-11-05 21:10:18 -0500 | 
| commit | a35287ea23112e3e6dc73de6066f31fbe1cb269c (patch) | |
| tree | 4165edecbaeb4d526d8189cd7fea1c8db73c7ad3 /lisp | |
| parent | 798aef02223bdfdf4ff383e59590b2a44eaf3a0c (diff) | |
| download | emacs-a35287ea23112e3e6dc73de6066f31fbe1cb269c.tar.gz | |
* lisp/electric.el (electric-indent-local-mode): New minor mode.
(electric-indent-functions-without-reindent): New var.
(electric-indent-post-self-insert-function): Use it.
* lisp/emacs-lisp/gv.el (buffer-local-value): Add setter.
Diffstat (limited to 'lisp')
| -rw-r--r-- | lisp/ChangeLog | 7 | ||||
| -rw-r--r-- | lisp/electric.el | 30 | ||||
| -rw-r--r-- | lisp/emacs-lisp/gv.el | 4 | 
3 files changed, 36 insertions, 5 deletions
| diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 9d5d97b3014..5b4cba44021 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,10 @@ +2013-11-06  Stefan Monnier  <monnier@iro.umontreal.ca> + +	* electric.el (electric-indent-local-mode): New minor mode. +	(electric-indent-functions-without-reindent): New var. +	(electric-indent-post-self-insert-function): Use it. +	* emacs-lisp/gv.el (buffer-local-value): Add setter. +  2013-11-05  Eli Zaretskii  <eliz@gnu.org>  	* international/quail.el (quail-help): Be more explicit about the diff --git a/lisp/electric.el b/lisp/electric.el index 1f95e68dbf5..9a89587ff93 100644 --- a/lisp/electric.el +++ b/lisp/electric.el @@ -207,6 +207,15 @@ point right after that char, and it should return t to cause indentation,  This should be set by major modes such as `python-mode' since  Python does not lend itself to fully automatic indentation.") +(defvar electric-indent-functions-without-reindent +  '(indent-relative indent-to-left-margin indent-relative-maybe +    py-indent-line coffee-indent-line org-indent-line +    haskell-indentation-indent-line haskell-indent-cycle haskell-simple-indent) +  "List of indent functions that can't reindent. +If `line-indent-function' is one of those, then `electric-indent-mode' will +not try to reindent lines.  It is normally better to make the major +mode set `electric-indent-inhibit', but this can be used as a workaround.") +  (defun electric-indent-post-self-insert-function ()    ;; FIXME: This reindents the current line, but what we really want instead is    ;; to reindent the whole affected text.  That's the current line for simple @@ -238,8 +247,7 @@ Python does not lend itself to fully automatic indentation.")          (let ((before (copy-marker (1- pos) t)))            (save-excursion              (unless (or (memq indent-line-function -                              '(indent-relative indent-to-left-margin -                                                indent-relative-maybe)) +                              electric-indent-functions-without-reindent)                          electric-indent-inhibit)                ;; Don't reindent the previous line if the indentation function                ;; is not a real one. @@ -255,9 +263,8 @@ Python does not lend itself to fully automatic indentation.")  	      ;; Remove the trailing whitespace after indentation because  	      ;; indentation may (re)introduce the whitespace.  	      (delete-horizontal-space t))))) -      (unless (or (memq indent-line-function '(indent-to-left-margin)) -                  (and electric-indent-inhibit -                       (> pos (line-beginning-position)))) +      (unless (and electric-indent-inhibit +                   (> pos (line-beginning-position)))          (indent-according-to-mode)))))  ;;;###autoload @@ -289,6 +296,19 @@ insert a character from `electric-indent-chars'."                           (delq #'electric-indent-post-self-insert-function                                 (cdr bp)))))))) +;;;###autoload +(define-minor-mode electric-indent-local-mode +  "Toggle `electric-indent-mode' only in this buffer." +  :variable (buffer-local-value 'electric-indent-mode (current-buffer)) +  (cond +   ((eq electric-indent-mode (default-value 'electric-indent-mode)) +    (kill-local-variable 'electric-indent-mode)) +   ((not (default-value 'electric-indent-mode)) +    ;; Locally enabled, but globally disabled. +    (electric-indent-mode 1)                ; Setup the hooks. +    (setq-default electric-indent-mode nil) ; But keep it globally disabled. +    ))) +  ;;; Electric pairing.  (defcustom electric-pair-pairs diff --git a/lisp/emacs-lisp/gv.el b/lisp/emacs-lisp/gv.el index 8a5841a5fad..1a3800597a6 100644 --- a/lisp/emacs-lisp/gv.el +++ b/lisp/emacs-lisp/gv.el @@ -346,6 +346,10 @@ The return value is the last VAL in the list.  (gv-define-simple-setter window-point set-window-point)  (gv-define-simple-setter window-start set-window-start) +(gv-define-setter buffer-local-value (val var buf) +  (macroexp-let2 nil v val +    `(with-current-buffer ,buf (set (make-local-variable ,var) ,v)))) +  ;;; Some occasionally handy extensions.  ;; While several of the "places" below are not terribly useful for direct use, | 
