Basic 7.00 Can Return Exit Code (Error Level) to Batch File (41533)
This article was previously published under Q41533
SUMMARY
MS-DOS batch processing (.BAT) files can use an "IF ERRORLEVEL n"
statement to detect exit code levels returned by some programs.
However, the only versions of Microsoft Basic that allow a program to
return an error level code to MS-DOS are Microsoft Basic Professional
Development System (PDS) versions 7.00 and 7.10. The END n or STOP n
statement returns error level n to the batch file that invoked the
Basic 7.00 or 7.10 .EXE program. The IF ERRORLEVEL n statement in the
batch file can detect if the returned exit code is equal to or greater
than n.
In all other versions of Microsoft Basic, the error level (exit) code
returned by a Basic program is controlled by the Basic run-time
module, not by your program. As an alternative, you can create a file
in the Basic program to serve as a flag when a certain condition
occurs. The batch file that called your program can then check for the
existence of the flag file in place of checking for an error level. In
batch files, the "IF EXIST filename" command can be used.
The following products do not allow your program to return an error
level to MS-DOS batch files:
- QuickBasic versions 1.00, 1.01, 1.02, 2.00, 2.01, 3.00, 4.00,
4.00b, and 4.50 for MS-DOS
- Microsoft GW-Basic versions 3.20, 3.22, and 3.23 for MS-DOS
- Microsoft Basic Compiler versions 5.35 and 5.36 for MS-DOS and
versions 6.00 and 6.00b for MS-DOS and MS OS/2
MORE INFORMATION
Your Basic program must not attempt to invoke any MS-DOS interrupts
(CALL INTERRUPT) to terminate the program with an error level;
otherwise, strange results may occur and the machine may hang. Basic
must handle program termination by itself.
Basic 7.00 or 7.10 Can Return Exit Code (ERRORLEVEL) to Batch File
An .EXE program compiled in Basic 7.00 or 7.10 can use the STOP n% or
END n% statement to return an exit code (n%) to MS-DOS, as follows:
' TEST.BAS
PRINT "This is a Basic program that returns an exit code of 5."
n% = 5
END n%
The exit code can be trapped in a MS-DOS batch file with the IF
ERRORLEVEL n GOTO statement, as follows:
TEST
ECHO OFF
IF NOT ERRORLEVEL 1 GOTO DONE
ECHO An error occurred with exit code 1 or higher.
:DONE
ECHO End of batch file.
Using a File as a Flag for a Batch File
The following technique lets any Basic version give a simple yes or no
message to a batch file.
The following batch file, ERRT.BAT, calls the Basic program ERRTST,
which drops back to the batch file. It then checks for the existence
of the file ERRFIL (which is an arbitrary name) to see if an error
occurred while running the Basic program:
echo off
del errfil
errtst
if not exist errfil goto end
echo An error occurred during program running
:end
echo End of batch file
The following file is ERRTST.BAS; it creates the error file if it
cannot open the file GARBAGE.DAT:
' set up to error out if "GARBAGE.DAT" does not exist
ON ERROR GOTO errorlevel
OPEN "garbage.dat" FOR INPUT AS #1
CLOSE #1
END
errorlevel:
CLOSE #1
OPEN "errfil" FOR OUTPUT AS #1 'Create file that acts as a flag
CLOSE #1
SYSTEM ' Returns to DOS.
To demonstrate this procedure, compile and link ERRTST.BAS as follows:
BC ERRTST.BAS;
LINK ERRTST.OBJ;
Now run the batch file ERRT.BAT. If the Basic program cannot find
GARBAGE.DAT, ERRT.BAT shows "An error occurred during program
running."
Modification Type: |
Minor |
Last Reviewed: |
1/9/2003 |
Keywords: |
KB41533 |
|