chiark
/
gitweb
/
~mdw
/
lisp
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
gitignore: Ignore CLisp FASL files.
[lisp]
/
sys-base.lisp
diff --git
a/sys-base.lisp
b/sys-base.lisp
index 440facfaa68d7d5c9d87d99bbad6b15a70a2eb6e..b1e3595a973cff10b82673e2ea8b18e81e75f85c 100644
(file)
--- a/
sys-base.lisp
+++ b/
sys-base.lisp
@@
-26,33
+26,45
@@
(defpackage #:mdw.runlisp
(:use #:common-lisp #+cmu #:extensions)
(:export #:*lisp-interpreter* #:*command-line-strings*))
(defpackage #:mdw.runlisp
(:use #:common-lisp #+cmu #:extensions)
(:export #:*lisp-interpreter* #:*command-line-strings*))
+(in-package #:mdw.runlisp)
+
+#+clisp
+(progn
+ (defvar *lisp-interpreter*)
+ (defvar *command-line-strings*)
+ (let ((args (coerce (ext:argv) 'list)))
+ (setf *lisp-interpreter* (car args))
+ (setf *command-line-strings* (nthcdr 7 args))))
+
(defpackage #:mdw.sys-base
(defpackage #:mdw.sys-base
- (:use #:common-lisp #+cmu #:extensions #:mdw.runlisp)
- (:export #:exit #:hard-exit #:*program-name* #:*command-line-strings*))
+ (:use #:common-lisp #+cmu #:extensions #+cmu #:mdw.runlisp)
+ (:export #:exit #:hard-exit #:*program-name* #:*command-line-strings*)
+ (:import-from #:mdw.runlisp #:*lisp-interpreter* #:*command-line-strings*)
+ #+clisp (:import-from #:ext #:exit))
(in-package #:mdw.sys-base)
;;; --- This is currently all a bit CMUCL-specific ---
(in-package #:mdw.sys-base)
;;; --- This is currently all a bit CMUCL-specific ---
-#+
cmu
+#+
(or cmu)
(defun exit (&optional (code 0))
"Polite way to end a program. If running in an interactive Lisp, just
return to the top-level REPL."
(defun exit (&optional (code 0))
"Polite way to end a program. If running in an interactive Lisp, just
return to the top-level REPL."
- (if *batch-mode*
- (throw 'lisp::%end-of-the-world code)
+ (if
#+cmu
*batch-mode*
+
#+cmu
(throw 'lisp::%end-of-the-world code)
(progn
(unless (zerop code)
(format t "~&Exiting unsuccessfully with code ~D.~%" code))
(abort))))
(progn
(unless (zerop code)
(format t "~&Exiting unsuccessfully with code ~D.~%" code))
(abort))))
-#+cmu
(defun hard-exit (&optional (code 0))
"Stops the program immediately in its tracks. Does nothing else. Use
after fork, for example, to avoid flushing buffers."
(declare (type (unsigned-byte 32) code))
(defun hard-exit (&optional (code 0))
"Stops the program immediately in its tracks. Does nothing else. Use
after fork, for example, to avoid flushing buffers."
(declare (type (unsigned-byte 32) code))
- (unix::void-syscall ("_exit" c-call:int) code))
+ #+cmu (unix::void-syscall ("_exit" c-call:int) code)
+ #+clisp (ext:quit code))
-#+cmu
-
(defvar *program-name*
(pathname-name (car *command-line-strings*))
+(defvar *program-name*
+
(pathname-name (car *command-line-strings*))
"A plausible guess at the program's name, stripped of strange extensions.")
;;;----- That's all, folks --------------------------------------------------
"A plausible guess at the program's name, stripped of strange extensions.")
;;;----- That's all, folks --------------------------------------------------