X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=gacela.lisp;h=5d6eae05a4c8a96b5a288e8c6db34a99ae83eb13;hb=ca6a66c5bbd26fb490b563189bd292a7c7f5f8a0;hp=de3a3f886a848fee75beb12de1266fa5758bb080;hpb=cb537bf64e0effe6e8b43cb98e23936d1434a9fb;p=gacela.git diff --git a/gacela.lisp b/gacela.lisp index de3a3f8..5d6eae0 100644 --- a/gacela.lisp +++ b/gacela.lisp @@ -204,13 +204,19 @@ (maphash (lambda (key res) (free-resource key)) resources-table))) -;;; Connection with the GUI -(let (socket) - (defun connect-to-gui () - (setq socket (si::socket 1984 :host "localhost"))) +;;; Gacela Server for development mode +(let (socket clients) + (defun server-running? () + (if socket t nil)) - (defun eval-from-gui () - (cond ((and socket (listen socket)) (eval (read socket)))))) + (defun start-server (port) + (setq socket (si::socket port :server #'eval-from-client))) + + (defun check-server-connections () + (when (si::listen socket) (push (si:accept socket) clients))) + + (defun eval-from-clients () + (dolist (cli clients) (when (si::listen cli) (eval (read cli)))))) ;;; GaCeLa Functions