doomemacs/core/defuns/defuns-repl.el

36 lines
1.2 KiB
EmacsLisp
Raw Normal View History

;;; defuns-repl.el
2016-05-20 22:37:30 -04:00
;;;###autoload (autoload 'doom:repl "defuns-repl" nil t)
(evil-define-command doom:repl (&optional bang command)
:repeat nil
2016-03-31 03:21:16 -04:00
(interactive "<!><a>")
2016-05-24 21:57:25 -04:00
(if (and doom-repl-buffer (buffer-live-p doom-repl-buffer))
(doom/popup-buffer doom-repl-buffer)
(rtog/toggle-repl (if (use-region-p) 4))
2016-05-24 21:57:25 -04:00
(setq doom-repl-buffer (current-buffer))
2016-03-31 03:21:16 -04:00
(when command
2016-05-24 21:57:25 -04:00
(with-current-buffer doom-repl-buffer
2016-03-31 03:21:16 -04:00
(insert command)
(unless bang (comint-send-input))))))
2016-05-20 22:37:30 -04:00
;;;###autoload (autoload 'doom:repl-eval "defuns-repl" nil t)
(evil-define-operator doom:repl-eval (&optional beg end bang)
:type inclusive
:repeat nil
(interactive "<r><!>")
(let ((region-p (use-region-p))
(selection (s-trim (buffer-substring-no-properties beg end))))
2016-05-20 22:37:30 -04:00
(doom:repl bang)
(when (and region-p beg end)
2016-05-24 21:57:25 -04:00
(let* ((buf doom-repl-buffer)
(win (get-buffer-window buf)))
2016-05-20 22:37:30 -04:00
(unless (eq buf (doom/popup-p (get-buffer-window buf)))
(doom/popup-buffer buf))
2016-05-24 21:57:25 -04:00
(when (and doom-repl-buffer (buffer-live-p doom-repl-buffer))
(with-current-buffer doom-repl-buffer
(goto-char (point-max))
(insert selection)))))))
(provide 'defuns-repl)
;;; defuns-repl.el ends here