-
-
Notifications
You must be signed in to change notification settings - Fork 75
/
nix-search.el
134 lines (110 loc) · 4.29 KB
/
nix-search.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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
;;; nix-search.el --- Run nix commands -*- lexical-binding: t -*-
;; Author: Matthew Bauer <[email protected]>
;; Homepage: https://github.com/NixOS/nix-mode
;; Keywords: nix
;; This file is NOT part of GNU Emacs.
;;; Commentary:
;;; Code:
(require 'nix)
(require 'nix-instantiate)
(require 'nix-shell)
(require 'json)
;;;###autoload
(defun nix-search--search (search file &optional no-cache use-flakes)
(nix--process-json-nocheck "search" "--json"
(unless use-flakes "--file") file
(when no-cache "--no-cache")
(unless (string-empty-p search) search)))
(defface nix-search-pname
'((t :height 1.5
:weight bold))
"Face used for package names."
:group 'nix-mode)
(defface nix-search-version
'((((class color) (background dark))
:foreground "light blue")
(((class color) (background light))
:foreground "blue"))
"Face used for package version."
:group 'nix-mode)
(defface nix-search-description
'((t))
"Face used for package description."
:group 'nix-mode)
(defvar nix-search-mode-menu (make-sparse-keymap "Nix")
"Menu for Nix Search mode.")
(defvar nix-search-mode-map (make-sparse-keymap)
"Local keymap used for Nix Search mode.")
(defvar-local nix-search--filter nil
"Search filter used for current buffer")
(defvar-local nix-search---file nil
"File/flake used for current buffer")
(defun nix-search--refresh ()
"Refresh Nix Search buffer"
(interactive)
(let ((results (nix-search--search nix-search--filter nix-search--file nil use-flakes)))
(nix-search--display results (current-buffer) use-flakes nix-search--filter nix-search--file)))
(defun nix-search-create-keymap ()
"Create the keymap associated with the Nix Search mode.")
(defun nix-search-create-menu ()
"Create the Nix Search menu as shown in the menu bar."
(let ((m '("Nix Search"
["Refresh" nix-search--refresh t])))
(easy-menu-define nix-search-mode-menu nix-search-mode-map "Menu keymap for Nix mode" m)))
(nix-search-create-keymap)
(nix-search-create-menu)
(define-derived-mode nix-search-mode view-mode "Nix Search"
"Major mode for showing Nix search results.
\\{nix-search-mode-map}"
:interactive nil
:group 'nix-mode
(easy-menu-add nix-search-mode-menu)
(read-only-mode 1))
;;;###autoload
(defun nix-search--display (results &optional display-buffer use-flakes search file)
(unless display-buffer (setq display-buffer (generate-new-buffer "*nix search*")))
(with-current-buffer display-buffer
(setq-local nix-search--filter search)
(setq-local nix-search--file file)
(unless (derived-mode-p 'nix-search-mode)
(nix-search-mode))
(let ((inhibit-read-only t))
(erase-buffer)
(insert "-------------------------------------------------------------------------------\n")
(dolist (entry results)
(let ((pname (if use-flakes
(alist-get 'pname (cdr entry))
(alist-get 'pkgName (cdr entry))))
(version (alist-get 'version (cdr entry)))
(description (alist-get 'description (cdr entry))))
(put-text-property 0 (length pname) 'face 'nix-search-pname pname)
(put-text-property 0 (length version) 'face 'nix-search-version version)
(put-text-property 0 (length description) 'face 'nix-search-description description)
(insert (format "* %s (%s)\n%s\n" pname version description))
(insert "-------------------------------------------------------------------------------\n")
))))
(display-buffer display-buffer))
;;;###autoload
(defun nix-search (search &optional file display-buffer)
"Run nix search.
SEARCH a search term to use.
FILE a Nix expression to search in."
(interactive "snix-search> \n")
(setq use-flakes (nix-has-flakes))
(setq file (or file (if use-flakes (nix-read-flake) (nix-read-file))))
(let ((results (nix-search--search search file nil use-flakes)))
(when (called-interactively-p 'any)
(nix-search--display results display-buffer use-flakes search file))
results))
(defun nix-search-read-attr (file)
"Read from a list of attributes.
FILE the nix file to look in."
(let ((collection
(sort (mapcar (lambda (x) (symbol-name (car x)))
(nix-search "" file))
'string<))
(read (cond ((fboundp 'ivy-read) 'ivy-read)
(t 'completing-read))))
(funcall read "Attribute: " collection)))
(provide 'nix-search)
;;; nix-search.el ends here