aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/ChangeLog7
-rw-r--r--src/lisp/core.lisp.in49
2 files changed, 38 insertions, 18 deletions
diff --git a/src/ChangeLog b/src/ChangeLog
index c208ab00..5864c9cb 100644
--- a/src/ChangeLog
+++ b/src/ChangeLog
@@ -1,5 +1,12 @@
2010-11-30 Gabriel Dos Reis <gdr@cs.tamu.edu>
+ * lisp/core.lisp.in (processCommandLine): Don't export.
+ Rewrite to pull out command line options wherever they are
+ except the ones after "--".
+ (topLevel): Bind *PACKAGE*; don't set it.
+
+2010-11-30 Gabriel Dos Reis <gdr@cs.tamu.edu>
+
* driver/utils.cc: Commonalize some of option handling code.
2010-11-30 Gabriel Dos Reis <gdr@cs.tamu.edu>
diff --git a/src/lisp/core.lisp.in b/src/lisp/core.lisp.in
index 89debd5e..d7a3268b 100644
--- a/src/lisp/core.lisp.in
+++ b/src/lisp/core.lisp.in
@@ -94,7 +94,6 @@
"getOptionValue"
"getCommandLineArguments"
- "processCommandLine"
"handleCommandLine"
"$originalLispTopLevel"
"link"
@@ -407,19 +406,34 @@
;; of the command line into a list. The processing stop as soon as
;; a non-option form is encountered. OPTIONS-SO-FAR accumulates the
;; the list of processed options.
-(defun |processCommandLine| (argv options-so-far)
- (if (and argv (>= (length (car argv)) 2)
- (equal "--" (subseq (car argv) 0 2)))
- (let ((option (|parseOption| (car argv))))
- (cond ((symbolp option)
- (|processCommandLine| (cdr argv)
- (cons (cons option t) options-so-far)))
- ((consp option)
- (|processCommandLine| (cdr argv) (cons option options-so-far)))
- (t (|internalError|
- (format nil "processCommandLine: unknown option ~S"
- option)))))
- (values options-so-far argv)))
+(defun |processCommandLine| (argv options-so-far args-so-far)
+ (cond ((null argv)
+ ;; no more command-line argument to process
+ (values options-so-far (nreverse args-so-far)))
+ ((equal "--" (car argv))
+ ;; end of command-line options
+ (values options-so-far (concatenate 'list
+ (nreverse args-so-far)
+ (cdr argv))))
+ ((or (< (length (car argv)) 2)
+ (not (equal "--" (subseq (car argv) 0 2))))
+ ;; not a command-line option
+ (|processCommandLine| (cdr argv)
+ options-so-far
+ (cons (car argv) args-so-far)))
+ (t (let ((option (|parseOption| (car argv))))
+ (cond ((symbolp option)
+ (|processCommandLine| (cdr argv)
+ (cons (cons option t)
+ options-so-far)
+ args-so-far))
+ ((consp option)
+ (|processCommandLine| (cdr argv)
+ (cons option options-so-far)
+ args-so-far))
+ (t (|internalError|
+ (format nil "processCommandLine: unknown option ~S"
+ option))))))))
;;
;; -*- Building New Lisp Images -*-
@@ -718,7 +732,6 @@
)
-
;;
;; -*- --help Handler -*-
;;
@@ -872,8 +885,8 @@
;; The top level entry point to most saved Lisp image.
(defun |topLevel|()
- (setq *package* (find-package "AxiomCore"))
- (let ((command-args (|getCommandLineArguments|)))
+ (let ((*package* (find-package "AxiomCore"))
+ (command-args (|getCommandLineArguments|)))
(when (null command-args)
(|internalError| "empty command line args"))
;; Existing system programming practive, and POSIX, have it
@@ -884,7 +897,7 @@
;; (1) either one of --help or --version, or
;; a filename.
(multiple-value-bind
- (options args) (|processCommandLine| (cdr command-args) nil)
+ (options args) (|processCommandLine| (cdr command-args) nil nil)
(setq |$sysOpts| options)
(setq |$sysArgs| args)