Skip to content


Subversion checkout URL

You can clone with
Download ZIP
Fetching contributors…
Cannot retrieve contributors at this time
181 lines (155 sloc) 6.97 KB
;;; helm-eval.el --- eval expressions from helm.
;; Copyright (C) 2012 Thierry Volpiatto <>
;; This program is free software; you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation, either version 3 of the License, or
;; (at your option) any later version.
;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; GNU General Public License for more details.
;; You should have received a copy of the GNU General Public License
;; along with this program. If not, see <>.
;;; Code:
(eval-when-compile (require 'cl))
(require 'helm)
(require 'eldoc)
(defgroup helm-eval nil
"Eval related Applications and libraries for Helm."
:group 'helm)
(defcustom helm-c-eldoc-in-minibuffer-show-fn
"A function to display eldoc info.
Should take one arg: the string to display."
:group 'helm-eval
:type 'symbol)
(defcustom helm-c-show-info-in-mode-line-delay 12
"Eldoc will show info in mode-line during this delay if user is idle."
:type 'integer
:group 'helm-eval)
(declare-function eldoc-current-symbol "eldoc")
(declare-function eldoc-get-fnsym-args-string "eldoc" (sym &optional index))
(declare-function eldoc-get-var-docstring "eldoc" (sym))
(declare-function eldoc-fnsym-in-current-sexp "eldoc")
;;; Evaluation Result
;; Internal
(defvar helm-eldoc-active-minibuffers-list nil)
(defvar helm-eval-expression-input-history nil)
(defvar helm-eval-expression-map
(let ((map (make-sparse-keymap)))
(set-keymap-parent map helm-map)
(define-key map (kbd "<C-return>") 'helm-eval-new-line-and-indent)
(define-key map (kbd "<tab>") 'lisp-indent-line)
(define-key map (kbd "<C-tab>") 'lisp-complete-symbol)
(define-key map (kbd "C-p") 'previous-line)
(define-key map (kbd "C-n") 'next-line)
(define-key map (kbd "<up>") 'previous-line)
(define-key map (kbd "<down>") 'next-line)
(define-key map (kbd "<right>") 'forward-char)
(define-key map (kbd "<left>") 'backward-char)
(defvar helm-c-source-evaluation-result
'((name . "Evaluation Result")
(mode-line . "C-RET: nl-and-indent, tab: reindent, C-tab:complete, C-p/n: next/prec-line.")
(filtered-candidate-transformer . (lambda (candidates source)
(condition-case nil
(eval (read helm-pattern))))
(error "Error")))))
(action . (("Copy result to kill-ring" . (lambda (candidate)
(with-current-buffer helm-buffer
(let ((end (save-excursion
(goto-char (point-max))
(search-backward "\n")
(kill-region (point) end)))))
("copy sexp to kill-ring" . (lambda (candidate)
(kill-new helm-input)))))))
(defun helm-eval-new-line-and-indent ()
(newline) (lisp-indent-line))
(defun helm-eldoc-store-minibuffer ()
"Store minibuffer buffer name in `helm-eldoc-active-minibuffers-list'."
(with-selected-window (minibuffer-window)
(push (buffer-name) helm-eldoc-active-minibuffers-list)))
(defun helm-eldoc-show-in-eval ()
"Return eldoc in mode-line for current minibuffer input."
(let ((buf (with-selected-window (minibuffer-window)
(when (member buf helm-eldoc-active-minibuffers-list)
(let* ((str-all (with-current-buffer buf
(sym (when str-all
(insert str-all)
(goto-char (point-max))
(unless (looking-back ")\\|\"") (forward-char -1))
(info-fn (eldoc-fnsym-in-current-sexp))
(doc (or (eldoc-get-var-docstring sym)
(car info-fn) (cadr info-fn)))))
(when doc (funcall helm-c-eldoc-in-minibuffer-show-fn doc))))))
(defun helm-c-show-info-in-mode-line (str)
"Display string STR in mode-line."
(with-current-buffer helm-buffer
(let ((mode-line-format (concat " " str)))
(sit-for helm-c-show-info-in-mode-line-delay))
;;; Calculation Result
(defvar helm-c-source-calculation-result
'((name . "Calculation Result")
(filtered-candidate-transformer . (lambda (candidates source)
(condition-case nil
(calc-eval helm-pattern)
(error "error")))))
(action ("Copy result to kill-ring" . kill-new))))
(defun helm-eval-expression (arg)
"Preconfigured helm for `helm-c-source-evaluation-result'."
(interactive "P")
(helm :sources 'helm-c-source-evaluation-result
:input (when arg (thing-at-point 'sexp))
:buffer "*helm eval*"
:history 'helm-eval-expression-input-history
:keymap helm-eval-expression-map))
(defun helm-eval-expression-with-eldoc ()
"Preconfigured helm for `helm-c-source-evaluation-result' with `eldoc' support. "
(declare (special eldoc-idle-delay))
(let ((timer (run-with-idle-timer eldoc-idle-delay
'repeat 'helm-eldoc-show-in-eval))
(minibuffer-completing-symbol t) ; Enable lisp completion.
(completion-cycle-threshold t)) ; Always cycle, (emacs24* only).
(call-interactively 'helm-eval-expression))
(and timer (cancel-timer timer))
(setq helm-eldoc-active-minibuffers-list
(cdr helm-eldoc-active-minibuffers-list)))))
(defun helm-calcul-expression ()
"Preconfigured helm for `helm-c-source-calculation-result'."
(helm-other-buffer 'helm-c-source-calculation-result "*helm calcul*"))
(provide 'helm-eval)
;; Local Variables:
;; coding: utf-8
;; indent-tabs-mode: nil
;; byte-compile-dynamic: t
;; End:
;;; helm-eval.el ends here
Jump to Line
Something went wrong with that request. Please try again.