init.el: Update emacs config

1. Change update interval to 4 days as it seems for
a longer interval somehow finding packages on melpa
runs into some issue.
2. Remove intero. It cannot even resolve a symbol in
the same project.
3. Add support for dumb-jump. Seems to have better
specific search focus than just git grep with helm.
4. Add key bindings for xref. We can use emacs tags
which is especially helpful since LSP or intero does
not work for Haskell nor does gtags.

Signed-off-by: Sanchayan Maity <maitysanchayan@gmail.com>
This commit is contained in:
Sanchayan Maity 2019-03-12 23:13:11 +05:30
parent fc1cdd6eda
commit 8938e61a52

73
init.el
View file

@ -61,7 +61,7 @@
:ensure t :ensure t
:config :config
(setq auto-package-update-delete-old-versions t (setq auto-package-update-delete-old-versions t
auto-package-update-interval 14) auto-package-update-interval 4)
(auto-package-update-maybe)) (auto-package-update-maybe))
;; Restart emacs from within emacs ;; Restart emacs from within emacs
@ -115,6 +115,9 @@
(setq avy-all-windows 'all-frames) (setq avy-all-windows 'all-frames)
(setq avy-background t))) (setq avy-background t)))
(use-package dumb-jump
:ensure t)
;; Vim mode ;; Vim mode
(use-package evil (use-package evil
:ensure t :ensure t
@ -184,6 +187,7 @@
helm-gtags-prefix-key "SPC" helm-gtags-prefix-key "SPC"
helm-gtags-use-input-at-cursor t helm-gtags-use-input-at-cursor t
helm-gtags-pulse-at-cursor t) helm-gtags-pulse-at-cursor t)
;; enable gtags only for C
(add-hook 'c-mode-hook 'helm-gtags-mode))) (add-hook 'c-mode-hook 'helm-gtags-mode)))
;; All The Icons ;; All The Icons
@ -361,7 +365,24 @@
"jb" 'avy-pop-mark "jb" 'avy-pop-mark
"jj" 'evil-avy-goto-char-timer "jj" 'evil-avy-goto-char-timer
"jl" 'evil-avy-goto-line "jl" 'evil-avy-goto-line
"jw" 'evil-avy-goto-word-or-subword-1)) "jw" 'evil-avy-goto-word-or-subword-1
;; dumb jump
"dg" 'dumb-jump-go
"dp" 'dump-jump-back
"dq" 'dump-jump-quick-look
"dw" 'dumb-jump-go-other-window
"de" 'dumb-jump-go-prefer-external
"do" 'dumb-jump-go-prefer-external-other-window
"dp" 'dumb-jump-go-prompt
;; xref
"xv" 'visit-tags-table
"xd" 'xref-find-definition
"xr" 'xref-find-references
"xa" 'xref-find-appropos
"xf" 'xref-find-definitions-other-frame
"xp" 'xref-pop-marker-stack
"xq" 'xref-query-replace-in-results
"xs" 'tags-search))
(general-define-key (general-define-key
:states '(normal visual emacs) :states '(normal visual emacs)
@ -372,33 +393,6 @@
:which-key "format declaration using hindent") :which-key "format declaration using hindent")
"F" '(haskell-mode-stylish-buffer "F" '(haskell-mode-stylish-buffer
:which-key "format buffer using haskell stylish") :which-key "format buffer using haskell stylish")
"gg" '(intero-goto-definition
:which-key "goto definition or tag")
"hi" '(intero-info
:which-key "get info for identifier under cursor")
"ht" '(intero-type-at
:which-key "get type of identifier under cursor")
"rs" '(intero-apply-suggestions)
"sb" '(intero-repl-load
:which-key "load/reload current buffer in repl")
"ic" '(intero-cd
:which-key "change directory in backend process")
"id" '(intero-devel-reload
:which-key "reload module DevelMain")
"ik" '(intero-destroy
:which-key "stop current process & kill its associated")
"il" '(intero-list-buffers
:which-key "list hidden process buffers created")
"ir" '(intero-restart
:which-key "restart process with same config")
"it" '(intero-targets
:which-key "set targets to use for stack ghci")
"sc" nil
"hT" '(haskell-intero/insert-type)
"ss" '(haskell-intero/display-repl
:which-key "show repl without switching")
"sS" '(haskell-intero/pop-to-repl
:which-key "show and switch to repl")
"rb" '(hlint-refactor-refactor-buffer "rb" '(hlint-refactor-refactor-buffer
:which-key "apply all hlint suggestions") :which-key "apply all hlint suggestions")
"rr" '(hlint-refactor-refactor-at-point "rr" '(hlint-refactor-refactor-at-point
@ -686,25 +680,6 @@
(call-interactively 'git-link-commit)) (call-interactively 'git-link-commit))
(call-interactively 'git-link-commit))) (call-interactively 'git-link-commit)))
(defun haskell-intero/insert-type ()
(interactive)
(intero-type-at :insert))
(defun haskell-intero/display-repl (&optional prompt-options)
(interactive "P")
(let ((buffer (intero-repl-buffer prompt-options)))
(unless (get-buffer-window buffer 'visible)
(display-buffer buffer))))
(defun haskell-intero/pop-to-repl (&optional prompt-options)
(interactive "P")
(pop-to-buffer (intero-repl-buffer prompt-options)))
(defun haskell-intero//preserve-focus (f &rest args)
(let ((buffer (current-buffer)))
(apply f args)
(pop-to-buffer buffer)))
(defun helm-gtags-dwim-other-window () (defun helm-gtags-dwim-other-window ()
;; Enable helm-gtags-dwim in the other window ;; Enable helm-gtags-dwim in the other window
(interactive) (interactive)
@ -810,8 +785,6 @@
(haskell-process-suggest-remove-import-lines t))) (haskell-process-suggest-remove-import-lines t)))
(use-package flycheck-haskell (use-package flycheck-haskell
:defer t) :defer t)
(use-package intero
:defer t)
(use-package hindent (use-package hindent
:defer t) :defer t)
(use-package hlint-refactor (use-package hlint-refactor