-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathdictem-elisp.el
102 lines (94 loc) · 3 KB
/
dictem-elisp.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
98
99
100
101
102
(require 'dictem)
(defun dictem-elisp-variable-documentation (func)
(let* ((help-buffer "*Help*")
(temp-buffer-show-function (lambda (b) ()))
)
(if (boundp func)
(save-excursion
(describe-variable func)
(set-buffer help-buffer)
(prog1
(buffer-substring (point-min) (point-max))
(kill-this-buffer help-buffer))
)
nil)))
(defun dictem-elisp-function-documentation (func)
(let* ((help-buffer "*Help*")
(temp-buffer-show-function (lambda (b) ()))
)
(if (functionp func)
(save-excursion
(describe-function func)
(set-buffer help-buffer)
(prog1
(buffer-substring (point-min) (point-max))
(kill-this-buffer))
)
nil)))
(defun dictem-elisp-DEFINE (query)
(let ((sym (intern-soft query))
(doc nil))
; (ret (if (and sym (functionp sym))
; (documentation sym)
; nil)))
(cond ((null sym)
(dictem-make-error
20 (format "SYmbol '%s is not defined" query)))
((functionp sym)
(setq doc (dictem-elisp-function-documentation sym))
(if doc doc
(dictem-make-error
20 (format "'%s is not documented as a function" query))))
(t
(setq doc (dictem-elisp-function-documentation sym))
(if doc doc
(dictem-make-error
20 (format "'%s is documented as neither function not variable" query)))
))))
; (documentation sym))
; (t (dictem-make-error
; 20 (format "There is no function '%s" query))))))
(defun dictem-string-match-prefix (pattern string)
(eq 0 (string-match (regexp-quote pattern) string)))
(defun dictem-string-match-substring (pattern string)
(string-match (regexp-quote pattern) string))
(defun dictem-string-match-suffix (pattern string)
(string-match (regexp-quote pattern) string)
(= (length string) (match-end 0)))
(defun dictem-string-match-word (pattern string)
(string-match (concat "\\b\\(" (regexp-quote pattern) "\\)\\b")
string))
(defun dictem-elisp-MATCH-UNI (query fun)
(let ((i 0)
(l nil)
; (re (regexp-quote query))
(item nil))
(while (< i (length obarray))
(progn
(setq item (symbol-name (elt obarray i)))
(if (funcall fun (regexp-quote query) item)
(setq l (cons item l)))
(setq i (+ i 1))))
l))
(defun dictem-elisp-MATCH (query strategy)
(let ((l (dictem-elisp-MATCH-UNI
query
(cond ((string= strategy "exact")
(symbol-function 'string=))
((string= strategy "word")
(symbol-function 'dictem-string-match-word))
((string= strategy "prefix")
(symbol-function 'dictem-string-match-prefix))
((string= strategy "suffix")
(symbol-function 'dictem-string-match-suffix))
((string= strategy "substring")
(symbol-function 'dictem-string-match-substring))))))
(if l l
(dictem-make-error
20 (format "No matches for %s/%s" query strategy)))))
;(dictem-elisp-MATCH "at" "word")
;(dictem-elisp-MATCH "file" "suffix")
;(dictem-elisp-MATCH "dictem" "prefix")
;(dictem-elisp-MATCH "s-s" "substring")
;(dictem-elisp-MATCH "pike" "substring")
(provide 'dictem-elisp)