Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

A 'SET EXECTRAC ON' command inside an EXEC does not turn on interactive trace #53

Open
BobBolch opened this issue Dec 12, 2020 · 8 comments
Labels
bug Something isn't working

Comments

@BobBolch
Copy link
Collaborator

Tracing is turned on, but not interactive trace.
The VM EXEC processor turns on interactive trace when this command is issued within an EXEC.
Also a 'SET EXECTRAC OFF' command runs the following command instead of turning tracing off.

I don't know when checks are made, but if tracing is off at the begining of a statement (after being turned
off in the previous statenment, then the statement should not be traced.

This is low priority. I recommend we get a release out to VM users before starting work on this.

Test case:

/* /
address ''
'SET EXECTRAC ON'
/
Test data */
rec.1 = '01234567890 $678901234567890123456789012345 '
rec.2 = '901234567890 45678901234567890123456789012345 '
rec.3 = '8901234567890 345678901234567890123456789012345 '
rec.4 = '78901234567890 $345678901234567890123456789012345 '
rec.5 = '67890123456789012345678901234567890123456789012345'
rec.6 = '78901234567890 2345678901234567890123456789012345 '
'SET EXECTRAC OFF'
rec.7 = '8901234567890 $45678901234567890123456789012345 '
rec.8 = '$01234567890 45678901234567890123456789012345 '
rec.9 = '01234567890 5678901234567890123456789012345 '
rec.0 = 9
say 'TEST EXEC ended'

******************************************************* on VM/370:
test
6 - rec.2 = '901234567890 45678901234567890123456789012345 '
7 - rec.3 = '8901234567890 345678901234567890123456789012345 '
8 - rec.4 = '78901234567890 $345678901234567890123456789012345 '
9 - rec.5 = '67890123456789012345678901234567890123456789012345'
10 - rec.6 = '78901234567890 2345678901234567890123456789012345 '
11 - 'SET EXECTRAC OFF'
12 - rec.7 = '8901234567890 $45678901234567890123456789012345 '
TEST EXEC ended
Ready; T=0.01/0.01 08:00:03

******************************************************* on z/VM:
test
4 - /* Test data */
5 - rec.1 = '01234567890 $678901234567890123456789012345 '
>>> "01234567890 $678901234567890123456789012345 "
+++ Interactive trace. TRACE OFF to end debug, ENTER to continue. +++
(Press ENTER)
6 - rec.2 = '901234567890 45678901234567890123456789012345 '
>>> "901234567890 45678901234567890123456789012345 "

 7 *-* rec.3 = '8901234567890  345678901234567890123456789012345  '         
   >>>   "8901234567890  345678901234567890123456789012345  "               
                                                                            
 8 *-* rec.4 = '78901234567890 $345678901234567890123456789012345 '         
   >>>   "78901234567890 $345678901234567890123456789012345 "               
                                                                            
 9 *-* rec.5 = '67890123456789012345678901234567890123456789012345'         
   >>>   "67890123456789012345678901234567890123456789012345"               
                                                                            
10 *-* rec.6 = '78901234567890 2345678901234567890123456789012345 '         
   >>>   "78901234567890 2345678901234567890123456789012345 "               
                                                                            
11 *-* 'SET EXECTRAC OFF'                                                   
   >>>   "SET EXECTRAC OFF"  
     TEST EXEC ended              

Ready; T=0.01/0.01 07:59:35

@adesutherland
Copy link
Owner

Two Issues

  • The check to trace seems to be after the next command
  • changing to trace should turn on interactive tracing.

Also - at the moment BREXX checks the flag on each command but actually it only needs checking on start-up and after an external command (slight performance opportunity - as it is in the inner loop).

@adesutherland adesutherland added the bug Something isn't working label Dec 13, 2020
@BobBolch
Copy link
Collaborator Author

By 'command', do you mean host command?
CMS REXX behaves differently, with more frequent checks. Checking one bit is cheap, and not a performance concern.

First, REXX defines a clause this way:
REXX clauses can be instructions, null clauses, and labels. Instructions can be keyword instructions, assignments, or commands.

Here is the description of trace behavior from the book.


The System External Trace Bit:

Before each clause is run, an external trace bit, owned by CMS, is inspected. You can turn the bit on with the TS immediate command, and turn it off with the TE immediate command. You can also alter the bit by using the SET EXECTRAC command (described later). CMS itself never alters this bit, except that it is cleared on return to CMS command level.

The language processor maintains an internal shadow of the external bit, which therefore allows it to detect when the external bit changes from a 0 to a 1, or vice-versa. If the language processor sees the bit change from 0 to 1, ? (interactive debug) is forced on and the tracing action is forced to R if it is A, C, E, F, L, N, or O. The tracing action is left unchanged if it is I, R, or S.

Similarly, if the shadow bit changes from 1 to 0, all tracing is forced off. This means that tracing may be controlled externally to the REXX program: you can switch on interactive debug at any time without modifying the program. The TE command can be useful if a program is tracing clauses without being in interactive debug (that is, after SET EXECTRAC ON, TRACE ? was issued). You can use TE to switch off the tracing without affecting any other output from the program.

If the external bit is on upon entry to a REXX program, the SOURCE string is traced (see PARSE) and interactive debug is switched on as usual—hence with use of the system trace bit, tracing of a program and all programs called from it, can be easily controlled.

The internal shadow bit is saved and restored across internal routine calls. This means that (as with internally controlled tracing) it is possible to turn tracing on or off locally within a subroutine. It also means that if a TS interrupt occurs during execution of a subroutine, tracing is also switched on upon RETURN to the caller.

You can use the CMSFLAG(EXECTRAC) function and the command QUERY EXECTRAC to test the setting of the system trace bit.

The command SET EXECTRAC ON turns on the trace bit. Using it before invoking a REXX program causes the program to be entered with debug tracing immediately active. If issued from inside a program, SET EXECTRAC ON has the same effect as TRACE ?R (unless TRACE I or S is in effect), but is more global in that all programs called are traced, too. The command SET EXECTRAC OFF turns the trace bit off. Issuing this when the bit is on is equivalent to the instruction TRACE O, except that it has a system (global) effect.

@adesutherland
Copy link
Owner

Note to self - need to check if external flag is brought into BREXX after a command

@BobBolch
Copy link
Collaborator Author

BobBolch commented Jan 30, 2021 via email

@BobBolch
Copy link
Collaborator Author

When you say 'command', do you mean REXX clause or host CMS command?

@adesutherland
Copy link
Owner

adesutherland commented Jan 31, 2021 via email

@BobBolch
Copy link
Collaborator Author

BobBolch commented Jan 31, 2021 via email

@BobBolch
Copy link
Collaborator Author

BobBolch commented Feb 2, 2021 via email

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

2 participants