XTRAN Example — Eliminate Dead PL/I Code
The following example uses a rule set written in XTRAN's rules language ("meta-code") that finds and suppresses every statement that is "dead" (cannot execute). The rules comprise 147 non-comment lines of meta-code.
NOTE that these rules are language-independent; they are exactly the same rules used for similar examples for other languages.
Strategy
- Use statement navigation facilities provided by XTRAN's rules language to follow every execution path through the code, and mark each visited statement as "live".
- Use recursive iterator facilities provided by XTRAN's rules language to visit every statement. If it is not marked "live", suppress its output.
Process Flowchart
Here is a flowchart for this process, in which the elements are color coded:
- BLUE for XTRAN versions (runnable programs)
- ORANGE for XTRAN rules (text files)
- RED for
code
Input to XTRAN
prc: PROCEDURE;
DCL i FIXED BIN (31);
IF i = 0 | i = 1 THEN
GOTO lbl2;
i = 1;
GOTO lbl3;
/*
* The following code is dead and should therefore be eliminated:
*/
IF i > 1 THEN
GOTO lbl1;
i = 2;
lbl1: i = 3;
GOTO lbl3;
/*
* The following statement is dead and should therefore be eliminated:
*/
i = 4;
lbl2: i = 4;
lbl3: i = 5;
END PRC;
Output from XTRAN
prc: PROCEDURE;
DECLARE i FIXED BINARY (31);
IF i = 0 | i = 1 THEN
GOTO lbl2;
i = 1;
GOTO lbl3;
lbl2: i = 4;
lbl3: i = 5;
END prc;