summaryrefslogtreecommitdiffstats
path: root/emacs/.emacs.d/site-lisp/oni-outline.el
blob: 96d71790e337f479ef7a7152d8671f255c9e3076 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
;;; oni-outline.el --- Extra functions and commands for outline-mode  -*- lexical-binding: t; -*-

;; Copyright (C) 2015  Tom Willemse

;; Author: Tom Willemse <tom@ryuslash.org>
;; Keywords:

;; This program is free software; you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation, either version 3 of the License, or
;; (at your option) any later version.

;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
;; GNU General Public License for more details.

;; You should have received a copy of the GNU General Public License
;; along with this program.  If not, see <http://www.gnu.org/licenses/>.

;;; Commentary:

;; Here are some extra commands and functions for `outline-mode'.

;;; Code:

(require 'outline)

;;;###autoload
(defun oni:set-tab-maybe-toggle-outline ()
  "Wrap the current function mapped to `TAB'."
  (let ((func (or (lookup-key (current-local-map) (kbd "TAB"))
                  (lookup-key (current-global-map) (kbd "TAB")))))
    (local-set-key (kbd "TAB")
                   (lambda ()
                     (interactive)
                     (if (outline-on-heading-p)
                         (if (outline-invisible-p (line-end-position))
                             (outline-show-entry)
                           (outline-hide-entry))
                       (call-interactively func))))))

;;;###autoload
(defun oni:outline-toggle-entry ()
  "Show or hide an outline entry depending on its current state."
  (interactive)
  (if (outline-on-heading-p)
      (if (eql (save-excursion
                 (end-of-line)
                 (outline-invisible-p))
               'outline)
          (outline-show-entry)
        (outline-hide-entry))))

(provide 'oni-outline)
;;; oni-outline.el ends here