Extract advice functions for core-eval
This commit is contained in:
parent
ca517d9df5
commit
bdf9616f80
3 changed files with 92 additions and 43 deletions
|
@ -22,26 +22,14 @@
|
||||||
(def-popup! "*quickrun*" :align below :size 10)
|
(def-popup! "*quickrun*" :align below :size 10)
|
||||||
|
|
||||||
;;; Popup hacks
|
;;; Popup hacks
|
||||||
(defun doom*quickrun-close-popup (&optional _ _ _ _)
|
|
||||||
"Allows us to re-run quickrun from inside the quickrun buffer."
|
|
||||||
(let ((buffer (get-buffer quickrun/buffer-name))
|
|
||||||
window)
|
|
||||||
(when buffer
|
|
||||||
(setq window (get-buffer-window buffer))
|
|
||||||
(shut-up! (quickrun/kill-running-process))
|
|
||||||
(doom/popup-close window nil t))))
|
|
||||||
(advice-add 'quickrun :before 'doom*quickrun-close-popup)
|
(advice-add 'quickrun :before 'doom*quickrun-close-popup)
|
||||||
(advice-add 'quickrun-region :before 'doom*quickrun-close-popup)
|
(advice-add 'quickrun-region :before 'doom*quickrun-close-popup)
|
||||||
|
;; Ensures window is scrolled to BOF
|
||||||
(defun doom|quickrun-after-run ()
|
|
||||||
"Ensures window is scrolled to BOF"
|
|
||||||
(with-selected-window (get-buffer-window quickrun/buffer-name)
|
|
||||||
(goto-char (point-min))))
|
|
||||||
(add-hook 'quickrun-after-run-hook 'doom|quickrun-after-run))
|
(add-hook 'quickrun-after-run-hook 'doom|quickrun-after-run))
|
||||||
|
|
||||||
(use-package repl-toggle
|
(use-package repl-toggle
|
||||||
:commands (rtog/toggle-repl rtog/add-repl)
|
:commands (rtog/toggle-repl rtog/add-repl)
|
||||||
:preface (defvar rtog/mode-repl-alist nil)
|
:preface (defvar rtog/mode-repl-alist nil)
|
||||||
:init
|
:init
|
||||||
(defvar doom-repl-buffer nil "The current REPL buffer.")
|
(defvar doom-repl-buffer nil "The current REPL buffer.")
|
||||||
(add-hook! repl-toggle-mode (evil-initialize-state 'emacs))
|
(add-hook! repl-toggle-mode (evil-initialize-state 'emacs))
|
||||||
|
@ -95,36 +83,8 @@
|
||||||
;; TODO does this work with shackle?
|
;; TODO does this work with shackle?
|
||||||
(advice-add 'realgud-cmdbuf-init :after 'doom:def-debug-on)
|
(advice-add 'realgud-cmdbuf-init :after 'doom:def-debug-on)
|
||||||
(advice-add 'realgud:cmd-quit :after 'doom:def-debug-off)
|
(advice-add 'realgud:cmd-quit :after 'doom:def-debug-off)
|
||||||
|
|
||||||
;; Monkey-patch `realgud:run-process' to run in a popup.
|
;; Monkey-patch `realgud:run-process' to run in a popup.
|
||||||
;; TODO Find a more elegant advice-based solution
|
(advice-add 'realgud:run-process :override 'doom*realgud:run-process))
|
||||||
;; FIXME Causes realgud:cmd-* to focus popup on every invocation
|
|
||||||
(defun realgud:run-process(debugger-name script-filename cmd-args minibuffer-history &optional no-reset)
|
|
||||||
(let ((cmd-buf))
|
|
||||||
(setq cmd-buf
|
|
||||||
(apply 'realgud-exec-shell debugger-name script-filename
|
|
||||||
(car cmd-args) no-reset (cdr cmd-args)))
|
|
||||||
(let ((process (get-buffer-process cmd-buf)))
|
|
||||||
(if (and process (eq 'run (process-status process)))
|
|
||||||
(progn
|
|
||||||
(pop-to-buffer cmd-buf)
|
|
||||||
(define-key evil-emacs-state-local-map (kbd "ESC ESC") 'doom/debug-quit)
|
|
||||||
(realgud:track-set-debugger debugger-name)
|
|
||||||
(realgud-cmdbuf-info-in-debugger?= 't)
|
|
||||||
(realgud-cmdbuf-info-cmd-args= cmd-args)
|
|
||||||
(when cmd-buf
|
|
||||||
(switch-to-buffer cmd-buf)
|
|
||||||
(when realgud-cmdbuf-info
|
|
||||||
(let* ((info realgud-cmdbuf-info)
|
|
||||||
(cmd-args (realgud-cmdbuf-info-cmd-args info))
|
|
||||||
(cmd-str (mapconcat 'identity cmd-args " ")))
|
|
||||||
(set minibuffer-history
|
|
||||||
(list-utils-uniq (cons cmd-str (eval minibuffer-history))))))))
|
|
||||||
;; else
|
|
||||||
(progn
|
|
||||||
(if cmd-buf (switch-to-buffer cmd-buf))
|
|
||||||
(message "Error running command: %s" (mapconcat 'identity cmd-args " ")))))
|
|
||||||
cmd-buf)))
|
|
||||||
|
|
||||||
(provide 'core-eval)
|
(provide 'core-eval)
|
||||||
;;; core-eval.el ends here
|
;;; core-eval.el ends here
|
||||||
|
|
|
@ -79,5 +79,21 @@ elisp buffer). Otherwise forward the region to Quickrun."
|
||||||
(insert (current-kill 0)))))
|
(insert (current-kill 0)))))
|
||||||
(t (quickrun-replace-region beg end))))
|
(t (quickrun-replace-region beg end))))
|
||||||
|
|
||||||
|
;;;###autoload
|
||||||
|
(defun doom*quickrun-close-popup (&optional _ _ _ _)
|
||||||
|
"Allows us to re-run quickrun from inside the quickrun buffer."
|
||||||
|
(let ((buffer (get-buffer quickrun/buffer-name))
|
||||||
|
window)
|
||||||
|
(when buffer
|
||||||
|
(setq window (get-buffer-window buffer))
|
||||||
|
(shut-up! (quickrun/kill-running-process))
|
||||||
|
(doom/popup-close window nil t))))
|
||||||
|
|
||||||
|
;;;###autoload
|
||||||
|
(defun doom|quickrun-after-run ()
|
||||||
|
"Ensures window is scrolled to BOF"
|
||||||
|
(with-selected-window (get-buffer-window quickrun/buffer-name)
|
||||||
|
(goto-char (point-min))))
|
||||||
|
|
||||||
(provide 'defuns-quickrun)
|
(provide 'defuns-quickrun)
|
||||||
;;; defuns-quickrun.el ends here
|
;;; defuns-quickrun.el ends here
|
||||||
|
|
73
core/defuns/defuns-realgud.el
Normal file
73
core/defuns/defuns-realgud.el
Normal file
|
@ -0,0 +1,73 @@
|
||||||
|
;;; defuns-realgud.el
|
||||||
|
|
||||||
|
;; TODO Find a more elegant solution
|
||||||
|
;; FIXME Causes realgud:cmd-* to focus popup on every invocation
|
||||||
|
;;;###autoload
|
||||||
|
(defun doom*realgud:run-process (debugger-name script-filename cmd-args minibuffer-history &optional no-reset)
|
||||||
|
(let ((cmd-buf))
|
||||||
|
(setq cmd-buf
|
||||||
|
(apply 'realgud-exec-shell debugger-name script-filename
|
||||||
|
(car cmd-args) no-reset (cdr cmd-args)))
|
||||||
|
(let ((process (get-buffer-process cmd-buf)))
|
||||||
|
(if (and process (eq 'run (process-status process)))
|
||||||
|
(progn
|
||||||
|
(pop-to-buffer cmd-buf)
|
||||||
|
(define-key evil-emacs-state-local-map (kbd "ESC ESC") 'doom/debug-quit)
|
||||||
|
(realgud:track-set-debugger debugger-name)
|
||||||
|
(realgud-cmdbuf-info-in-debugger?= 't)
|
||||||
|
(realgud-cmdbuf-info-cmd-args= cmd-args)
|
||||||
|
(when cmd-buf
|
||||||
|
(switch-to-buffer cmd-buf)
|
||||||
|
(when realgud-cmdbuf-info
|
||||||
|
(let* ((info realgud-cmdbuf-info)
|
||||||
|
(cmd-args (realgud-cmdbuf-info-cmd-args info))
|
||||||
|
(cmd-str (mapconcat 'identity cmd-args " ")))
|
||||||
|
(set minibuffer-history
|
||||||
|
(list-utils-uniq (cons cmd-str (eval minibuffer-history))))))))
|
||||||
|
;; else
|
||||||
|
(progn
|
||||||
|
(if cmd-buf (switch-to-buffer cmd-buf))
|
||||||
|
(message "Error running command: %s" (mapconcat 'identity cmd-args " ")))))
|
||||||
|
cmd-buf))
|
||||||
|
|
||||||
|
|
||||||
|
;;;###autoload (autoload 'doom:debug-toggle-breakpoint "defuns-realgud" nil t)
|
||||||
|
(evil-define-command doom:debug-toggle-breakpoint (&optional bang)
|
||||||
|
(interactive "<!>")
|
||||||
|
(call-interactively (if bang 'realgud:cmd-clear 'realgud:cmd-break)))
|
||||||
|
|
||||||
|
;;;###autoload
|
||||||
|
(defun doom/debug-quit ()
|
||||||
|
(interactive)
|
||||||
|
(ignore-errors (call-interactively 'realgud:cmd-quit))
|
||||||
|
(doom/popup-close)
|
||||||
|
(evil-normal-state))
|
||||||
|
|
||||||
|
;;;###autoload (autoload 'doom:debug "defuns-realgud" nil t)
|
||||||
|
(evil-define-command doom:debug (&optional path)
|
||||||
|
"Initiate debugger for current major mode"
|
||||||
|
(interactive "<f>")
|
||||||
|
(let ((default-directory (doom/project-root)))
|
||||||
|
(cond ((memq major-mode '(c-mode c++-mode))
|
||||||
|
(realgud:gdb (if path (concat "gdb " path))))
|
||||||
|
((memq major-mode '(ruby-mode enh-ruby-mode))
|
||||||
|
(doom:repl nil (format "run '%s'" (f-filename (or path buffer-file-name)))))
|
||||||
|
((eq major-mode 'sh-mode)
|
||||||
|
(let ((shell sh-shell))
|
||||||
|
(when (string= shell "sh")
|
||||||
|
(setq shell "bash"))
|
||||||
|
(cond ((string= shell "bash")
|
||||||
|
(realgud:bashdb (if path (concat "bashdb " path))))
|
||||||
|
((string= shell "zsh")
|
||||||
|
(realgud:zshdb (if path (concat "zshdb " path))))
|
||||||
|
(t (user-error "No shell debugger for %s" shell)))))
|
||||||
|
;; TODO Add python debugging
|
||||||
|
((memq major-mode '(js-mode js2-mode js3-mode))
|
||||||
|
(realgud:trepanjs))
|
||||||
|
((eq major-mode 'haskell-mode)
|
||||||
|
(haskell-debug))
|
||||||
|
(t (user-error "No debugger for %s" major-mode)))))
|
||||||
|
|
||||||
|
|
||||||
|
(provide 'defuns-realgud)
|
||||||
|
;;; defuns-realgud.el ends here
|
Loading…
Add table
Add a link
Reference in a new issue