2018-02-14 23:16:38 -05:00
|
|
|
;; config/default/autoload/default.el -*- lexical-binding: t; -*-
|
2017-12-23 02:27:42 -05:00
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defun +default/yank-buffer-filename ()
|
|
|
|
"Copy the current buffer's path to the kill ring."
|
|
|
|
(interactive)
|
|
|
|
(if-let* ((filename (or buffer-file-name (bound-and-true-p list-buffers-directory))))
|
|
|
|
(message (kill-new (abbreviate-file-name filename)))
|
|
|
|
(error "Couldn't find filename in current buffer")))
|
|
|
|
|
2018-03-01 04:15:09 -05:00
|
|
|
;;;###autoload
|
|
|
|
(defun +default/browse-project ()
|
|
|
|
(interactive) (doom-project-browse (doom-project-root)))
|
2018-02-04 17:30:16 -05:00
|
|
|
;; NOTE No need for find-in-project, use `projectile-find-file'
|
2017-12-23 02:27:42 -05:00
|
|
|
|
2018-03-01 04:15:09 -05:00
|
|
|
;;;###autoload
|
|
|
|
(defun +default/browse-templates ()
|
|
|
|
(interactive) (doom-project-browse +file-templates-dir))
|
|
|
|
;;;###autoload
|
|
|
|
(defun +default/find-in-templates ()
|
|
|
|
(interactive) (doom-project-find-file +file-templates-dir))
|
2017-12-23 02:27:42 -05:00
|
|
|
|
2018-03-01 04:15:09 -05:00
|
|
|
;;;###autoload
|
|
|
|
(defun +default/browse-emacsd ()
|
|
|
|
(interactive) (doom-project-browse doom-emacs-dir))
|
|
|
|
;;;###autoload
|
|
|
|
(defun +default/find-in-emacsd ()
|
|
|
|
(interactive) (doom-project-find-file doom-emacs-dir))
|
2017-12-23 02:27:42 -05:00
|
|
|
|
2018-03-01 04:15:09 -05:00
|
|
|
;;;###autoload
|
|
|
|
(defun +default/browse-notes ()
|
2018-06-15 00:45:26 +02:00
|
|
|
(interactive) (doom-project-browse org-directory))
|
2018-03-01 04:15:09 -05:00
|
|
|
;;;###autoload
|
|
|
|
(defun +default/find-in-notes ()
|
2018-06-15 00:45:26 +02:00
|
|
|
(interactive) (doom-project-find-file org-directory))
|
2017-12-23 02:27:42 -05:00
|
|
|
|
2018-03-14 19:45:51 -04:00
|
|
|
;;;###autoload
|
|
|
|
(defun +default/compile (arg)
|
|
|
|
"Runs `compile' from the root of the current project.
|
|
|
|
|
|
|
|
If a compilation window is already open, recompile that instead.
|
|
|
|
|
|
|
|
If ARG (universal argument), runs `compile' from the current directory."
|
|
|
|
(interactive "P")
|
|
|
|
(if (and (bound-and-true-p compilation-in-progress)
|
|
|
|
(buffer-live-p compilation-last-buffer))
|
|
|
|
(recompile)
|
|
|
|
(call-interactively
|
|
|
|
(if arg
|
|
|
|
#'projectile-compile-project
|
|
|
|
#'compile))))
|
2018-06-01 12:13:56 +02:00
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defun +default/man-or-woman ()
|
|
|
|
"Invoke `man' if man is installed, otherwise use `woman'."
|
|
|
|
(interactive)
|
|
|
|
(call-interactively
|
|
|
|
(if (executable-find "man")
|
|
|
|
#'man
|
|
|
|
#'woman)))
|
2018-06-28 14:46:33 +02:00
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defalias '+default/newline #'newline)
|
Introduce general.el & rewrite map!
+ Now uses an overriding keymap for leader keys, so that it is always
available, even outside of normal/visual states. In insert/emacs
states, or in sessions where evil is absent, an alternative prefix is
used for leader/localleader keys. See these variables:
+ doom-leader-prefix
+ doom-leader-alt-prefix
+ doom-localleader-prefix
+ doom-localleader-alt-prefix
+ Keybinds now support alternative prefixes through the new :alt-prefix
property. This is useful for non-evil users and non-normal evil
states. By default, this is M-SPC (leader) and M-SPC m (localleader).
+ Removed +evil-commands flag from config/default (moved to
feature/evil/+commands.el).
+ config/default/+bindings.el has been split into
config/default/+{evil,emacs}-bindings.el, which one is loaded depends
on whether evil is present or not. The latter is blank, but will soon
be populated with a keybinding scheme for non-evil users (perhaps
inspired by #641).
+ The define-key! macro has been replaced; it is now an alias for
general-def.
+ Added unmap! as an alias for general-unbind.
+ The following modifier key conventions are now enforced for
consistency, across all OSes:
alt/option = meta
windows/command = super
It used to be
alt/option = alt
windows/command = meta
Many of the default keybinds have been updated to reflect this switch,
but it is likely to affect personal meta/super keybinds!
The map! macro has also been rewritten to use general-define-key. Here
is what has been changed:
+ map! no longer works with characters, e.g. (map! ?x #'do-something) is
no longer supported. Keys must be kbd-able strings like "C-c x" or
vectors like [?C-c ?x].
+ The :map and :map* properties are now the same thing. If specified
keymaps aren't defined when binding keys, it is automatically
deferred.
+ The way you bind local keybinds has changed:
;; Don't do this
(map! :l "a" #'func-a
:l "b" #'func-b)
;; Do this
(map! :map 'local "a" #'func-a
"b" #'func-b)
+ map! now supports the following new blocks:
+ (:if COND THEN-FORM ELSE-FORM...)
+ (:alt-prefix PREFIX KEYS...) -- this prefix will be used for
non-normal evil states. Equivalent to :non-normal-prefix in general.
+ The way you declare a which-key label for a prefix key has changed:
;; before
(map! :desc "label" :prefix "a" ...)
;; now
(map! :prefix ("a" . "label") ...)
+ It used to be that map! supported binding a key to a key sequence,
like so:
(map! "a" [?x]) ; pressing a is like pressing x
This functionality was removed *temporarily* while I figure out the
implementation.
Addresses: #448, #814, #860
Mentioned in: #940
2018-12-22 03:30:04 -05:00
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defun +default/new-buffer ()
|
|
|
|
"TODO"
|
|
|
|
(interactive)
|
|
|
|
(if (featurep! 'evil)
|
|
|
|
(call-interactively #'evil-buffer-new)
|
|
|
|
(let ((buffer (generate-new-buffer "*new*")))
|
|
|
|
(set-window-buffer nil buffer)
|
|
|
|
(with-current-buffer buffer
|
|
|
|
(funcall (default-value 'major-mode))))))
|
2018-12-28 03:31:03 +02:00
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defun +default/project-tasks ()
|
2018-12-31 15:28:35 -05:00
|
|
|
"Invokes `+ivy/tasks' or `+helm/tasks', depending on which is available."
|
|
|
|
(interactive)
|
2019-02-12 00:47:15 -05:00
|
|
|
(cond ((featurep! :completion ivy) (+ivy/tasks))
|
|
|
|
((featurep! :completion helm) (+helm/tasks))))
|
2019-01-21 22:07:31 -05:00
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defun +default/newline-above ()
|
|
|
|
"Insert an indented new line before the current one."
|
|
|
|
(interactive)
|
|
|
|
(if (featurep 'evil)
|
|
|
|
(call-interactively 'evil-open-above)
|
|
|
|
(beginning-of-line)
|
|
|
|
(save-excursion (newline))
|
|
|
|
(indent-according-to-mode)))
|
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defun +default/newline-below ()
|
|
|
|
"Insert an indented new line after the current one."
|
|
|
|
(interactive)
|
|
|
|
(if (featurep 'evil)
|
|
|
|
(call-interactively 'evil-open-below)
|
|
|
|
(end-of-line)
|
|
|
|
(newline-and-indent)))
|
2019-02-12 00:51:07 -05:00
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defun +default/yank-pop ()
|
|
|
|
"Interactively select what text to insert from the kill ring."
|
|
|
|
(interactive)
|
|
|
|
(call-interactively
|
|
|
|
(cond ((fboundp 'counsel-yank-pop) #'counsel-yank-pop)
|
|
|
|
((fboundp 'helm-show-kill-ring) #'helm-show-kill-ring)
|
|
|
|
((error "No kill-ring search backend available. Enable ivy or helm!")))))
|
2019-02-22 00:22:43 -05:00
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defun +default*newline-indent-and-continue-comments (_orig-fn)
|
|
|
|
"Inserts a newline and possibly indents it. Also continues comments if
|
|
|
|
executed from a commented line; handling special cases for certain languages
|
|
|
|
with weak native support."
|
|
|
|
(interactive)
|
|
|
|
(cond ((sp-point-in-string) (newline))
|
|
|
|
((and (sp-point-in-comment)
|
|
|
|
comment-line-break-function)
|
|
|
|
(funcall comment-line-break-function))
|
|
|
|
(t
|
|
|
|
(newline nil t)
|
|
|
|
(indent-according-to-mode))))
|
|
|
|
|
|
|
|
(defun doom--backward-delete-whitespace-to-column ()
|
|
|
|
"Delete back to the previous column of whitespace, or as much whitespace as
|
|
|
|
possible, or just one char if that's not possible."
|
|
|
|
(interactive)
|
|
|
|
(let* ((context (ignore-errors (sp-get-thing)))
|
|
|
|
(op (plist-get context :op))
|
|
|
|
(cl (plist-get context :cl))
|
|
|
|
open-len close-len)
|
|
|
|
(cond ;; When in strings (sp acts weird with quotes; this is the fix)
|
|
|
|
;; Also, skip closing delimiters
|
|
|
|
((and op cl
|
|
|
|
(string= op cl)
|
|
|
|
(and (string= (char-to-string (or (char-before) 0)) op)
|
|
|
|
(setq open-len (length op)))
|
|
|
|
(and (string= (char-to-string (or (char-after) 0)) cl)
|
|
|
|
(setq close-len (length cl))))
|
|
|
|
(delete-char (- open-len))
|
|
|
|
(delete-char close-len))
|
|
|
|
|
|
|
|
;; Delete up to the nearest tab column IF only whitespace between
|
|
|
|
;; point and bol.
|
|
|
|
((and (not indent-tabs-mode)
|
|
|
|
(not (bolp))
|
|
|
|
(not (sp-point-in-string))
|
|
|
|
(save-excursion (>= (- (skip-chars-backward " \t")) tab-width)))
|
|
|
|
(let ((movement (% (current-column) tab-width)))
|
|
|
|
(when (= movement 0)
|
|
|
|
(setq movement tab-width))
|
|
|
|
(delete-char (- movement)))
|
|
|
|
(unless (memq (char-before) (list ?\n ?\ ))
|
|
|
|
(insert " ")))
|
|
|
|
|
|
|
|
;; Otherwise do a regular delete
|
|
|
|
((delete-char -1)))))
|
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defun +default*delete-backward-char (n &optional killflag)
|
|
|
|
"Same as `delete-backward-char', but preforms these additional checks:
|
|
|
|
|
|
|
|
+ If point is surrounded by (balanced) whitespace and a brace delimiter ({} []
|
|
|
|
()), delete a space on either side of the cursor.
|
|
|
|
+ If point is at BOL and surrounded by braces on adjacent lines, collapse
|
|
|
|
newlines:
|
|
|
|
{
|
|
|
|
|
|
|
|
|
} => {|}
|
|
|
|
+ Otherwise, resort to `doom--backward-delete-whitespace-to-column'.
|
|
|
|
+ Resorts to `delete-char' if n > 1"
|
|
|
|
(interactive "p\nP")
|
|
|
|
(or (integerp n)
|
|
|
|
(signal 'wrong-type-argument (list 'integerp n)))
|
|
|
|
(cond ((and (use-region-p)
|
|
|
|
delete-active-region
|
|
|
|
(= n 1))
|
|
|
|
;; If a region is active, kill or delete it.
|
|
|
|
(if (eq delete-active-region 'kill)
|
|
|
|
(kill-region (region-beginning) (region-end) 'region)
|
|
|
|
(funcall region-extract-function 'delete-only)))
|
|
|
|
;; In Overwrite mode, maybe untabify while deleting
|
|
|
|
((null (or (null overwrite-mode)
|
|
|
|
(<= n 0)
|
|
|
|
(memq (char-before) '(?\t ?\n))
|
|
|
|
(eobp)
|
|
|
|
(eq (char-after) ?\n)))
|
|
|
|
(let ((ocol (current-column)))
|
|
|
|
(delete-char (- n) killflag)
|
|
|
|
(save-excursion
|
|
|
|
(insert-char ?\s (- ocol (current-column)) nil))))
|
|
|
|
;;
|
|
|
|
((and (= n 1) (bound-and-true-p smartparens-mode))
|
|
|
|
(cond ((and (memq (char-before) (list ?\ ?\t))
|
|
|
|
(save-excursion
|
|
|
|
(and (/= (skip-chars-backward " \t" (line-beginning-position)) 0)
|
|
|
|
(bolp))))
|
|
|
|
(doom--backward-delete-whitespace-to-column))
|
|
|
|
((let* ((pair (ignore-errors (sp-get-thing)))
|
|
|
|
(op (plist-get pair :op))
|
|
|
|
(cl (plist-get pair :cl))
|
|
|
|
(beg (plist-get pair :beg))
|
|
|
|
(end (plist-get pair :end)))
|
|
|
|
(cond ((and end beg (= end (+ beg (length op) (length cl))))
|
|
|
|
(sp-backward-delete-char 1))
|
|
|
|
((doom-surrounded-p pair 'inline 'balanced)
|
|
|
|
(delete-char -1 killflag)
|
|
|
|
(delete-char 1)
|
|
|
|
(when (= (point) (+ (length cl) beg))
|
|
|
|
(sp-backward-delete-char 1)
|
|
|
|
(sp-insert-pair op)))
|
|
|
|
((and (bolp) (doom-surrounded-p pair nil 'balanced))
|
|
|
|
(delete-region beg end)
|
|
|
|
(sp-insert-pair op)
|
|
|
|
t)
|
|
|
|
((run-hook-with-args-until-success 'doom-delete-backward-functions))
|
|
|
|
((doom--backward-delete-whitespace-to-column)))))))
|
|
|
|
;; Otherwise, do simple deletion.
|
|
|
|
((delete-char (- n) killflag))))
|
2019-03-07 23:24:16 -05:00
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defun +default/search-from-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 "Switch to project: " default-directory)
|
|
|
|
default-directory)))
|
|
|
|
(call-interactively
|
|
|
|
(cond ((featurep! :completion ivy) #'+ivy/project-search-from-cwd)
|
|
|
|
((featurep! :completion helm) #'+helm/project-search-from-cwd)
|
|
|
|
(#'projectile-grep)))))
|
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defun +default/search-project (&optional arg)
|
|
|
|
"Conduct a text search in files under the project root.
|
|
|
|
If prefix ARG is set, prompt for a project to search from."
|
|
|
|
(interactive "P")
|
|
|
|
(let ((default-directory
|
|
|
|
(if arg
|
|
|
|
(if-let* ((projects (projectile-relevant-known-projects)))
|
|
|
|
(completing-read "Switch to project: " projects
|
|
|
|
nil t nil nil (doom-project-root))
|
|
|
|
(user-error "There are no known projects"))
|
|
|
|
default-directory)))
|
|
|
|
(call-interactively
|
|
|
|
(cond ((featurep! :completion ivy) #'+ivy/project-search)
|
|
|
|
((featurep! :completion helm) #'+helm/project-search)
|
|
|
|
(#'rgrep)))))
|