blob: 9e9904158da72bdb610959517fc139927fd144f3 [file] [log] [blame]
Barry Warsaw5947af52001-11-28 21:34:34 +00001
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002/* Grammar subroutines needed by parser */
3
Tim Peters1ca12962001-12-04 03:18:48 +00004#include "Python.h"
Guido van Rossum3f5da241990-12-20 15:06:42 +00005#include "pgenheaders.h"
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00006#include "grammar.h"
7#include "token.h"
8
9/* Return the DFA for the given type */
10
11dfa *
Antoine Pitrou9ed5f272013-08-13 20:18:52 +020012PyGrammar_FindDFA(grammar *g, int type)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000013{
Antoine Pitrou9ed5f272013-08-13 20:18:52 +020014 dfa *d;
Guido van Rossum6522eb01994-09-09 11:11:39 +000015#if 1
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000016 /* Massive speed-up */
17 d = &g->g_dfa[type - NT_OFFSET];
18 assert(d->d_type == type);
19 return d;
Guido van Rossum6522eb01994-09-09 11:11:39 +000020#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000021 /* Old, slow version */
Antoine Pitrou9ed5f272013-08-13 20:18:52 +020022 int i;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000023
24 for (i = g->g_ndfas, d = g->g_dfa; --i >= 0; d++) {
25 if (d->d_type == type)
26 return d;
27 }
Barry Warsawb2e57942017-09-14 18:13:16 -070028 Py_UNREACHABLE();
Guido van Rossum6522eb01994-09-09 11:11:39 +000029#endif
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000030}
31
Benjamin Peterson742b2f82012-10-31 13:36:13 -040032const char *
Thomas Wouters23c9e002000-07-22 19:20:54 +000033PyGrammar_LabelRepr(label *lb)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000034{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000035 static char buf[100];
36
37 if (lb->lb_type == ENDMARKER)
38 return "EMPTY";
39 else if (ISNONTERMINAL(lb->lb_type)) {
40 if (lb->lb_str == NULL) {
41 PyOS_snprintf(buf, sizeof(buf), "NT%d", lb->lb_type);
42 return buf;
43 }
44 else
45 return lb->lb_str;
46 }
Christian Heimes53d2dc42013-07-22 10:30:14 +020047 else if (lb->lb_type < N_TOKENS) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000048 if (lb->lb_str == NULL)
49 return _PyParser_TokenNames[lb->lb_type];
50 else {
51 PyOS_snprintf(buf, sizeof(buf), "%.32s(%.32s)",
52 _PyParser_TokenNames[lb->lb_type], lb->lb_str);
53 return buf;
54 }
55 }
Christian Heimes53d2dc42013-07-22 10:30:14 +020056 else {
57 Py_FatalError("invalid label");
Christian Heimes1eb0cb12013-07-22 16:34:13 +020058 return NULL;
Christian Heimes53d2dc42013-07-22 10:30:14 +020059 }
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000060}