ack/lang/pc/comp/program.g

78 lines
1.3 KiB
Text
Raw Normal View History

1988-10-26 15:21:11 +00:00
/* The grammar of ISO-Pascal as given by the specification, BS6192: 1982. */
{
#include <alloc.h>
#include <em_arith.h>
#include <em_label.h>
1990-12-11 13:52:08 +00:00
#include <em_code.h>
#include <stb.h>
1988-10-26 15:21:11 +00:00
#include "LLlex.h"
#include "def.h"
1989-05-03 10:30:22 +00:00
#include "f_info.h"
#include "idf.h"
1988-10-26 15:21:11 +00:00
#include "main.h"
#include "node.h"
#include "scope.h"
#include "dbsymtab.h"
1988-10-26 15:21:11 +00:00
}
%lexical LLlex;
%start LLparse, Program;
/* ISO section 6.10, p. 137 */
Program
{
struct def *df;
1989-05-03 10:30:22 +00:00
arith dummy;
1988-10-26 15:21:11 +00:00
}:
1990-12-11 13:52:08 +00:00
ProgramHeading(&df)
';' Block(df) '.'
{
#ifdef DBSYMTAB
if (options['g']) {
1990-12-11 13:52:08 +00:00
C_ms_stb_cst(df->df_idf->id_text, N_MAIN, 0, (arith) 0);
stb_string(df, D_END);
}
#endif /* DBSYMTAB */
1990-12-11 13:52:08 +00:00
}
1989-05-03 10:30:22 +00:00
| { df = new_def();
df->df_idf = str2idf(FileName, 1);
df->df_kind = D_MODULE;
open_scope();
GlobalScope = CurrentScope;
df->prc_vis = CurrVis;
}
Module(df, &dummy)
1988-10-26 15:21:11 +00:00
;
ProgramHeading(register struct def **df;):
PROGRAM IDENT
{ program = *df = new_def();
(*df)->df_idf = dot.TOK_IDF;
(*df)->df_kind = D_PROGRAM;
open_scope();
GlobalScope = CurrentScope;
(*df)->prc_vis = CurrVis;
#ifdef DBSYMTAB
1990-12-11 13:52:08 +00:00
if (options['g']) stb_string(*df, D_MODULE);
#endif /* DBSYMTAB */
1988-10-26 15:21:11 +00:00
}
[
'('
ProgramParameters
')'
1989-05-03 10:30:22 +00:00
{ make_extfl(); }
1988-10-26 15:21:11 +00:00
]?
;
ProgramParameters
{
struct node *Proglist;
}:
IdentifierList(&Proglist)
{ EnterProgList(Proglist); }
;