Add outline library

This commit is contained in:
Tom Willemse 2015-12-18 20:48:59 +01:00
parent 0258e9aa5a
commit 36c7cec4d4
2 changed files with 48 additions and 14 deletions

View file

@ -141,19 +141,6 @@ MODE1 is enabled and vice-versa."
"Set the `disabled' property for each item in FUNCTIONS to nil." "Set the `disabled' property for each item in FUNCTIONS to nil."
(mapc #'(lambda (f) (put f 'disabled nil)) functions)) (mapc #'(lambda (f) (put f 'disabled nil)) functions))
(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))))))
(defun oni:current-conkeror-tab (httpcon) (defun oni:current-conkeror-tab (httpcon)
"Demonstration function" "Demonstration function"
(elnode-http-start (elnode-http-start
@ -641,7 +628,10 @@ If no direction is given, don't split."
(add-hook 'gnus-exit-group-hook 'oni:update-mailcount) (add-hook 'gnus-exit-group-hook 'oni:update-mailcount)
(add-hook 'gnus-exit-gnus-hook 'oni:update-mailcount) (add-hook 'gnus-exit-gnus-hook 'oni:update-mailcount)
(add-hook 'haskell-mode-hook 'turn-on-haskell-indentation) (add-hook 'haskell-mode-hook 'turn-on-haskell-indentation)
(add-hook 'outline-minor-mode-hook #'oni:set-tab-maybe-toggle-outline)
;; Make tab toggle outlines on outline headings.
(add-hook 'outline-minor-mode-hook 'oni:set-tab-maybe-toggle-outline)
(add-hook 'scheme-mode-hook (lambda () (setq ac-sources '(ac-source-geiser)))) (add-hook 'scheme-mode-hook (lambda () (setq ac-sources '(ac-source-geiser))))
(add-hook 'slime-mode-hook #'set-up-slime-ac) (add-hook 'slime-mode-hook #'set-up-slime-ac)

View file

@ -0,0 +1,44 @@
;;; 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))))))
(provide 'oni-outline)
;;; oni-outline.el ends here