aboutsummaryrefslogtreecommitdiff
path: root/.emacs.d/lisp/my/generic-search.el
diff options
context:
space:
mode:
authorYuchen Pei <id@ypei.org>2023-06-17 17:20:29 +1000
committerYuchen Pei <id@ypei.org>2023-06-17 17:20:29 +1000
commit093ffa5fbf7143f4668bb0a3dc9659a5cc836e12 (patch)
tree1ed4e14b2a43b8e338f4ad6a04d969b99b9239be /.emacs.d/lisp/my/generic-search.el
parentabc686827ae38ee715d9eed1c5c29161c74127e6 (diff)
Moving things one level deeper
To ease gnu stow usage. Now we can do stow -t ~ emacs
Diffstat (limited to '.emacs.d/lisp/my/generic-search.el')
-rw-r--r--.emacs.d/lisp/my/generic-search.el99
1 files changed, 0 insertions, 99 deletions
diff --git a/.emacs.d/lisp/my/generic-search.el b/.emacs.d/lisp/my/generic-search.el
deleted file mode 100644
index 3db5b08..0000000
--- a/.emacs.d/lisp/my/generic-search.el
+++ /dev/null
@@ -1,99 +0,0 @@
-;;; generic-search.el -- A search result UI -*- lexical-binding: t -*-
-
-;; Copyright (C) 2023 Free Software Foundation.
-
-;; Author: Yuchen Pei <id@ypei.org>
-;; Package-Requires: ((emacs "28.2"))
-
-;; This file is part of dotfiles.
-
-;; dotfiles is free software: you can redistribute it and/or modify it
-;; under the terms of the GNU Affero General Public License as
-;; published by the Free Software Foundation, either version 3 of the
-;; License, or (at your option) any later version.
-
-;; dotfiles 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
-;; Affero General Public License for more details.
-
-;; You should have received a copy of the GNU Affero General Public
-;; License along with dotfiles. If not, see
-;; <https://www.gnu.org/licenses/>.
-
-;;; Commentary:
-
-;; A search result UI. A generic search result mode displaying a list
-;; of things, and action on an item
-
-
-;;; Code:
-
-(defvar-local generic-search-transformer nil)
-(defvar-local generic-search-formatter nil)
-(defvar-local generic-search-default-action nil)
-(defvar-local generic-search-results nil)
-(defvar-local generic-search-keymap nil)
-
-(defvar generic-search-default-transformer 'identity)
-(defvar generic-search-default-formatter 'pp)
-(defvar generic-search-default-default-action 'generic-search-message-pp)
-(defvar generic-search-default-keymap button-map)
-
-(defun generic-search-message-pp (data)
- (interactive)
- (message (pp data)))
-
-(define-derived-mode generic-search-mode special-mode "Generic search"
- "Search results.")
-
-(defun generic-search-buffer-name (name)
- (format "*generic-search %s*" name))
-
-(defun generic-search-open (results name &optional display-options)
- (let ((buffer-name (generic-search-buffer-name name)))
- (with-current-buffer (get-buffer-create buffer-name)
- (generic-search-mode)
- (setq generic-search-results results
- generic-search-formatter
- (or (alist-get 'formatter display-options)
- generic-search-default-formatter)
- generic-search-default-action
- (or (alist-get 'default-action display-options)
- generic-search-default-default-action)
- generic-search-keymap
- (or (alist-get 'keymap display-options)
- generic-search-default-keymap)
- generic-search-transformer
- (or (alist-get 'transfomer display-options
- generic-search-default-transformer)))
- (generic-search-update)
- (switch-to-buffer-other-window buffer-name))))
-
-(defun generic-search-update ()
- (let ((inhibit-read-only t))
- (erase-buffer)
- (insert (format "%s Results:" (length generic-search-results)))
- (seq-do (lambda (result)
- (insert "\n----\n")
- (let ((start (point)))
- (insert
- (funcall generic-search-formatter result))
- (make-text-button start (point)
- 'action generic-search-default-action
- 'button-data
- (funcall generic-search-transformer result)
- 'keymap generic-search-keymap)))
- generic-search-results)
- (goto-char (point-min))
- (forward-button 1)))
-
-(defun generic-search-refresh ()
- (interactive)
- (generic-search-update))
-
-(define-key generic-search-mode-map "\t" 'forward-button)
-(define-key generic-search-mode-map [backtab] 'backward-button)
-(define-key generic-search-mode-map "g" 'generic-search-refresh)
-
-(provide 'generic-search)