mirror of
https://github.com/rabbibotton/clog.git
synced 2025-12-06 10:40:45 -08:00
127 lines
4.3 KiB
Common Lisp
127 lines
4.3 KiB
Common Lisp
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;;;; CLOG - The Common Lisp Omnificent GUI ;;;;
|
|
;;;; (c) 2020-2022 David Botton ;;;;
|
|
;;;; License BSD 3 Clause ;;;;
|
|
;;;; ;;;;
|
|
;;;; clog-helpers.lisp ;;;;
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
;;; Various helpers for CLOG
|
|
|
|
(cl:in-package :clog)
|
|
|
|
(defpackage #:clog-user
|
|
(:use #:cl #:clog))
|
|
|
|
(defpackage #:clog-tools
|
|
(:use #:cl #:clog #:clog-gui #:clog-web)
|
|
(:export :clog-builder
|
|
:add-supported-controls
|
|
:control-info
|
|
:clog-db-admin))
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;; Implementation - CLOG Utilities
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
(defvar clog-user::*body* nil "clog-repl access to body")
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;
|
|
;; clog-install-dir ;;
|
|
;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
(defun clog-install-dir ()
|
|
"Return the directory CLOG was installed in."
|
|
(asdf:system-source-directory :clog))
|
|
|
|
;;;;;;;;;;;;;;;;;
|
|
;; open-manual ;;
|
|
;;;;;;;;;;;;;;;;;
|
|
|
|
(defun open-manual ()
|
|
"Launches a browser with CLOG manual."
|
|
(open-browser :url (format nil "~A"
|
|
(merge-pathnames "./doc/clog-manual.html"
|
|
(asdf:system-source-directory :clog)))))
|
|
|
|
;;;;;;;;;;;;;;;;;;
|
|
;; run-tutorial ;;
|
|
;;;;;;;;;;;;;;;;;;
|
|
|
|
(defun run-tutorial (num)
|
|
"Run tutorial NUM"
|
|
(load-tutorial num)
|
|
(funcall (symbol-function (find-symbol
|
|
"START-TUTORIAL"
|
|
(format nil "CLOG-TUT-~A" num)))))
|
|
|
|
;;;;;;;;;;;;;;;;;;;
|
|
;; load-tutorial ;;
|
|
;;;;;;;;;;;;;;;;;;;
|
|
|
|
(defun load-tutorial (num)
|
|
"Load tutorial NUM - use (clog-user:start-tutorial)"
|
|
(let ((p (merge-pathnames (format nil "./tutorial/~2,'0d-tutorial.lisp" num)
|
|
(asdf:system-source-directory :clog))))
|
|
(load p)
|
|
(format t "~%~% ---- The tutorial src is located at: ~A~%" p)))
|
|
|
|
;;;;;;;;;;;;;;
|
|
;; run-demo ;;
|
|
;;;;;;;;;;;;;;
|
|
|
|
(defun run-demo (num)
|
|
"Run demo NUM"
|
|
(load-demo num)
|
|
(funcall (symbol-function (find-symbol
|
|
"START-DEMO"
|
|
(format nil "CLOG-DEMO-~A" num)))))
|
|
|
|
;;;;;;;;;;;;;;;
|
|
;; load-demo ;;
|
|
;;;;;;;;;;;;;;;
|
|
|
|
(defun load-demo (num)
|
|
"Load demo NUM - use (clog-user:start-demo)"
|
|
(let ((p (merge-pathnames (format nil "./demos/~2,'0d-demo.lisp" num)
|
|
(asdf:system-source-directory :clog))))
|
|
(load p)
|
|
(format t "~%~% ---- The demo src is located at: ~A~%" p)))
|
|
|
|
;;;;;;;;;;;;;;;
|
|
;; clog-repl ;;
|
|
;;;;;;;;;;;;;;;
|
|
|
|
(defun clog-repl (&key (clog-gui-initialize t) (clog-web-initialize t))
|
|
"Set a path /repl that opens a blank page and sets the global
|
|
clog-user:*body* to last window openned to /repl. Debug mode is
|
|
set (logging to browser console), "
|
|
(unless *clog-running*
|
|
(initialize nil :boot-file "/debug.html"))
|
|
(set-on-new-window (lambda (body)
|
|
(clog-connection:debug-mode (connection-id body))
|
|
(when clog-web-initialize
|
|
(clog-web:clog-web-initialize body))
|
|
(when clog-gui-initialize
|
|
(clog-gui:clog-gui-initialize body))
|
|
(setf clog-user::*body* body))
|
|
:path "/repl")
|
|
(open-browser :url "http://127.0.0.1:8080/repl")
|
|
(format t "Use clog-user:*body* to access the clog-repl window."))
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;
|
|
;; save-body-to-file ;;
|
|
;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
(defun save-body-to-file (file-name &key (body clog-user::*body*)
|
|
(if-exists :error)
|
|
if-does-not-exist
|
|
external-format)
|
|
"Save the current html of BODY in the current state to FILE-NAME"
|
|
(when (alexandria:write-string-into-file
|
|
(outer-html (document-element (html-document body)))
|
|
file-name
|
|
:if-exists if-exists
|
|
:if-does-not-exist if-does-not-exist
|
|
:external-format external-format)
|
|
t))
|