doomemacs/modules/feature/eval/autoload/eval.el

33 lines
1 KiB
EmacsLisp
Raw Normal View History

;;; feature/eval/autoload/eval.el -*- lexical-binding: t; -*-
2017-02-13 16:57:08 -05:00
;;;###autoload
2017-03-04 18:28:51 -05:00
(defun +eval/buffer ()
2017-02-13 16:57:08 -05:00
"Evaluate the whole buffer."
(interactive)
(cond ((assq major-mode +eval-runners-alist)
2017-03-04 18:28:51 -05:00
(+eval/region (point-min) (point-max)))
2017-02-13 16:57:08 -05:00
(t (quickrun))))
;;;###autoload
2017-03-04 18:28:51 -05:00
(defun +eval/region (beg end)
2017-02-13 16:57:08 -05:00
"Evaluate a region and, if large enough, prints its output to a popup buffer (if an
elisp buffer). Otherwise forward the region to Quickrun."
(interactive "r")
(let ((load-file-name buffer-file-name))
(if-let (runner (cdr (assq major-mode +eval-runners-alist)))
(funcall runner beg end)
(quickrun-region beg end))))
2017-02-13 16:57:08 -05:00
;;;###autoload
2017-03-04 18:28:51 -05:00
(defun +eval/region-and-replace (beg end)
2017-02-13 16:57:08 -05:00
(interactive "r")
(cond ((eq major-mode 'emacs-lisp-mode)
(kill-region beg end)
(condition-case nil
(prin1 (eval (read (current-kill 0)))
(current-buffer))
(error (message "Invalid expression")
(insert (current-kill 0)))))
(t (quickrun-replace-region beg end))))