-
-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathdocstr-rust.el
97 lines (78 loc) · 3.25 KB
/
docstr-rust.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
;;; docstr-rust.el --- Document string for Rust -*- lexical-binding: t; -*-
;; Copyright (C) 2020-2025 Shen, Jen-Chieh <[email protected]>
;; 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 of the License, 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. If not, see <https://www.gnu.org/licenses/>.
;;; Commentary:
;;
;; Document string for Rust.
;;
;;; Code:
(require 'docstr)
(defcustom docstr-rust-style 'rfc-430
"Style specification for document string in Rust."
:type '(choice (const :tag "No specify" nil)
(const :tag "RFC 430 documentation conventions" rfc-430))
:group 'docstr)
(defcustom docstr-rust-prefix "* "
"Prefix you use on each newline."
:type 'string
:group 'docstr)
(defcustom docstr-rust-header-param ""
"Header string before inserting paramters document string."
:type 'string
:group 'docstr)
(defun docstr-rust-config-rfc-430 ()
"Configure for convention, RFC 430."
(docstr--default-format :param "*" :ret "" :show-tn nil)
(setq-local docstr-rust-prefix "/// "
docstr-rust-header-param "# Arguments"
docstr-format-var "`%s` -"))
(defun docstr-rust-config ()
"Automatically configure style according to variable `docstr-rust-style'."
(cl-case docstr-rust-style
(rfc-430 (docstr-rust-config-rfc-430))
(t (docstr--default-format))))
;;; Writer
(defun docstr-writers-rust (search-string)
"Insert document string for Rust using SEARCH-STRING."
(docstr-rust-config)
(let* ((start (point)) (prefix docstr-rust-prefix)
(paren-param-list (docstr-writers--paren-param-list-behind search-string ":" t))
(param-types (nth 0 paren-param-list))
(param-vars (nth 1 paren-param-list))
(param-var-len (length param-vars))
(return-type-str (docstr-writers--return-type-behind search-string ":")))
(unless (= param-var-len 0)
(insert "\n")
(insert docstr-rust-prefix)
(insert "\n")
(unless (string-empty-p docstr-rust-header-param)
(insert docstr-rust-prefix)
(insert docstr-rust-header-param)
(insert "\n")
(insert docstr-rust-prefix)))
(docstr-writers--insert-param param-types param-vars prefix)
(docstr-writers--insert-return return-type-str '("void") prefix)
(docstr-writers-after start t t t)))
;;; Trigger
(defcustom docstr-rust-modes '(rust-mode rustic-mode)
"Rust major modes for document string insertion."
:type 'list
:group 'docstr)
(defun docstr-trigger-rust (&rest _)
"Trigger document string inside Rust."
(when (and (memq major-mode docstr-rust-modes)
(docstr--doc-valid-p) (docstr--looking-back "///" 3))
(insert " ")
(docstr--insert-doc-string (docstr--c-style-search-string 2))))
(provide 'docstr-rust)
;;; docstr-rust.el ends here