Machine-independent Macro-Processor Features.
The design of macro processor doesn’t depend on the architecture of the machine. We will be
studying some extended feature for this macro processor. These features are:
● Concatenation of Macro Parameters
● Generation of unique labels
● Conditional Macro Expansion
● Keyword Macro Parameters
1. Concatenation of Macro parameters:
● Most macro processor allows parameters to be concatenated with other character strings.
Suppose that a program contains a series of variables named by the symbols XA1, XA2,
XA3,…, another series of variables named XB1, XB2, XB3,…, etc. If similar processing
is to be performed on each series of labels, the programmer might put this as a macro
instruction.
● The parameter to such a macro instruction could specify the series of variables to be
operated on (A, B, etc.). The macro processor would use this parameter to construct the
symbols required in the macro expansion (XA1, XB1, etc.
● Suppose that the parameter to such a macro instruction is named &ID. The body of the
macro definition might contain a statement like
▪ LDA X&ID1
● & is the starting character of the macro instruction; but the end of the parameter is not
marked. So in the case of &ID1, the macro processor could deduce the meaning that was
intended.
● If the macro definition contains &ID and &ID1 as parameters, the situation would be
unavoidably ambiguous.
● Most of the macro processors deal with this problem by providing a special concatenation
operator. In the SIC macro language, this operator is the character →. Thus the statement
LDA X&ID1 can be written as
LDA X&ID→1
● The above figure shows a macro definition that uses the concatenation operator as previously
described. The statement SUM A and SUM BETA shows the invocation statements and the
corresponding macro expansion.
2. Generation of Unique Labels
● it is not possible to use labels for the instructions in the macro definition, since every expansion
of macro would include the label repeatedly which is not allowed by the assembler.
● We can use the technique of generating unique labels for every macro invocation and
expansion.
● During macro expansion each $ will be replaced with $XX, where xx is a two- character
alphanumeric counter of the number of macro instructions expansion.
For example,
XX = AA, AB, AC…
This allows 1296 macro expansions in a single program.
The following program shows the macro definition with labels to the instruction.
The following figure shows the macro invocation and expansion first time.
● If the macro is invoked second time the labels may be expanded as $ABLOOP $ABEXIT.
3. Conditional Macro Expansion
o IF ELSE
o WHILE loop
● We can modify the sequence of statements generated for a macro expansion depending on
conditions.
IF ELSE ENDIF structure
● Consider the following example.
● Here the definition of RDBUFF has two additional parameters. &EOR(end of record )
&MAXLTH(maximum length of the record that can be read)
● The macro processor directive SET – The statement assigns a value 1 to &EORCK and &EORCK
is known as macrotime variable. A macrotime variable is used to store working values during the
macro expansion. Any symbol that begins with & and that is not a macro instruction parameter is
assumed to be a macro time variable. All such variables are initialized to a value 0.
● Implementation of Conditional macro expansion- Macro processor maintains a symbol table that
contains the values of all macrotime variables used. Entries in this table are made when SET
statements are processed. The table is used to look up the current value of the variable.
● Testing of Boolean expression in IF statement occurs at the time macros are expanded. By the time
the program is assembled all such decisions are made and conditional macro instruction directives
are removed.
● IF statements are different from COMPR which test data values during program expansion.
Looping-WHILE
● Consider the following example.
● Here the programmer can specify a list of end of record characters.
● In the macro invocation statement there is a list(00,03,04) corresponding to the parameter &EOR.
Any one of these characters is to be considered as end of record.
● The WHILE statement specifies that the following lines until the next ENDW are to be generated
repeatedly as long as the condition is true.
● The testing of these condition and the looping are done while the macro is being expanded.
The conditions do not contain any runtime values.
● %NITEMS is a macroprocessor function that returns as its value the number of members in an
argument list. Here it has the value 3. The value of &CTR is used as a subscript to select the proper
member of the list for each iteration of the loop. &EOR[&CTR] takes the values 00,03,04 .
● Implementation- When a WHILE statement is encountered during a macro expansion the specified
Boolean expression is evaluated , if the value is false the macroprocessor skips ahead in DEFTAB
until it finds the ENDW and then resumes normal macro expansion(not at run time).
4. Keyword Macro Parameters
● All the macro instruction definitions used positional parameters. Parameters and
arguments are matched according to their positions in the macro prototype and the
macro invocation statement.
● The programmer needs to be careful while specifying the arguments. If an argument
is to be omitted the macro invocation statement must contain a null argument
mentioned with two commas.
● Positional parameters are suitable for the macro invocation. But if the macro
invocation has large number of parameters, and if only few of the values need to be
used in a typical invocation, a different type of parameter specification is required.
● Eg: Consider the macro GENER which has 10 parameters, but in a particular
invocation of a macro only the third and nineth parameters are to be specified. If
positional parameters are used the macro invocation will look like
GENER , , DIRECT, , , , , , 3,
● But using keyword parameters this problem can be solved. We can write
GENER TYPE=DIRECT, CHANNEL=3
Keyword parameters
● Each argument value is written with a keyword that names the corresponding
parameter.
● Arguments may appear in any order.
● Null arguments no longer need to be used.
● It is easier to read and much less error-prone than the positional method.
Macro Processor Design Options
1. Recursive Macro Expansion
● We have seen an example of the definition of one macro instruction by another. But we have
not dealt with the invocation of one macro by another. The following example shows the
invocation of one macro by another macro.
Problem of Recursive Expansion
● Previous macro processor design cannot handle such kind of recursive macro
invocation and expansion
o The procedure EXPAND would be called recursively, thus the invocation
arguments in the ARGTAB will be overwritten.
o The Boolean variable EXPANDING would be set to FALSE when the “inner”
macro expansion is finished, i.e., the macro process would forget that it had
been in the middle of expanding an “outer” macro.
The procedure EXPAND would be called when the macro was recognized. The arguments
from the macro invocation would be entered into ARGTAB as follows:
Parame Value
ter
1 BUFFE
R
2 LENG
TH
3 F1
4 (unused
)
- -
The Boolean variable EXPANDING would be set to TRUE, and expansion of the macro
invocation statement would begin. The processing would proceed normally until statement
invoking RDCHAR is processed.
This time, ARGTAB would look like
Value
Paramet
er
1 F1
2 (Unuse
d)
-- --
At the expansion, when the end of RDCHAR is recognized, EXPANDING would be
set to FALSE. Thus the macro processor would ‘forget’ that it had been in the middle of
expanding a macro when it encountered the RDCHAR statement. In addition, the arguments
from the original macro invocation (RDBUFF) would be lost because the value in ARGTAB
was overwritten with the arguments from the invocation of RDCHAR.
● Solutions
o Write the macro processor in a programming language that allows recursive
calls, thus local variables will be retained.
o If you are writing in a language without recursion support, use a stack to take
care of pushing and popping local variables and return addresses.
2. General-Purpose Macro Processors
● Macro processors that do not dependent on any particular programming language,
but can be used with a variety of different languages
● Pros
o Programmers do not need to learn many macro languages.
o Although its development costs are somewhat greater than those for a
language specific macro processor, this expense does not need to be repeated
for each language, thus save substantial overall cost.
● Cons
o Large number of details must be dealt with in a real programming language
▪ Situations in which normal macro parameter substitution should not
occur, e.g., comments.
▪ Facilities for grouping together terms, expressions, or statements. Eg: some
languages use begin and end . Some use { and }
▪ Tokens, e.g., identifiers, constants, operators, keywords
▪ Syntax used for macro definition and macro invocation statement is
different.
3. Macro Processing within Language Translators
● The macro processors we discussed are called “Preprocessors”.
o Process macro definitions
o Expand macro invocations
o Produce an expanded version of the source program, which is then used as input
to an assembler or compiler
● You may also combine the macro processing functions with the language translator:
o Line-by-line macro processor
o Integrated macro processor
Line-by-Line Macro Processor
● Used as a sort of input routine for the assembler or compiler
o Read source program
o Process macro definitions and expand macro invocations
o Pass output lines to the assembler or compiler
● Benefits
o Avoid making an extra pass over the source program.
o Data structures required by the macro processor and the language translator can be
combined (e.g., OPTAB and NAMTAB)
o Utility subroutines can be used by both macro processor and the language
translator.
▪ Scanning input lines
▪ Searching tables
▪ Data format conversion
o It is easier to give diagnostic messages related to the source statements
Integrated Macro Processor
● An integrated macro processor can potentially make use of any information about the source
program that is extracted by the language translator.
o Ex (blanks are not significant in FORTRAN)
▪ DO 100 I = 1,20
● a DO statement
▪ DO 100 I = 1
● An assignment statement
● DO100I: variable (blanks are not significant in FORTRAN)
● An integrated macro processor can support macro instructions that depend upon the
context in which they occur.
● Disadvantages- They must be specially designed and written to work with a particular
implementation of an assembler or compiler.. Cost of development is high.