-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathorg-iv-config.el
125 lines (96 loc) · 4.13 KB
/
org-iv-config.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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
;;; org-iv-config.el --- configure of org-iv
;; This is free and unencumbered software released into the public domain.
;; Author: kuangdash <[email protected]>
;; Version: 1.0.0
;; URL: https://github.com/kuangdash/org-iv
;; Package-Requires: ((impatient-mode 1.0.0) (org-mode 8.0))
;;; Commentary:
;; org-iv is a tool used to view html generated by org-file
;; immediately. Powered by impatient-mode.
;;; Code:
(defvar org-iv/root (file-name-directory load-file-name)
"Where the current package loaded.")
(defcustom org-iv/config-alist nil
"Association list to control ego publishing behavior.
Each element of the alist is a ego 'project.' The CAR of
each element is a string, uniquely identifying the project. The
CDR of each element is a well-formed property list with an even
number of elements, alternating keys and values, specifying
parameters for the publishing process.
\(:property value :property value ... )
Most properties are optional, but some should always be set:
`:front-html-file'
The path to the html-strings which will be put on front of html file generated by org-mode.
1. Type: string
2. Example: \"~/default/org-iv-front-file.html\"
`:back-html-file'
The path to the html-strings which will be put on back of html file generated by org-mode.
1. Type: string
2. Example: \"~/default/org-iv-back-file.html\"
`:backend'
1. Type: symbol
2. Example: 'html
`:web-test-root'
Where to store CSS and JS files, and where http-server serves
1. Type: string
2. Example: \"~/default\"
`:web-test-port'
1. Type: number
2. Example: 9876
")
(defvar org-iv--current-config-name nil
"The current org-iv configure")
(defvar org-iv--config-fallback
`(:front-html-file ,(expand-file-name "default/org-iv-front-file.html" org-iv/root)
;; The file put on front of the html generated by org-file.
:back-html-file ,(expand-file-name "default/org-iv-back-file.html" org-iv/root)
;; The file put on back of the html generated by org-file.
:backend 'html
;; The org-export-backend we choose
:web-test-root ,(expand-file-name "default" org-iv/root)
;; where we copy the content of web-resource-dir into
:web-test-port 9876)
"configure org-iv (default)")
(defvar org-iv--front-html-string nil
"The string of org-iv/front-html-file.")
(defvar org-iv--back-html-string nil
"The string of org-iv/back-html-file.")
(defun org-iv/add-to-alist (alist-var new-alist)
"Add NEW-ALIST to the ALIST-VAR.
If an element with the same key as the key of an element of
NEW-ALIST is already present in ALIST-VAR, add the new values to
it; if a matching element is not already present, append the new
element to ALIST-VAR."
;; Loop over all elements of NEW-ALIST.
(while new-alist
(let* ((new-element (car new-alist))
;; Get the element of ALIST-VAR with the same key of the current
;; element of NEW-ALIST, if any.
(old-element (assoc (car new-element) (symbol-value alist-var)))
)
(if old-element
(progn
(set alist-var (delete old-element (symbol-value alist-var)))
;; Append to `old-element' the values of the current element of
;; NEW-ALIST.
(mapc (lambda (elt) (add-to-list 'old-element elt t))
(cdr new-element))
(set alist-var (add-to-list alist-var old-element t)))
(add-to-list alist-var new-element t)))
;; Next element of NEW-ALIST.
(setq new-alist (cdr new-alist))))
(org-iv/add-to-alist
'org-iv/config-alist
`( ,(cons "default" org-iv--config-fallback))
)
(defun org-iv--get-config-option (option)
"The default org-iv config read function,
which can read `option' from `org-iv/config-alist'
if `option' is not found, get fallback value from
`org-iv--config-fallback'."
(let ((config-plist (cdr (assoc org-iv--current-config-name
org-iv/config-alist))))
(if (plist-member config-plist option)
(plist-get config-plist option)
(plist-get org-iv--config-fallback option))))
(provide 'org-iv-config)