X-Git-Url: https://code.consxy.com/gitweb/gitweb.cgi?a=blobdiff_plain;f=src%2Fmain%2Fmain.lisp;h=09244a02229c2f11e8c54799557cef8dae6985a3;hb=82888b4;hp=70be24dfa7f0f2beafe2ce72ab7ae5fdc35f72b5;hpb=213ed30b45140af3f34b7e003aa60394178d524c;p=clnl diff --git a/src/main/main.lisp b/src/main/main.lisp index 70be24d..09244a0 100644 --- a/src/main/main.lisp +++ b/src/main/main.lisp @@ -1,5 +1,26 @@ (in-package #:clnl) +(defvar *model-package* (find-package :cl-user) + "*MODEL-PACKAGE* + +VALUE TYPE: + + a package + +INITIAL VALUE: + + The common-lisp-user package + +DESCRIPTION: + + *MODEL-PACKAGE* is used for interning symbols as a NetLogo code + gets compiled. + + Any local symbols are interned in this package, for use either + by other code, or in order to have all symbols interned in the + same placakge. This is also the package in which a model should + be run, whether by clnl code or independently.") + (defun e (ast) ast) (defun r (str) @@ -43,7 +64,12 @@ DESCRIPTION: is set so that multiple runs will evaluate to the same. When FILE is not provided, a default model is used." - (eval (model->lisp (if file (with-open-file (str file) (clnl-model:read-from-nlogo str)) (clnl-model:default-model))))) + (let + ((netlogoed-lisp + (model->lisp + (if file (with-open-file (str file) (clnl-model:read-from-nlogo str)) (clnl-model:default-model)))) + (*package* *model-package*)) + (eval netlogoed-lisp))) (defun run-commands (cmds) "RUN-COMMANDS CMDS => RESULT @@ -77,7 +103,8 @@ DESCRIPTION: ; The intention of this method is to generate the common lisp equivalent of a model file, ; such that if you decided to no longer use nlogo, you could use the engine without it. (defun model->lisp (model) - `(progn + `(let + ,(clnl-model:globals model) (clnl-random:set-seed 15) ; should the seed always be 15? - (clnl-nvm:create-world ,model) - (clnl-interface:initialize ,model))) + (clnl-nvm:create-world :dims ',(clnl-model:world-dimensions model)) + (clnl-interface:initialize :dims ',(clnl-model:world-dimensions model))))