aboutsummaryrefslogtreecommitdiff
path: root/emacs/.emacs.d/lisp/my/wiki.el
blob: 0ef52e31a3329724307828b604194f885a646a2c (plain) (blame)
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
;;; wiki.el -- A wikitext mode -*- lexical-binding: t -*-

;; Copyright (C) 2023 Free Software Foundation.

;; Author: Yuchen Pei <id@ypei.org>
;; Package-Requires: ((emacs "28.2"))

;; This file is part of dotted.

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

;; dotted 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 Affero General
;; Public License for more details.

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

;;; Commentary:

;; A wikitext mode.

;;; Code:
(require 'parsec)

(defun wiki-file ()
  (parsec-many (wiki-block)))

(defun wiki-block ()
  (parsec-or (wiki-header)))

(defun wiki-header ()
  (let* ((marker (parsec-many-s (parsec-ch ?=)))
         (raw-content
          (string-trim
           (parsec-many-till-s
            (parsec-none-of ?\n)
            (parsec-try
             (parsec-and
               (parsec-str marker)
               (wiki-header-end)))))))
    (list 'Header
          (length marker)
          (parsec-with-input raw-content
            (wiki-inlines)))))

(defun wiki-header-end ()
  (parsec-and
    (parsec-many (wiki-space))
    (parsec-eol-or-eof)))

(defun wiki-space ()
  (parsec-one-of ?\s ?\t))

(defun wiki-inlines ()
  (parsec-many (wiki-inline)))

(defun wiki-inline ()
  (parsec-or (wiki-plain)))

(defun wiki-plain ()
  (list 'Plain (parsec-many1-as-string (parsec-any-ch))))

(define-derived-mode wiki-mode text-mode "Wiki"
  "A wikitext mode.")

(provide 'wiki)
;;; wiki.el ends here