doomemacs/modules/config/default/autoload/search.el

115 lines
4.3 KiB
EmacsLisp
Raw Normal View History

2019-12-23 17:20:19 -05:00
;;; config/default/autoload/search.el -*- lexical-binding: t; -*-
;;;###autoload
(defun +default/search-cwd (&optional arg)
"Conduct a text search in files under the current folder.
If prefix ARG is set, prompt for a directory to search from."
(interactive "P")
(let ((default-directory
(if arg
(read-directory-name "Search directory: ")
default-directory)))
(call-interactively
(cond ((featurep! :completion ivy) #'+ivy/project-search-from-cwd)
((featurep! :completion helm) #'+helm/project-search-from-cwd)
((featurep! :completion vertico) #'+vertico/project-search-from-cwd)
2019-12-23 17:20:19 -05:00
(#'rgrep)))))
;;;###autoload
(defun +default/search-other-cwd ()
"Conduct a text search in another directory."
(interactive)
(+default/search-cwd 'other))
;;;###autoload
(defun +default/search-buffer ()
"Conduct a text search on the current buffer.
If a selection is active, pre-fill the prompt with it."
(interactive)
(cond ((or (featurep! :completion helm) (featurep! :completion ivy))
(call-interactively
(if (region-active-p)
#'swiper-isearch-thing-at-point
#'swiper-isearch)))
((featurep! :completion vertico)
(if (region-active-p)
(let ((start (region-beginning))
(end (region-end)))
(deactivate-mark)
(consult-line (buffer-substring-no-properties start end)))
(call-interactively #'consult-line)))))
2020-07-31 12:55:29 +07:00
;;;###autoload
2019-12-23 17:20:19 -05:00
(defun +default/search-project (&optional arg)
"Conduct a text search in the current project root.
If prefix ARG is set, include ignored/hidden files."
2019-12-23 17:20:19 -05:00
(interactive "P")
(let* ((projectile-project-root nil)
(disabled-command-function nil)
(current-prefix-arg (unless (eq arg 'other) arg))
2019-12-23 17:20:19 -05:00
(default-directory
(if (eq arg 'other)
2019-12-23 17:20:19 -05:00
(if-let (projects (projectile-relevant-known-projects))
(completing-read "Search project: " projects nil t)
2019-12-23 17:20:19 -05:00
(user-error "There are no known projects"))
default-directory)))
(call-interactively
(cond ((featurep! :completion ivy) #'+ivy/project-search)
((featurep! :completion helm) #'+helm/project-search)
((featurep! :completion vertico) #'+vertico/project-search)
2019-12-23 17:20:19 -05:00
(#'projectile-ripgrep)))))
;;;###autoload
(defun +default/search-other-project ()
"Conduct a text search in a known project."
(interactive)
(+default/search-project 'other))
;;;###autoload
(defun +default/search-project-for-symbol-at-point (&optional symbol arg)
2019-12-25 21:04:52 -05:00
"Search current project for symbol at point.
2019-12-23 17:20:19 -05:00
If prefix ARG is set, prompt for a known project to search from."
(interactive
(list (rxt-quote-pcre (or (doom-thing-at-point-or-region) ""))
current-prefix-arg))
(let* ((projectile-project-root nil)
(default-directory
(if arg
(if-let (projects (projectile-relevant-known-projects))
(completing-read "Search project: " projects nil t)
(user-error "There are no known projects"))
default-directory)))
2019-12-23 17:20:19 -05:00
(cond ((featurep! :completion ivy)
(+ivy/project-search nil symbol))
((featurep! :completion helm)
(+helm/project-search nil symbol))
((featurep! :completion vertico)
(+vertico/project-search nil symbol))
2019-12-23 17:20:19 -05:00
((rgrep (regexp-quote symbol))))))
;;;###autoload
(defun +default/search-notes-for-symbol-at-point (&optional symbol)
"Conduct a text search in the current project for symbol at point. If prefix
ARG is set, prompt for a known project to search from."
(interactive
(list (rxt-quote-pcre (or (doom-thing-at-point-or-region) ""))))
2019-12-23 17:20:19 -05:00
(require 'org)
(let ((default-directory org-directory))
(+default/search-project-for-symbol-at-point
nil symbol)))
;;;###autoload
(defun +default/org-notes-search ()
"Perform a text search on `org-directory'."
(interactive)
(require 'org)
(let ((default-directory org-directory))
(+default/search-project-for-symbol-at-point "")))
2019-12-23 17:20:19 -05:00
;;;###autoload
(defun +default/org-notes-headlines ()
"Jump to an Org headline in `org-agenda-files'."
(interactive)
(doom-completing-read-org-headings
"Jump to org headline: " org-agenda-files 3 t))