Next: Exercise 9.
Up: Final-2003
Previous: Exercise 7.
Some languages such as PL1 permit a list of names to be given a list of attributes.
The grammar G below abstracts the problem.
D |
data:image/s3,"s3://crabby-images/afd25/afd25009062cf0b93d96bbbd7346de6e2de43d79" alt="$\displaystyle \longmapsto$" |
namelist attriblistdata:image/s3,"s3://crabby-images/71b36/71b367c5f2ab60cfbce5b9aad8609dbb9886ae89" alt="$\displaystyle \bf ;$" |
namelist |
data:image/s3,"s3://crabby-images/afd25/afd25009062cf0b93d96bbbd7346de6e2de43d79" alt="$\displaystyle \longmapsto$" |
, namelist |
namelist |
data:image/s3,"s3://crabby-images/afd25/afd25009062cf0b93d96bbbd7346de6e2de43d79" alt="$\displaystyle \longmapsto$" |
data:image/s3,"s3://crabby-images/1d433/1d4335dc5fc8d3fe53b4f178f07cbe7a68204855" alt="$\displaystyle \bf id$" |
attriblist |
data:image/s3,"s3://crabby-images/afd25/afd25009062cf0b93d96bbbd7346de6e2de43d79" alt="$\displaystyle \longmapsto$" |
A attriblist |
attriblist |
data:image/s3,"s3://crabby-images/afd25/afd25009062cf0b93d96bbbd7346de6e2de43d79" alt="$\displaystyle \longmapsto$" |
A |
A |
data:image/s3,"s3://crabby-images/afd25/afd25009062cf0b93d96bbbd7346de6e2de43d79" alt="$\displaystyle \longmapsto$" |
data:image/s3,"s3://crabby-images/cda1d/cda1dced9abd3d91f8ca45d89678849320477713" alt="$\displaystyle \bf long$" |
A |
data:image/s3,"s3://crabby-images/afd25/afd25009062cf0b93d96bbbd7346de6e2de43d79" alt="$\displaystyle \longmapsto$" |
data:image/s3,"s3://crabby-images/375a1/375a1f753631c6b40e6e8c836f87fd93b6770af2" alt="$\displaystyle \bf double$" |
A |
data:image/s3,"s3://crabby-images/afd25/afd25009062cf0b93d96bbbd7346de6e2de43d79" alt="$\displaystyle \longmapsto$" |
data:image/s3,"s3://crabby-images/730c6/730c6d0097bfc64f1e8d04e3f1576f348e3e5dac" alt="$\displaystyle \bf single$" |
A |
data:image/s3,"s3://crabby-images/afd25/afd25009062cf0b93d96bbbd7346de6e2de43d79" alt="$\displaystyle \longmapsto$" |
data:image/s3,"s3://crabby-images/00698/00698fa70ceda0dfb56b5a0193fc545560c12c17" alt="$\displaystyle \bf integer$" |
A |
data:image/s3,"s3://crabby-images/afd25/afd25009062cf0b93d96bbbd7346de6e2de43d79" alt="$\displaystyle \longmapsto$" |
data:image/s3,"s3://crabby-images/c38be/c38be70a0ab07ec0111f5f21fc60fcc3fa6accd6" alt="$\displaystyle \bf float$" |
|
|
where D, namelist,
attriblist and A are nonterminals
and where id, long, double, single, integer, float and ;
are terminals. As usual id is the identifier token.
For instance each of the following lines is a declaration
generated by G.
i, j single integer;
u, v, w double float;
Give a syntax-directed definition
for declarations generated by G.
Here are some hints.
- You may simply write N and T instead of namelist and
attriblist respectively.
- The code in the actions does not need to be C code but may be any pseudo-code
that is convenient to you.
- You may consider that id has an attribute
.name (as usual)
giving the lexical value of id.
- Moreover you may assume that every variable in the symbol table may be
associated with a list of attributes by an instruction like
enter(
.name, T.list)
- The instruction T.list := makelist(A.attrib) will
create the list consisting of the single item A.attrib.
- The instruction T.list := cons(A.attrib, T.list) will
add the element A.attrib at the beginning of the list T.list.
Answer 8
data:image/s3,"s3://crabby-images/d2215/d22152ceca1db1b7ee688d9d88dfd073567ffa7d" alt="\fbox{
\begin{minipage}{12 cm}
\mbox{ } \\
\mbox{ } \\
\mbox{ } \\
\mbox{ } \...
...\mbox{ } \\
\mbox{ } \\
\mbox{ } \\
\mbox{ } \\
\mbox{ } \\
\end{minipage}}"
Next: Exercise 9.
Up: Final-2003
Previous: Exercise 7.
Marc Moreno Maza
2004-12-02