/usr/include/styx/prs_gen.h is in styx-dev 2.0.1-1build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 | /* ------------------------------------------------------------------------ */
/* */
/* [prs_gen.h] LALR(1) Parser Generator */
/* */
/* Copyright (c) 1993 by D\olle, Manns */
/* ------------------------------------------------------------------------ */
/* File generated by 'ctoh'. Don't change manually. */
#ifndef prs_gen_INCL
#define prs_gen_INCL
#include "prs_dfn.h"
#ifdef __cplusplus
extern "C" {
#endif
/*
<p>The module [prs_gen] performs two main tasks.
<p>1) A set of functions will be used to dynamically create a BNF-like context
free grammar definition. ( reentrant )
<br>It is possible to define multiple startsymbols and comment tokens.
<p>2) The latter function create the corresponding parse table and nonterminal
classes.
The parse table is the input for the <a href="prs.htm">parse function</a>.
<br>This creation process is not reentrant. You must synchronize the access
to the function within threads.
*/
/*
The following rules define the abstract syntax. On this base the nonterminal
classes are created.
A) well-formed productions:
1. let X :nil#* : <0 members>
2. let X :cons#*: Y Z <2 members: Y = member && Z = nonterminal>
3. let X :ign#+ : Y <1 nonterminal>
4. let X :name : X1 .. Xn <n >= 0 && name =/= { ign#+, nil#*, cons#* }>
Extension for options (styx version >= 1):
5. let X :none : <0 members>
6. let X :some : Y <1 member>
7. let X :name : X1 .. Xn <n >= 0 && name =/= { ign#+, nil#*, cons#*, none, some }>
B) construction of the token/nonterminal classes:
1. X <=> X reflexiv
2. X <=> Y --> Y <=> X symmetric
3. X <=> Y && Y <=> Z --> X <=> Z transitiv
4. let X :ign#+: Y --> X <=> Y
5. let X :cons#*: Y Z --> X <=> Z
6. X <=> Y && let X :idx: X1 .. Xn && let Y :idy: Y1 .. Ym && idx = idy
--> n = m && forall i, 1 <= i <= n: Type(Xi) = Type(Yi) && Xi <=> Yi,
where Type(Z) = { token, nonterminal }
7. all tokens are equivalent.
C) token/nonterminal classes:
[X] = { Y | Y <=> X }
class representants:
- tokens: "Tok"
- startsymbols: language name
- nonterminals: less nonterminal name according the lexical order
D) correctness:
1. X <=> Y --> Type(X) = Type(Y), where Type(Z) = { token, nonterminal }
2. let X^ :id: a && let X^ :id: b --> a <=> b
3. let X^ :nil#*: a || let X^ :cons#*: b
--> not exists P: P = let X^ :id: c && id =/= { ign#+, nil#*, cons#* }
[ 1,2: checked during construction ]
Extension for options (styx version >= 1):
4. let X^ :none: a || let X^ :some: b
--> not exists P: P = let X^ :id: c && id =/= { ign#+, none, some }
5. let X^ :none: a
--> exists P: P = let X^ :some: b
6. let X^ :some: a
--> exists P: P = let X^ :none: b
E) abstract context free grammar:
NT |--> NT^
T |--> T^ ( NT^ T^ are the class representants )
for all "normal" productions there will be one interface function
of type 'bool' which returns whether the argument term represents
a production of this kind and in the positive case all required members.
*/
/* ------------------------------ Types ------------------------------------- */
AbstractType(PLR_Cfg); /* Abstract context free grammar type */
/* ----------------------- Grammar definition ------------------------------- */
PLR_Cfg PLR_createCfg(c_string Language, int version)
/* creates a context free grammar definition named 'Language' */
;
int PLR_addTK(PLR_Cfg Cfg, c_string Token, int kind)
/* adds token 'Token' of type 'kind'
( token or keyword, see [cfg_dfn] )
to definition 'Cfg'
*/
;
int PLR_addNT(PLR_Cfg Cfg, c_string NonTerm, c_bool catchError)
/* adds nonterminal 'NonTerm' to definition 'Cfg'
catchError --> use 'NonTerm' as reparse point
*/
;
void PLR_endSD(PLR_Cfg Cfg)
/* symbol definition end;
completes token and nonterminal definition
*/
;
int PLR_addSN(PLR_Cfg Cfg, c_string StartNt)
/* adds startsymbol 'StartNt' to definition 'Cfg' */
;
int PLR_addST(PLR_Cfg Cfg, c_string SpecTk)
/* marks 'SpecTk' as special comment token */
;
int PLR_addPR(PLR_Cfg Cfg, c_string PName, int Method, c_string NonTerm)
/* adds production 'NonTerm'::'PName' with layout hint 'Method'
( default=0, see [prs_dfn] ) to definition 'Cfg'
*/
;
int PLR_addPT(PLR_Cfg Cfg, c_string Token, long sRow, long sCol)
/* adds (dynamic) token 'Token' to current production of definition 'Cfg';
The symbol position 'sRow', 'sCol' is used as layout hint.
*/
;
int PLR_addPD(PLR_Cfg Cfg, c_string Token, c_string DToken, long sRow, long sCol)
/* adds token 'Token' as dynamic Token 'DToken' to current production of definition 'Cfg';
The symbol position 'sRow', 'sCol' is used as layout hint.
*/
;
int PLR_addPK(PLR_Cfg Cfg, c_string Keyword, long sRow, long sCol)
/* adds keyword 'Keyword' to current production of definition 'Cfg';
The symbol position 'sRow', 'sCol' is used as layout hint.
*/
;
int PLR_addPN(PLR_Cfg Cfg, c_string NonTerm, long sRow, long sCol)
/* adds nonterminal 'NonTerm' to current production of definition 'Cfg';
The symbol position 'sRow', 'sCol' is used as layout hint.
*/
;
int PLR_addCCtx(PLR_Cfg Cfg, int StateIdx, c_string StateSym, c_string Token)
/* adds conflict context (state, token) to definition 'Cfg'
*/
;
int PLR_addCRule(PLR_Cfg Cfg, c_string NonTerm, c_string PName)
/* adds rule i.e. production 'NonTerm'::'PName' to current conflict of definition 'Cfg';
*/
;
void PLR_delCfg(PLR_Cfg Cfg); /* removes grammar definition 'Cfg' */
/* --------------------- Parse table creation ------------------------------- */
PLR_Tab PLR_createTab(PLR_Cfg Cfg, c_bool verbose, c_bool diagnose)
/* creates the corresponding parse table for definition 'Cfg'
'verbose' --> entertainment
'diagnose' --> print conflict / result informations
*/
;
PLR_Tab PLR_createTab_ex
(
PLR_Cfg Cfg, void (*prMsg)(c_string msg), c_bool verbose, c_bool diagnose
)
/* like PLR_createTab;
uses 'prMsg' as print function
*/
;
#ifdef __cplusplus
}
#endif
#endif
|