2017-03-04 18:28:51 -05:00
|
|
|
;;; feature/eval/autoload/build.el
|
2017-02-13 16:57:08 -05:00
|
|
|
|
2017-03-04 18:28:51 -05:00
|
|
|
(defvar-local +eval-last-builder nil
|
|
|
|
"The last builder run in the current buffer.")
|
2017-02-13 16:57:08 -05:00
|
|
|
|
2017-04-07 01:19:55 -04:00
|
|
|
(defvar +eval-current-builder nil
|
|
|
|
"The spec for the currently running builder. Available from inside builder
|
|
|
|
functions.")
|
|
|
|
|
2017-03-04 18:28:51 -05:00
|
|
|
(defun +eval--read-builder ()
|
2017-04-07 01:19:55 -04:00
|
|
|
(when-let (builders
|
|
|
|
(cl-remove-if-not
|
|
|
|
(lambda (plist)
|
|
|
|
(if-let (pred (plist-get plist :when))
|
|
|
|
(and (or (symbolp pred)
|
|
|
|
(functionp pred))
|
|
|
|
(funcall pred))
|
|
|
|
t))
|
|
|
|
(cl-delete-duplicates
|
|
|
|
(reverse (cdr (assq major-mode +eval-builders)))
|
|
|
|
:key 'car)
|
|
|
|
:key 'cdr))
|
|
|
|
(if (= (length builders) 1)
|
|
|
|
(car builders)
|
|
|
|
(when-let (builder (completing-read "Build: "
|
2017-04-17 02:17:10 -04:00
|
|
|
(mapcar #'car builders)
|
2017-04-07 01:19:55 -04:00
|
|
|
nil t))
|
|
|
|
(assq (intern builder) builders)))))
|
2017-02-13 16:57:08 -05:00
|
|
|
|
|
|
|
;;;###autoload
|
2017-04-07 01:19:55 -04:00
|
|
|
(defun +eval/build (builder)
|
2017-05-13 00:14:15 +02:00
|
|
|
"TODO"
|
2017-04-07 01:19:55 -04:00
|
|
|
(interactive
|
|
|
|
(list (or +eval-last-builder
|
|
|
|
(+eval--read-builder)
|
|
|
|
(error "No builder for this buffer"))))
|
2017-03-04 18:28:51 -05:00
|
|
|
(unless builder
|
2017-04-07 01:19:55 -04:00
|
|
|
(error "Builder not found in registered builders"))
|
|
|
|
(let* ((name (car builder))
|
|
|
|
(plist (cdr builder))
|
|
|
|
(fn (plist-get plist :fn)))
|
|
|
|
(message "Running %s" name)
|
|
|
|
(if (or (functionp fn)
|
|
|
|
(and (symbolp fn) (fboundp fn)))
|
|
|
|
(let ((+eval-current-builder builder))
|
|
|
|
(funcall fn))
|
|
|
|
(error "'%s' builder is invalid" name))))
|
2017-02-13 16:57:08 -05:00
|
|
|
|