-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathorg-padding.el
94 lines (83 loc) · 3.81 KB
/
org-padding.el
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
;;; org-padding.el --- Pad headings in org-mode
;;; Version: 0.0.1
;;; Author: TonCherAmi
;;; URL: https://github.com/TonCherAmi/org-padding
;; This file is NOT part of GNU Emacs.
;;
;; 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, 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 ; see the file COPYING. If not, write to
;; the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
;; Boston, MA 02111-1307, USA.
;;; Code:
(require 'cl)
(defvar org-padding-heading-padding-alist
'((nil . nil) (nil . nil) (nil . nil) (nil . nil) (nil . nil) (nil . nil) (nil . nil) (nil . nil))
"An alist where CAR of an item represents top heading padding
and CDR of an item represents bottom heading padding")
(defvar org-padding-block-begin-line-padding '(nil . nil)
"A pair where CAR represents top org-block-begin-line padding
and CDR represents bottom org-block-begin-line padding")
(defvar org-padding-block-end-line-padding '(nil . nil)
"A pair where CAR represents top org-block-end-line padding
and CDR represents bottom org-block-end-line padding")
(defun org-padding--set-padding (point padding)
(unless (= point (point-max))
(let ((point* (1+ point)))
(put-text-property point point* 'rear-nonsticky t)
(put-text-property point point* 'line-height (car padding))
(put-text-property point point* 'line-spacing (cdr padding)))))
(cl-defun org-padding--remove-padding (point &key (top t) (bottom t))
(when top
(remove-text-properties point (1+ point) '(line-height nil)))
(when bottom
(remove-text-properties point (1+ point) '(line-spacing nil)))
(when (and top bottom)
(remove-text-properties point (1+ point) '(rear-nonsticky nil))))
(define-minor-mode org-padding-mode
"Padding for org-mode"
nil nil nil
(let* ((keyword
`((".*\\($\\)"
(1 (let ((point (match-beginning 1)))
(unless (= point (point-max))
(org-padding--remove-padding point))
nil)))
("^\\(\\*+\\) .+\\($\\)"
(2 (let* ((level (- (match-end 1) (match-beginning 1)))
(point (match-beginning 2))
(padding (nth (1- level) org-padding-heading-padding-alist)))
(org-padding--set-padding point padding)
nil)))
("^\\*+ .+\\($\\)\n\\*+ "
(1 (let ((point (match-beginning 1)))
(org-padding--remove-padding point :top nil :bottom t))))
("^[ \t]*#\\(\\+[a-zA-Z]+:?\\| \\|$\\)_[a-zA-Z]+[ \t]*[^ \t\n]*[ \t]*.*\\($\\)"
(2 (let* ((line-type (downcase (match-string 1)))
(padding (if (string= "+begin" line-type)
org-padding-block-begin-line-padding
(if (string= "+end" line-type)
org-padding-block-end-line-padding
nil)
)))
(org-padding--set-padding (match-beginning 2) padding)
nil))))))
(if org-padding-mode
(progn
(font-lock-add-keywords nil keyword)
(font-lock-fontify-buffer))
(save-excursion
(goto-char (point-min))
(font-lock-remove-keywords nil keyword)
(font-lock-fontify-buffer)))))
(provide 'org-padding)
;;; org-padding.el ends here