-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathcubical.el
64 lines (52 loc) · 1.89 KB
/
cubical.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
;; define several class of keywords
(setq cub-keywords '("data" "import" "mutual" "let" "in" "split"
"module" "where" "U") )
(setq cub-special '("undefined" "primitive"))
;; create regex strings
(setq cub-keywords-regexp (regexp-opt cub-keywords 'words))
(setq cub-operators-regexp (regexp-opt '(":" "->" "=" "\\" "|" "\\" "*" "_") t))
(setq cub-special-regexp (regexp-opt cub-special 'words))
(setq cub-def-regexp "^[[:word:]]+")
;; clear memory
(setq cub-keywords nil)
(setq cub-special nil)
;; create the list for font-lock.
;; each class of keyword is given a particular face
(setq cub-font-lock-keywords
`(
(,cub-keywords-regexp . font-lock-type-face)
(,cub-operators-regexp . font-lock-variable-name-face)
(,cub-special-regexp . font-lock-warning-face)
(,cub-def-regexp . font-lock-function-name-face)
))
;; command to comment/uncomment text
(defun cub-comment-dwim (arg)
"Comment or uncomment current line or region in a smart way. For detail, see `comment-dwim'."
(interactive "*P")
(require 'newcomment)
(let ((comment-start "--") (comment-end ""))
(comment-dwim arg)))
;; syntax table for comments, same as for haskell-mode
(defvar cub-syntax-table
(let ((st (make-syntax-table)))
(modify-syntax-entry ?\{ "(}1nb" st)
(modify-syntax-entry ?\} "){4nb" st)
(modify-syntax-entry ?- "_ 123" st)
(modify-syntax-entry ?\n ">" st)
st))
;; define the mode
(define-derived-mode cub-mode fundamental-mode
"cubical mode"
"Major mode for editing cubical files…"
:syntax-table cub-syntax-table
;; code for syntax highlighting
(setq font-lock-defaults '(cub-font-lock-keywords))
(setq mode-name "cub")
;; modify the keymap
(define-key cub-mode-map [remap comment-dwim] 'cub-comment-dwim)
;; clear memory
(setq cub-keywords-regexp nil)
(setq cub-operators-regexp nil)
(setq cub-special-regexp nil)
)
(provide 'cub-mode)