(in-package "CLOG-TOOLS") (defclass clog-builder-repl (clog:clog-panel) ((package-div :reader package-div) (terminal :reader terminal))) (defun create-clog-builder-repl (clog-obj &key (hidden nil) (class nil) (html-id nil) (auto-place t)) (let ((panel (change-class (clog:create-div clog-obj :content "
" :hidden hidden :class class :html-id html-id :auto-place auto-place) 'clog-builder-repl))) (setf (slot-value panel 'package-div) (attach-as-child clog-obj "CLOGB3868568691" :clog-type 'clog:clog-form-element :new-id t)) (setf (slot-value panel 'terminal) (attach-as-child clog-obj "CLOGB3868568690" :clog-type 'clog-terminal:clog-terminal-element :new-id t)) (let ((target (terminal panel))) (declare (ignorable target)) (clog-terminal:attach-clog-terminal target :greetings "CLOG Builder REPL") (clog-terminal:prompt target "> ")) (clog-terminal:set-on-command (terminal panel) (lambda (target data) (declare (ignorable target data)) (multiple-value-bind (result new-package) (capture-eval data :clog-obj panel :eval-in-package (text-value (package-div panel))) (setf (text-value (package-div panel)) (string-downcase (package-name new-package))) (clog-terminal:echo target result)))) panel))