DOS shell scripts are known as batch files. A conventional DOS batch file that outputs “Hello, World!” has the following contents:
echo Hello, World!
It uses the DOS command echo
. The batch file is
named hello.bat
, which identifies it to the
operating system as an executable. It may then be
placed in one of the directories on the PATH
environment variable. Thereafter, anytime one types
hello.bat
or simply
hello
at the DOS prompt, one promptly gets the insufferable greeting.
A Scheme version of the hello batch file will perform
the same output using Scheme, but we need something in
the file to inform DOS that it needs to construe the
commands in the file as Scheme, and not as its default
batch language. The Scheme batch file, also called
hello.bat
, looks like:
;@echo off ;goto :start #| :start echo. > c:\_temp.scm echo (load (find-executable-path "hello.bat" >> c:\_temp.scm echo "hello.bat")) >> c:\_temp.scm mzscheme -r c:\_temp.scm %1 %2 %3 %4 %5 %6 %7 %8 %9 goto :eof |# (display "Hello, World!") (newline) ;:eof
The lines upto |#
are standard DOS batch. Then
follows the Scheme code for the greeting. Finally,
there is one more standard DOS batch line, viz.,
;:eof
.
When the user types hello
at the DOS prompt, DOS
reads and runs the file hello.bat
as a regular
batch file. The first line, ;@echo off
, turns off
the echoing of the commands run — as we don’t want
excessive verbiage clouding the effect of our script.
The second line, ;goto :start
, causes execution to
jump forward to the line labeled :start
, i.e., the
fourth line. The three ensuing echo
lines create a
temporary Scheme file called c:\_temp.tmp
with the
following contents:
(load (find-executable-path "hello.bat" "hello.bat"))
The next batch command is a call to MzScheme. The
‑r
option loads the Scheme file c:\_temp.scm
.
All the arguments (in this example, none) will be
available to Scheme in the vector argv
. This call
to Scheme will evaluate our Scheme script, as we will
see below. After Scheme returns, we still need to
ensure that the batch file winds up cleanly. The next
batch command is goto :eof
, which causes
control to skirt all the Scheme code and go to the very
end of the file, which contains the label
;:eof
. The script thus ends.
Now we can see how the call to Scheme does its part,
viz., to run the Scheme expressions embedded in the
batch file. Loading c:\_temp.scm
will cause Scheme
to deduce the full pathname of the file hello.bat
(using find‑executable‑path
), and to then
load
hello.bat
.
Thus, the Scheme script file will now be run as a
Scheme file, and the Scheme forms in the file will have
access to the script’s original arguments via the
vector argv
.
Now, Scheme has to skirt the batch commands in the
script. This is easily done because these batch
commands are either prefixed with a semicolon or are
enclosed in #| ... |#
, making them Scheme comments.
The rest of the file is of course straight Scheme, and
the expressions therein are evaluated in sequence. (The
final expression, ;:eof
, is a Scheme comment, and
causes no harm.) After all the expressions have been
evaluated, Scheme will exit.
In sum, typing hello
at the DOS prompt will produce
Hello, World!
and return you to the DOS prompt.