This script is used to debug an Tcl Script and print errors to BWSPOOL message window. You to enter the name of the Script to be tested in a Text-type tag named TestScriptname. Note that ACTION commands do not usually return errors. The catch commands displays errors by the built-in Tcl KEYWORD commands. Note that a Tcl script can debug only another Tcl script. Tcl can not debug VB Script or JScript.
The JScript version is at 12.14.8 Display errors (Debug a JScript).
The VB Script version is at 12.17.8 Display errors (Debug a VB Script)
# DebugTclScript.scr - a Tcl script
# Open Message spooler window
WINEXEC BWSPOOL.EXE
# Exit if it calls itself, it will loop endlessly
# trim blank characters
set scriptname [string trim [GETVAL TestScriptname]]
BWSPOOL "Requested script is "
BWSPOOL $scriptname
BWSPOOL "\r\n" #print Carriage return and line feed
if {$scriptname == "DebugTclScript.scr"} then {
BWSPOOL "don't call itself. Will create an endless loop."
return
}
# Run the script put errors in err
catch "SCREXEC [GETVAL TestScriptname]" err
if {[file exists [GETVAL TestScriptname]]} then {
#figure out if blank - No errors
set msglength [string length $err]
if {$msglength <= 0} then {
set err "No reported errors."
}
BWSPOOL $err
} else {
BWSPOOL "[GETVAL TestScriptname] ... File not found."
}
BWSPOOL "\r\n"
The following script calls your script (by replacing yourscript.scr with the name of your actual script. You will also need to create a Graphics Display with:
· Text Type Screen Tag, 70 characters long named:
text70.
· Rtext field on your graphic display connected to text70.
· A pushbutton with the keymacro <SCREXEC>@debug1.scr
· Name this script debug1.scr
Calls script yourscript.scr to be debugged with SCREXEC.
Traps errors with catch and displays if error updates variable err
Sets text values to error message for display
catch {SCREXEC yourscript.scr } err
SETVAL text70=$err
The following is another method to display an error in Advantech WebAccess/SCADA scripts
# runs script source.scr - traps and displays if error
# Failed. couldn't read file "sourcein.scr": no such file or
directory
# it splits the error in to two tags using the strung command. # Errors can be longer than 70 characters,
# the maximum text tag length.
if {[catch [list SCREXEC sourcein.scr] err]} {
SETVAL "text=Failed. $err "
SETVAL text50=[string range $err 61 112]
}
Another third version allows you to enter the name of the Script to be tested in a Text-type tag.
# This script calls whatever script is entered in text tag named SCRname
# the scr extension should be added
# SCRERR displays the error on a Display named ScriptTest.bgr
catch {
SCREXEC [GETVAL SCRname]
} err
SETVAL SCRERR=$err