1 ;; Maintainer: The LLVM team, http://llvm.org/
2 ;; Description: Major mode for TableGen description files (part of LLVM project)
9 ;; Create mode-specific tables.
10 (defvar td-decorators-face
'td-decorators-face
11 "Face method decorators.")
12 (make-face 'td-decorators-face
)
14 (defvar tablegen-font-lock-keywords
15 (let ((kw (regexp-opt '("class" "defm" "def" "field" "include" "in"
18 (type-kw (regexp-opt '("bit" "bits" "code" "dag" "int" "list" "string")
23 ;; '("\/\/" . font-lock-comment-face)
25 '("\"[^\"]+\"" . font-lock-string-face
)
27 '("\\<0x[0-9A-Fa-f]+\\>" . font-lock-preprocessor-face
)
29 '("\\<0b[01]+\\>" . font-lock-preprocessor-face
)
31 '("\\<[-]?[0-9]+\\>" . font-lock-preprocessor-face
)
32 ;; Floating point constants
33 '("\\<[-+]?[0-9]+\.[0-9]*\([eE][-+]?[0-9]+\)?\\>" . font-lock-preprocessor-face
)
35 '("^[ \t]*\\(@.+\\)" 1 'td-decorators-face
)
37 (cons (concat kw
"[ \n\t(]") 1)
40 (cons (concat type-kw
"[ \n\t(]") 1)
42 "Additional expressions to highlight in TableGen mode.")
43 (put 'tablegen-mode
'font-lock-defaults
'(tablegen-font-lock-keywords))
45 ;; ---------------------- Syntax table ---------------------------
46 ;; Shamelessly ripped from jasmin.el
47 ;; URL: http://www.neilvandyke.org/jasmin-emacs/jasmin.el
49 (defvar tablegen-mode-syntax-table nil
50 "Syntax table used in `tablegen-mode' buffers.")
51 (when (not tablegen-mode-syntax-table
)
52 (setq tablegen-mode-syntax-table
(make-syntax-table))
54 (modify-syntax-entry ?\
" " tablegen-mode-syntax-table
)
55 (modify-syntax-entry ?
\t " " tablegen-mode-syntax-table
)
56 (modify-syntax-entry ?
\r " " tablegen-mode-syntax-table
)
57 (modify-syntax-entry ?
\n " " tablegen-mode-syntax-table
)
58 (modify-syntax-entry ?
\f " " tablegen-mode-syntax-table
)
59 ;; word constituents (`w')
60 (modify-syntax-entry ?\%
"w" tablegen-mode-syntax-table
)
61 (modify-syntax-entry ?\_
"w" tablegen-mode-syntax-table
)
63 (modify-syntax-entry ?
/ ". 124b" tablegen-mode-syntax-table
)
64 (modify-syntax-entry ?
* ". 23" tablegen-mode-syntax-table
)
65 (modify-syntax-entry ?
\n "> b" tablegen-mode-syntax-table
)
67 (modify-syntax-entry ?\
( "(" tablegen-mode-syntax-table
)
68 (modify-syntax-entry ?\
[ "(" tablegen-mode-syntax-table
)
69 (modify-syntax-entry ?\
{ "(" tablegen-mode-syntax-table
)
70 (modify-syntax-entry ?\
< "(" tablegen-mode-syntax-table
)
72 (modify-syntax-entry ?\
) ")" tablegen-mode-syntax-table
)
73 (modify-syntax-entry ?\
] ")" tablegen-mode-syntax-table
)
74 (modify-syntax-entry ?\
} ")" tablegen-mode-syntax-table
)
75 (modify-syntax-entry ?\
> ")" tablegen-mode-syntax-table
)
77 (modify-syntax-entry ?
\" "\"" tablegen-mode-syntax-table
)
80 ;; --------------------- Abbrev table -----------------------------
82 (defvar tablegen-mode-abbrev-table nil
83 "Abbrev table used while in TableGen mode.")
84 (define-abbrev-table 'tablegen-mode-abbrev-table
())
86 (defvar tablegen-mode-hook nil
)
87 (defvar tablegen-mode-map nil
) ; Create a mode-specific keymap.
89 (if (not tablegen-mode-map
)
90 () ; Do not change the keymap if it is already set up.
91 (setq tablegen-mode-map
(make-sparse-keymap))
92 (define-key tablegen-mode-map
"\t" 'tab-to-tab-stop
)
93 (define-key tablegen-mode-map
"\es" 'center-line
)
94 (define-key tablegen-mode-map
"\eS" 'center-paragraph
))
96 (defun tablegen-mode ()
97 "Major mode for editing TableGen description files.
99 Runs tablegen-mode-hook on startup."
101 (kill-all-local-variables)
102 (use-local-map tablegen-mode-map
) ; Provides the local keymap.
103 (make-local-variable 'font-lock-defaults
)
104 (setq major-mode
'tablegen-mode
; This is how describe-mode
105 ; finds the doc string to print.
106 mode-name
"TableGen" ; This name goes into the modeline.
107 local-abbrev-table tablegen-mode-abbrev-table
108 font-lock-defaults
`(tablegen-font-lock-keywords)
109 require-final-newline t
112 (set-syntax-table tablegen-mode-syntax-table
)
113 (make-local-variable 'comment-start
)
114 (setq comment-start
"//")
115 (run-hooks 'tablegen-mode-hook
)) ; Finally, this permits the user to
116 ; customize the mode with a hook.
118 ;; Associate .td files with tablegen-mode
119 (setq auto-mode-alist
(append '(("\\.td$" . tablegen-mode
)) auto-mode-alist
))
121 (provide 'tablegen-mode
)
122 ;; end of tablegen-mode.el