2021-07-09 20:16:11 +03:00
|
|
|
;;; completion/vertico/autoload/vertico.el -*- lexical-binding: t; -*-
|
2021-02-16 16:46:35 -06:00
|
|
|
|
2021-07-24 16:17:04 +03:00
|
|
|
;; To prevent "Unused lexical variable" warning from +vertico--company-capf--candidates-a
|
|
|
|
;;;###autoload
|
|
|
|
(defvar orderless-match-faces)
|
|
|
|
|
2021-02-16 16:46:35 -06:00
|
|
|
;;;###autoload
|
2021-07-09 20:28:40 +03:00
|
|
|
(defadvice! +vertico--company-capf--candidates-a (fn &rest args)
|
2021-07-07 01:24:31 +03:00
|
|
|
"Highlight company matches correctly, and try default completion styles before
|
|
|
|
orderless."
|
2021-02-16 16:46:35 -06:00
|
|
|
:around 'company-capf--candidates
|
2021-07-07 01:24:31 +03:00
|
|
|
(let ((orderless-match-faces [completions-common-part])
|
2021-07-24 17:21:55 +03:00
|
|
|
(completion-styles +vertico-company-completion-styles))
|
2021-02-16 16:46:35 -06:00
|
|
|
(apply fn args)))
|
|
|
|
|
2021-01-16 20:21:50 +08:00
|
|
|
;;;###autoload
|
2021-07-09 20:28:40 +03:00
|
|
|
(cl-defun +vertico-file-search (&key query in all-files (recursive t) prompt args)
|
2021-01-16 20:21:50 +08:00
|
|
|
"Conduct a file search using ripgrep.
|
2021-02-22 15:47:06 -06:00
|
|
|
|
2021-01-16 20:21:50 +08:00
|
|
|
:query STRING
|
|
|
|
Determines the initial input to search for.
|
|
|
|
:in PATH
|
2021-02-16 20:42:41 -06:00
|
|
|
Sets what directory to base the search out of. Defaults to the current project's root.
|
2021-01-16 20:21:50 +08:00
|
|
|
:recursive BOOL
|
|
|
|
Whether or not to search files recursively from the base directory."
|
|
|
|
(declare (indent defun))
|
|
|
|
(unless (executable-find "rg")
|
|
|
|
(user-error "Couldn't find ripgrep in your PATH"))
|
|
|
|
(require 'consult)
|
2021-02-16 20:42:41 -06:00
|
|
|
(setq deactivate-mark t)
|
2021-05-17 13:20:02 +03:00
|
|
|
(let* ((project-root (or (doom-project-root) default-directory))
|
2021-02-23 22:12:10 -06:00
|
|
|
(directory (or in project-root))
|
2021-07-26 22:44:51 -04:00
|
|
|
(args
|
|
|
|
(split-string
|
|
|
|
(string-trim
|
|
|
|
(concat (if all-files "-uu")
|
|
|
|
(unless recursive "--maxdepth 1")
|
|
|
|
"--null --line-buffered --color=always --max-columns=500 --no-heading --line-number"
|
|
|
|
" --hidden -g !.git "
|
|
|
|
(mapconcat #'shell-quote-argument args " ")))
|
|
|
|
" "))
|
|
|
|
(prompt (if (stringp prompt) (string-trim prompt) "Search"))
|
2021-02-23 22:12:10 -06:00
|
|
|
(query (or query
|
|
|
|
(when (doom-region-active-p)
|
2021-07-26 22:44:51 -04:00
|
|
|
(rxt-quote-pcre (doom-thing-at-point-or-region)))))
|
|
|
|
(ripgrep-command (string-join `("rg" ,@args "." "-e ARG OPTS" ) " "))
|
|
|
|
(consult-async-split-style consult-async-split-style)
|
|
|
|
(consult-async-split-styles-alist consult-async-split-styles-alist))
|
|
|
|
;; Change the split style if the initial query contains the separator.
|
|
|
|
(when query
|
|
|
|
(cl-destructuring-bind (&key type separator initial)
|
|
|
|
(consult--async-split-style)
|
|
|
|
(pcase type
|
|
|
|
(`separator
|
|
|
|
(replace-regexp-in-string (regexp-quote (char-to-string separator))
|
|
|
|
(concat "\\" separator)
|
|
|
|
query t t))
|
|
|
|
(`perl
|
|
|
|
(when (string-match-p initial query)
|
|
|
|
(setf (alist-get 'perlalt consult-async-split-styles-alist)
|
|
|
|
`(:initial ,(or (cl-loop for char in (list "%" "@" "!" "&" "/" ";")
|
|
|
|
unless (string-match-p char query)
|
|
|
|
return char)
|
|
|
|
"%")
|
|
|
|
:type perl)
|
|
|
|
consult-async-split-style 'perlalt))))))
|
2021-02-23 22:12:10 -06:00
|
|
|
(consult--grep prompt ripgrep-command directory query)))
|
2021-01-16 20:21:50 +08:00
|
|
|
|
|
|
|
;;;###autoload
|
2021-07-09 20:28:40 +03:00
|
|
|
(defun +vertico/project-search (&optional arg initial-query directory)
|
2021-02-16 20:42:41 -06:00
|
|
|
"Peforms a live project search from the project root using ripgrep.
|
2021-01-16 20:21:50 +08:00
|
|
|
If ARG (universal argument), include all files, even hidden or compressed ones,
|
|
|
|
in the search."
|
|
|
|
(interactive "P")
|
2021-07-09 20:28:40 +03:00
|
|
|
(+vertico-file-search :query initial-query :in directory :all-files arg))
|
2021-01-16 20:21:50 +08:00
|
|
|
|
|
|
|
;;;###autoload
|
2021-07-09 20:28:40 +03:00
|
|
|
(defun +vertico/project-search-from-cwd (&optional arg initial-query)
|
2021-02-16 20:42:41 -06:00
|
|
|
"Performs a live project search from the current directory.
|
2021-01-16 20:21:50 +08:00
|
|
|
If ARG (universal argument), include all files, even hidden or compressed ones."
|
|
|
|
(interactive "P")
|
2021-07-09 20:28:40 +03:00
|
|
|
(+vertico/project-search arg initial-query default-directory))
|
2021-02-19 20:48:34 -06:00
|
|
|
|
|
|
|
;;;###autoload
|
2021-07-09 20:28:40 +03:00
|
|
|
(defun +vertico/search-symbol-at-point ()
|
2021-02-19 20:48:34 -06:00
|
|
|
(interactive)
|
|
|
|
(consult-line (thing-at-point 'symbol)))
|
2021-05-07 21:27:14 +03:00
|
|
|
|
2021-06-30 19:24:27 +03:00
|
|
|
;;;###autoload
|
2021-07-09 20:28:40 +03:00
|
|
|
(defun +vertico/backward-updir ()
|
2021-07-09 20:16:11 +03:00
|
|
|
"Delete char before or go up directory for file cagetory vertico buffers."
|
2021-06-30 19:24:27 +03:00
|
|
|
(interactive)
|
|
|
|
(let ((metadata (completion-metadata (minibuffer-contents)
|
|
|
|
minibuffer-completion-table
|
|
|
|
minibuffer-completion-predicate)))
|
|
|
|
(if (and (eq (char-before) ?/)
|
|
|
|
(eq (completion-metadata-get metadata 'category) 'file))
|
|
|
|
(let ((new-path (minibuffer-contents)))
|
|
|
|
(delete-region (minibuffer-prompt-end) (point-max))
|
|
|
|
(insert (abbreviate-file-name
|
|
|
|
(file-name-directory
|
|
|
|
(directory-file-name
|
|
|
|
(expand-file-name new-path))))))
|
|
|
|
(call-interactively 'backward-delete-char))))
|
|
|
|
|
2021-07-28 11:51:19 -04:00
|
|
|
;;;###autoload
|
|
|
|
(defun +vertico-embark-target-package-fn ()
|
|
|
|
"Targets Doom's package! statements and returns the package name"
|
|
|
|
(when (or (derived-mode-p 'emacs-lisp-mode) (derived-mode-p 'org-mode))
|
|
|
|
(save-excursion
|
|
|
|
(search-backward "(")
|
|
|
|
(when (looking-at "(\\s-*package!\\s-*\\(\\(\\sw\\|\\s_\\)+\\)\\s-*")
|
|
|
|
(let ((pkg (match-string 1)))
|
|
|
|
(set-text-properties 0 (length pkg) nil pkg)
|
|
|
|
`(package . ,pkg))))))
|
2021-06-30 19:24:27 +03:00
|
|
|
|
2021-05-07 21:27:14 +03:00
|
|
|
;;;###autoload
|
2021-07-09 20:28:40 +03:00
|
|
|
(defun +vertico/embark-export-write ()
|
2021-07-09 20:16:11 +03:00
|
|
|
"Export the current vertico results to a writable buffer if possible.
|
2021-05-21 13:19:52 +03:00
|
|
|
|
|
|
|
Supports exporting consult-grep to wgrep, file to wdeired, and consult-location to occur-edit"
|
2021-05-07 21:27:14 +03:00
|
|
|
(interactive)
|
2021-07-25 19:05:52 +03:00
|
|
|
(require 'embark)
|
2021-05-07 21:27:14 +03:00
|
|
|
(require 'wgrep)
|
|
|
|
(pcase-let ((`(,type . ,candidates)
|
|
|
|
(run-hook-with-args-until-success 'embark-candidate-collectors)))
|
2021-05-21 13:19:52 +03:00
|
|
|
(pcase type
|
|
|
|
('consult-grep (let ((embark-after-export-hook #'wgrep-change-to-wgrep-mode))
|
|
|
|
(embark-export)))
|
|
|
|
('file (let ((embark-after-export-hook #'wdired-change-to-wdired-mode))
|
|
|
|
(embark-export)))
|
|
|
|
('consult-location (let ((embark-after-export-hook #'occur-edit-mode))
|
|
|
|
(embark-export)))
|
|
|
|
(x (user-error "embark category %S doesn't support writable export" x)))))
|
2021-05-22 01:21:10 +03:00
|
|
|
|
|
|
|
;;;###autoload
|
2021-07-09 20:28:40 +03:00
|
|
|
(defun +vertico/embark-preview ()
|
2021-07-09 20:16:11 +03:00
|
|
|
"Previews candidate in vertico buffer, unless it's a consult command"
|
2021-05-22 01:21:10 +03:00
|
|
|
(interactive)
|
2021-05-22 23:22:17 +03:00
|
|
|
(unless (bound-and-true-p consult--preview-function)
|
|
|
|
(save-selected-window
|
|
|
|
(let ((embark-quit-after-action nil))
|
|
|
|
(embark-default-action)))))
|
2021-05-22 01:21:10 +03:00
|
|
|
|
|
|
|
;;;###autoload
|
2021-07-13 14:01:42 +03:00
|
|
|
(defun +vertico/next-candidate-preview (&optional n)
|
|
|
|
"Go forward N candidates and preivew"
|
2021-05-22 01:21:10 +03:00
|
|
|
(interactive)
|
2021-07-13 14:01:42 +03:00
|
|
|
(vertico-next (or n 1))
|
2021-07-09 20:28:40 +03:00
|
|
|
(+vertico/embark-preview))
|
2021-05-22 01:21:10 +03:00
|
|
|
|
|
|
|
;;;###autoload
|
2021-07-13 14:01:42 +03:00
|
|
|
(defun +vertico/previous-candidate-preview (&optional n)
|
|
|
|
"Go backward N candidates and preivew"
|
2021-05-22 01:21:10 +03:00
|
|
|
(interactive)
|
2021-07-13 14:01:42 +03:00
|
|
|
(vertico-previous (or n 1))
|
2021-07-09 20:28:40 +03:00
|
|
|
(+vertico/embark-preview))
|
2021-07-28 12:53:02 -04:00
|
|
|
|
|
|
|
(defvar +vertico/find-file-in--history nil)
|
|
|
|
;;;###autoload
|
|
|
|
(defun +vertico/find-file-in (&optional dir initial)
|
|
|
|
"Jump to file under DIR (recursive).
|
|
|
|
If INITIAL is non-nil, use as initial input."
|
|
|
|
(interactive)
|
|
|
|
(let* ((default-directory (or dir default-directory))
|
|
|
|
(prompt-dir (consult--directory-prompt "Find" default-directory))
|
|
|
|
(cmd (split-string-and-unquote consult-find-command " "))
|
|
|
|
(cmd (remove "OPTS" cmd))
|
|
|
|
(cmd (remove "ARG" cmd)))
|
|
|
|
(find-file
|
|
|
|
(consult--read
|
|
|
|
(split-string (cdr (apply #'doom-call-process cmd)) "\n" t)
|
|
|
|
:prompt default-directory
|
|
|
|
:sort nil
|
|
|
|
:require-match t
|
|
|
|
:initial (if initial (shell-quote-argument initial))
|
|
|
|
:add-history (thing-at-point 'filename)
|
|
|
|
:category '+vertico
|
|
|
|
:history '(:input +vertico/find-file-in--history)))))
|
2021-07-28 13:02:46 -04:00
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defun +vertico/jump-list (jump)
|
|
|
|
"Go to an entry in evil's (or better-jumper's) jumplist."
|
|
|
|
(interactive
|
|
|
|
(let (buffers)
|
|
|
|
(unwind-protect
|
|
|
|
(list
|
|
|
|
(consult--read
|
|
|
|
;; REVIEW Refactor me
|
|
|
|
(nreverse
|
|
|
|
(delete-dups
|
|
|
|
(delq
|
|
|
|
nil (mapcar (lambda (mark)
|
|
|
|
(when mark
|
|
|
|
(cl-destructuring-bind (path pt _id) mark
|
|
|
|
(let ((buf (get-file-buffer path)))
|
|
|
|
(unless buf
|
|
|
|
(push (setq buf (find-file-noselect path t))
|
|
|
|
buffers))
|
|
|
|
(with-current-buffer buf
|
|
|
|
(goto-char pt)
|
|
|
|
(font-lock-fontify-region (line-beginning-position) (line-end-position))
|
|
|
|
(cons (format "%s:%d: %s"
|
|
|
|
(buffer-name)
|
|
|
|
(line-number-at-pos)
|
|
|
|
(string-trim-right (or (thing-at-point 'line) "")))
|
|
|
|
(point-marker)))))))
|
|
|
|
(cddr (better-jumper-jump-list-struct-ring
|
|
|
|
(better-jumper-get-jumps (better-jumper--get-current-context))))))))
|
|
|
|
:prompt "jumplist: "
|
|
|
|
:sort nil
|
|
|
|
:require-match t
|
|
|
|
:category 'jump-list))
|
|
|
|
(mapc #'kill-buffer buffers))))
|
|
|
|
(let ((mark (cdr jump)))
|
|
|
|
(delq! (marker-buffer mark) buffers)
|
|
|
|
(mapc #'kill-buffer buffers)
|
|
|
|
(setq buffers nil)
|
|
|
|
(with-current-buffer (switch-to-buffer (marker-buffer mark))
|
|
|
|
(goto-char (marker-position mark)))))
|