Refactor tools/dired; fix leader key in dired buffers

This commit is contained in:
Henrik Lissner 2018-01-27 20:49:46 -05:00
parent fcbfe352c4
commit cedb8d0058
No known key found for this signature in database
GPG key ID: 5F6C0EA160557395

View file

@ -1,6 +1,9 @@
;;; tools/dired/config.el -*- lexical-binding: t; -*- ;;; tools/dired/config.el -*- lexical-binding: t; -*-
(setq ;; Always copy/delete recursively (def-package! dired
:defer t
:init
(setq ;; Always copy/delete recursively
dired-recursive-copies 'always dired-recursive-copies 'always
dired-recursive-deletes 'top dired-recursive-deletes 'top
;; Auto refresh dired, but be quiet about it ;; Auto refresh dired, but be quiet about it
@ -12,8 +15,8 @@
image-dired-gallery-dir (concat image-dired-dir "gallery/") image-dired-gallery-dir (concat image-dired-dir "gallery/")
image-dired-temp-image-file (concat image-dired-dir "temp-image") image-dired-temp-image-file (concat image-dired-dir "temp-image")
image-dired-temp-rotate-image-file (concat image-dired-dir "temp-rotate-image")) image-dired-temp-rotate-image-file (concat image-dired-dir "temp-rotate-image"))
:config
(defun +dired|sort-directories-first () (defun +dired|sort-directories-first ()
"List directories first in dired buffers." "List directories first in dired buffers."
(save-excursion (save-excursion
(let (buffer-read-only) (let (buffer-read-only)
@ -23,39 +26,29 @@
(fboundp 'dired-insert-set-properties) (fboundp 'dired-insert-set-properties)
(dired-insert-set-properties (point-min) (point-max))) (dired-insert-set-properties (point-min) (point-max)))
(set-buffer-modified-p nil)) (set-buffer-modified-p nil))
(add-hook 'dired-after-readin-hook #'+dired|sort-directories-first) (add-hook 'dired-after-readin-hook #'+dired|sort-directories-first)
;; Automatically create missing directories when creating new files ;; Automatically create missing directories when creating new files
(defun +dired|create-non-existent-directory () (defun +dired|create-non-existent-directory ()
(let ((parent-directory (file-name-directory buffer-file-name))) (let ((parent-directory (file-name-directory buffer-file-name)))
(when (and (not (file-exists-p parent-directory)) (when (and (not (file-exists-p parent-directory))
(y-or-n-p (format "Directory `%s' does not exist! Create it?" parent-directory))) (y-or-n-p (format "Directory `%s' does not exist! Create it?" parent-directory)))
(make-directory parent-directory t)))) (make-directory parent-directory t))))
(push #'+dired|create-non-existent-directory find-file-not-found-functions) (push #'+dired|create-non-existent-directory find-file-not-found-functions)
(after! evil ;; Don't interfere with leader key
(add-transient-hook! 'dired-mode-hook (define-key dired-mode-map (kbd doom-leader-key) nil))
(map! :map dired-mode-map
:n "c" #'find-file
:n "d" #'dired-do-delete
:n "r" #'dired-do-rename)))
;;
;; Packages
;;
(def-package! dired-k (def-package! dired-k
:after dired :after dired
:config :config
(setq dired-k-style 'git) (setq dired-k-style 'git)
(add-hook 'dired-initial-position-hook #'dired-k)
(add-hook 'dired-after-readin-hook #'dired-k-no-revert)
(defun +dired*dired-k-highlight (orig-fn &rest args) (defun +dired*dired-k-highlight (orig-fn &rest args)
"Butt out if the requested directory is remote (i.e. through tramp)." "Butt out if the requested directory is remote (i.e. through tramp)."
(unless (file-remote-p default-directory) (unless (file-remote-p default-directory)
(apply orig-fn args))) (apply orig-fn args)))
(advice-add #'dired-k--highlight :around #'+dired*dired-k-highlight) (advice-add #'dired-k--highlight :around #'+dired*dired-k-highlight))
(add-hook 'dired-initial-position-hook #'dired-k)
(add-hook 'dired-after-readin-hook #'dired-k-no-revert))