所以我有这个文件称为hooks.el我emacs.d有这样的内容:
(add-hook 'term-mode-hook ...)
(add-hook 'term-exec-mode-hook ...)
(add-hook 'python-mode-hook ...)
(add-hook 'ido-setup-hook ...)
(add-hook 'makefile-mode-hook ...)
(add-hook 'c-mode-common-hook ...)
(add-hook 'c-mode-hook ...)
(add-hook 'c++-mode-hook ...)
(add-hook 'dired-mode-hook
(lambda()
(define-key dired-mode-map "h" 'dired-previous-line)
(define-key dired-mode-map "j" 'ido-find-file)
;; ...
))
Run Code Online (Sandbox Code Playgroud)
我只是想知道我是否在做一些奇怪的事情,或者这确实是基于模式分配快捷方式的惯用方法?
我的意思是在这里添加钩子而不是明白地写:
(define-key dired-mode-map "h" 'dired-previous-line)
Run Code Online (Sandbox Code Playgroud)
当然,除非dired加载并dired-mode-map定义,否则这将不起作用,因此钩子.并且加载所有模式可能不是最好的事情,即使我不是总是使用它们,只是为了定义自定义快捷方式.但另一方面,钩子正在为每个新的缓冲区打开 - 所有这些快捷方式都被重复定义,而不是一次.
你对此事有何看法?我确信我可以切换到更优化的东西.
在此期间,我可以为我展示书签hooks.el:
(defun goto-hook-file ()
"Opens hooks.el at point specific to current `major-mode'"
(interactive)
(let ((str-mode-hook (format "%s-hook" major-mode)))
(find-file (concat emacs.d "hooks.el"))
(goto-char (point-min))
(search-forward str-mode-hook nil t)))
Run Code Online (Sandbox Code Playgroud)
你可以使用eval-after-load:
(eval-after-load 'dired
'(progn
(define-key dired-mode-map "h" 'dired-previous-line)
(define-key dired-mode-map "j" 'ido-find-file)))
Run Code Online (Sandbox Code Playgroud)
这样,密钥只定义一次.
| 归档时间: |
|
| 查看次数: |
97 次 |
| 最近记录: |