summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authormrBliss <dewinant@gmail.com>2017-01-12 10:33:04 +0100
committermrBliss <dewinant@gmail.com>2017-01-12 10:39:19 +0100
commitb8126e4f647ed6a4f79e623752b0b0821f42890e (patch)
tree7e340056357e17dd45bd234df7a03d024dcdc36e
parentc091852fbda25c62095513753b44d3fcaf8eb340 (diff)
downloadrust-mode-b8126e4f647ed6a4f79e623752b0b0821f42890e.tar.gz
Recognize "extern" imenu items
Fixes #188.
-rw-r--r--rust-mode-tests.el40
-rw-r--r--rust-mode.el3
2 files changed, 43 insertions, 0 deletions
diff --git a/rust-mode-tests.el b/rust-mode-tests.el
index 2585237..7b29ee1 100644
--- a/rust-mode-tests.el
+++ b/rust-mode-tests.el
@@ -3,6 +3,7 @@
(require 'rust-mode)
(require 'ert)
(require 'cl)
+(require 'imenu)
(setq rust-test-fill-column 32)
@@ -2614,6 +2615,45 @@ Fontification needs to include this whole string or none of it.
(rust--after-revert-hook)
(should (equal initial-point (point))))))
+(defun test-imenu (code expected-items)
+ (with-temp-buffer
+ (rust-mode)
+ (insert code)
+ (let ((actual-items
+ ;; Replace ("item" . #<marker at ? in ?.rs) with "item"
+ (mapcar (lambda (class)
+ (cons (car class)
+ (mapcar #'car (cdr class))))
+ (imenu--generic-function rust-imenu-generic-expression))))
+ (should (equal expected-items actual-items)))))
+
+(ert-deftest rust-test-imenu-extern-unsafe-fn ()
+ (test-imenu
+ "
+fn one() {
+}
+
+unsafe fn two() {
+}
+
+extern \"C\" fn three() {
+}
+
+pub extern fn four() {
+
+}
+
+extern \"rust-intrinsic\" fn five() {
+
+}
+"
+ '(("Fn"
+ "one"
+ "two"
+ "three"
+ "four"
+ "five"))))
+
;; If electric-pair-mode is available, load it and run the tests that use it. If not,
;; no error--the tests will be skipped.
(require 'elec-pair nil t)
diff --git a/rust-mode.el b/rust-mode.el
index 1527c7a..dfe3e9a 100644
--- a/rust-mode.el
+++ b/rust-mode.el
@@ -33,6 +33,7 @@
(defconst rust-re-uc-ident "[[:upper:]][[:word:][:multibyte:]_[:digit:]]*")
(defconst rust-re-vis "pub")
(defconst rust-re-unsafe "unsafe")
+(defconst rust-re-extern "extern")
(defconst rust-re-non-standard-string
(rx
@@ -571,6 +572,8 @@ buffer."
(concat "^[[:space:]]*"
(rust-re-shy (concat (rust-re-word rust-re-vis) "[[:space:]]+")) "?"
(rust-re-shy (concat (rust-re-word rust-re-unsafe) "[[:space:]]+")) "?"
+ (rust-re-shy (concat (rust-re-word rust-re-extern) "[[:space:]]+"
+ (rust-re-shy "\"[^\"]+\"[[:space:]]+") "?")) "?"
(rust-re-item-def itype)))
(defconst rust-re-special-types (regexp-opt rust-special-types 'symbols))