-
Notifications
You must be signed in to change notification settings - Fork 5
/
helm-fasd.el
101 lines (88 loc) · 3.84 KB
/
helm-fasd.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
;;; helm-fasd.el --- Helm source for fasd
;; Author: Antti Salminen <antti.salminen@gmail.com>
;; URL: https://github.com/ajsalminen/helm-fasd
;; Package-Requires: ((helm "2.0"))
;;; Commentary:
;;; Code:
(require 'helm)
(require 'helm-types)
(require 'helm-for-files)
(defface helm-fasd-finish
'((t (:foreground "Green")))
"Face used in mode line when fasd process returns."
:group 'helm-fasd)
(defun helm-fasd-init (command)
"Initialize async locate process for `helm-source-fasd'."
(let ((cmd (concat command (shell-quote-argument helm-pattern))))
(helm-log "Starting helm-fasd process")
(helm-log "Command line used was:\n\n%s" (concat ">>> " (propertize cmd 'face 'font-lock-comment-face) "\n\n"))
(prog1
(start-process-shell-command
"fasd-process" helm-buffer
cmd)
(set-process-sentinel
(get-buffer-process helm-buffer)
#'(lambda (_process event)
(if (string= event "finished\n")
(with-helm-window
(setq mode-line-format
'(" " mode-line-buffer-identification " "
(:eval (format "L%s" (helm-candidate-number-at-point))) " "
(:eval (propertize
(format "[fasd process finished - (%s results)]"
(max (1- (count-lines
(point-min) (point-max)))
0))
'face 'helm-fasd-finish))))
(force-mode-line-update))
(helm-log "Error: Fasd %s"
(replace-regexp-in-string "\n" "" event))))))))
(defclass helm-fasd-source (helm-source-async helm-type-file)
((candidates-process :initform 'helm-fasd-init)
(history :initform 'helm-file-name-history)
(keymap :initform helm-generic-files-map)
(help-message :initform helm-generic-file-help-message)
(candidate-number-limit :initform 9999)
(mode-line :initform helm-read-file-name-mode-line-string)))
(defvar helm-source-fasd
(helm-make-source "fasd" 'helm-fasd-source))
;;;###autoload
(defun helm-fasd ()
"Helm source for fasd."
(interactive)
(require 'helm-mode)
(let ((helm-ff-transformer-show-only-basename nil))
(helm :sources (helm-make-source "FASD" 'helm-fasd-source
:candidates-process (apply-partially #'helm-fasd-init
"fasd -R -l -s "))
:buffer "*helm fasd*")))
;;;###autoload
(defun helm-fasd-files ()
"Helm source for fasd listing files."
(interactive)
(let ((helm-ff-transformer-show-only-basename nil))
(helm :sources (helm-make-source "FASD files" 'helm-fasd-source
:candidates-process (apply-partially #'helm-fasd-init
"fasd -R -l -f "))
:buffer "*helm fasd files*")))
;;;###autoload
(defun helm-fasd-directories ()
"Helm source for fasd listing directories."
(interactive)
(let ((helm-ff-transformer-show-only-basename nil))
(helm :sources (helm-make-source "FASD directories" 'helm-fasd-source
:candidates-process (apply-partially #'helm-fasd-init
"fasd -R -l -d "))
:buffer "*helm fasd directories*")))
;;;###autoload
(defun helm-find-fasd-add-file ()
"Add file to fasd database."
(unless (executable-find "fasd") (error "Helm-search-fasd: cannot find the fasd executable"))
(let ((file (if (string= major-mode "dired-mode") dired-directory (buffer-file-name))))
(start-process "*fasd*" nil "fasd" "--add" file)))
;;;###autoload
(add-hook 'find-file-hook 'helm-find-fasd-add-file)
;;;###autoload
(add-hook 'dired-mode-hook 'helm-find-fasd-add-file)
(provide 'helm-fasd)
;;; helm-fasd.el ends here