]>
git.saurik.com Git - bison.git/blob - src/lalr.c
e6738bdac55172a97d92f58c83ebde44d4ae5a18
   1 /* Compute look-ahead criteria for bison, 
   2    Copyright 1984, 1986, 1989, 2000, 2001  Free Software Foundation, Inc. 
   4    This file is part of Bison, the GNU Compiler Compiler. 
   6    Bison is free software; you can redistribute it and/or modify 
   7    it under the terms of the GNU General Public License as published by 
   8    the Free Software Foundation; either version 2, or (at your option) 
  11    Bison is distributed in the hope that it will be useful, 
  12    but WITHOUT ANY WARRANTY; without even the implied warranty of 
  13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 
  14    GNU General Public License for more details. 
  16    You should have received a copy of the GNU General Public License 
  17    along with Bison; see the file COPYING.  If not, write to 
  18    the Free Software Foundation, Inc., 59 Temple Place - Suite 330, 
  19    Boston, MA 02111-1307, USA.  */ 
  22 /* Compute how to make the finite state machine deterministic; find 
  23    which rules need lookahead in each state, and which lookahead 
  24    tokens they accept.  */ 
  36 /* All the decorated states, indexed by the state number.  Warning: 
  37    there is a state_TABLE in LR0.c, but it is different and static. 
  39 state_t 
*state_table 
= NULL
; 
  50 /* And for the famous F variable, which name is so descriptive that a 
  51    comment is hardly needed.  <grin>.  */ 
  52 static unsigned *F 
= NULL
; 
  53 #define F(Rule)  (F + (Rule) * tokensetsize) 
  55 static short **includes
; 
  56 static shorts 
**lookback
; 
  59 /*---------------------------------------------------------------. 
  60 | digraph & traverse.                                            | 
  62 | The following variables are used as common storage between the | 
  64 `---------------------------------------------------------------*/ 
  68 static short *VERTICES
; 
  78   size_t size 
= F (i 
+ 1) - F(i
); 
  81   INDEX
[i
] = height 
= top
; 
  84     for (j 
= 0; R
[i
][j
] >= 0; ++j
) 
  86         if (INDEX
[R
[i
][j
]] == 0) 
  89         if (INDEX
[i
] > INDEX
[R
[i
][j
]]) 
  90           INDEX
[i
] = INDEX
[R
[i
][j
]]; 
  92         for (k 
= 0; k 
< size
; ++k
) 
  93           F (i
)[k
] |= F (R
[i
][j
])[k
]; 
  96   if (INDEX
[i
] == height
) 
 105         for (k 
= 0; k 
< size
; ++k
) 
 112 digraph (short **relation
) 
 116   infinity 
= ngotos 
+ 2; 
 117   INDEX 
= XCALLOC (short, ngotos 
+ 1); 
 118   VERTICES 
= XCALLOC (short, ngotos 
+ 1); 
 123   for (i 
= 0; i 
< ngotos
; i
++) 
 126   for (i 
= 0; i 
< ngotos
; i
++) 
 127     if (INDEX
[i
] == 0 && R
[i
]) 
 135 /*--------------------. 
 136 | Build STATE_TABLE.  | 
 137 `--------------------*/ 
 140 set_state_table (void) 
 142   /* NSTATES + 1 because lookahead for the pseudo state number NSTATES 
 143      might be used (see conflicts.c).  It is too opaque for me to 
 144      provide a probably less hacky implementation. --akim */ 
 145   state_table 
= XCALLOC (state_t
, nstates 
+ 1); 
 149     for (sp 
= first_state
; sp
; sp 
= sp
->next
) 
 151         state_table
[sp
->number
].state 
= sp
; 
 152         state_table
[sp
->number
].accessing_symbol 
= sp
->accessing_symbol
; 
 158     for (sp 
= first_shift
; sp
; sp 
= sp
->next
) 
 159       state_table
[sp
->number
].shift_table 
= sp
; 
 164     for (rp 
= first_reduction
; rp
; rp 
= rp
->next
) 
 165       state_table
[rp
->number
].reduction_table 
= rp
; 
 168   /* Initializing the lookaheads members.  Please note that it must be 
 169      performed after having set some of the other members which are 
 170      used below.  Change with extreme caution.  */ 
 174     for (i 
= 0; i 
< nstates
; i
++) 
 177         reductions 
*rp 
= state_table
[i
].reduction_table
; 
 178         shifts 
*sp 
= state_table
[i
].shift_table
; 
 180         state_table
[i
].lookaheads 
= count
; 
 183             && (rp
->nreds 
> 1 || (sp 
&& SHIFT_IS_SHIFT (sp
, 0)))) 
 186           state_table
[i
].consistent 
= 1; 
 189           for (k 
= 0; k 
< sp
->nshifts
; k
++) 
 190             if (SHIFT_IS_ERROR (sp
, k
)) 
 192                 state_table
[i
].consistent 
= 0; 
 196      state_table
[nstates
].lookaheads 
= count
; 
 209   size_t nLA 
= state_table
[nstates
].lookaheads
; 
 213   LA 
= XCALLOC (unsigned, nLA 
* tokensetsize
); 
 214   LAruleno 
= XCALLOC (short, nLA
); 
 215   lookback 
= XCALLOC (shorts 
*, nLA
); 
 218   for (i 
= 0; i 
< nstates
; i
++) 
 219     if (!state_table
[i
].consistent
) 
 220       if ((rp 
= state_table
[i
].reduction_table
)) 
 221         for (j 
= 0; j 
< rp
->nreds
; j
++) 
 222           *np
++ = rp
->rules
[j
]; 
 237   goto_map 
= XCALLOC (short, nvars 
+ 1) - ntokens
; 
 238   temp_map 
= XCALLOC (short, nvars 
+ 1) - ntokens
; 
 241   for (sp 
= first_shift
; sp
; sp 
= sp
->next
) 
 243       for (i 
= sp
->nshifts 
- 1; i 
>= 0 && SHIFT_IS_GOTO (sp
, i
); --i
) 
 245           symbol 
= state_table
[sp
->shifts
[i
]].accessing_symbol
; 
 247           if (ngotos 
== MAXSHORT
) 
 248             fatal (_("too many gotos (max %d)"), MAXSHORT
); 
 256   for (i 
= ntokens
; i 
< nsyms
; i
++) 
 262   for (i 
= ntokens
; i 
< nsyms
; i
++) 
 263     goto_map
[i
] = temp_map
[i
]; 
 265   goto_map
[nsyms
] = ngotos
; 
 266   temp_map
[nsyms
] = ngotos
; 
 268   from_state 
= XCALLOC (short, ngotos
); 
 269   to_state 
= XCALLOC (short, ngotos
); 
 271   for (sp 
= first_shift
; sp
; sp 
= sp
->next
) 
 274       for (i 
= sp
->nshifts 
- 1; i 
>= 0 && SHIFT_IS_GOTO (sp
, i
); --i
) 
 276           state2 
= sp
->shifts
[i
]; 
 277           symbol 
= state_table
[state2
].accessing_symbol
; 
 279           k 
= temp_map
[symbol
]++; 
 280           from_state
[k
] = state1
; 
 281           to_state
[k
] = state2
; 
 285   XFREE (temp_map 
+ ntokens
); 
 290 /*----------------------------------------------------------. 
 291 | Map a state/symbol pair into its numeric representation.  | 
 292 `----------------------------------------------------------*/ 
 295 map_goto (int state
, int symbol
) 
 302   low 
= goto_map
[symbol
]; 
 303   high 
= goto_map
[symbol 
+ 1] - 1; 
 307       middle 
= (low 
+ high
) / 2; 
 308       s 
= from_state
[middle
]; 
 326   short **reads 
= XCALLOC (short *, ngotos
); 
 327   short *edge 
= XCALLOC (short, ngotos 
+ 1); 
 332   F 
= XCALLOC (unsigned, ngotos 
* tokensetsize
); 
 334   for (i 
= 0; i 
< ngotos
; i
++) 
 336       int stateno 
= to_state
[i
]; 
 337       shifts 
*sp 
= state_table
[stateno
].shift_table
; 
 342           for (j 
= 0; j 
< sp
->nshifts 
&& SHIFT_IS_SHIFT (sp
, j
); j
++) 
 344               int symbol 
= state_table
[sp
->shifts
[j
]].accessing_symbol
; 
 345               SETBIT (F 
+ i 
* tokensetsize
, symbol
); 
 348           for (; j 
< sp
->nshifts
; j
++) 
 350               int symbol 
= state_table
[sp
->shifts
[j
]].accessing_symbol
; 
 351               if (nullable
[symbol
]) 
 352                 edge
[nedges
++] = map_goto (stateno
, symbol
); 
 357               reads
[i
] = XCALLOC (short, nedges 
+ 1); 
 358               shortcpy (reads
[i
], edge
, nedges
); 
 359               reads
[i
][nedges
] = -1; 
 367   for (i 
= 0; i 
< ngotos
; i
++) 
 376 add_lookback_edge (int stateno
, int ruleno
, int gotono
) 
 383   i 
= state_table
[stateno
].lookaheads
; 
 384   k 
= state_table
[stateno 
+ 1].lookaheads
; 
 386   while (!found 
&& i 
< k
) 
 388       if (LAruleno
[i
] == ruleno
) 
 396   sp 
= XCALLOC (shorts
, 1); 
 397   sp
->next 
= lookback
[i
]; 
 404 matrix_print (FILE *out
, short **matrix
, int n
) 
 408   for (i 
= 0; i 
< n
; ++i
) 
 410       fprintf (out
, "%3d: ", i
); 
 412         for (j 
= 0; matrix
[i
][j
] != -1; ++j
) 
 413           fprintf (out
, "%3d ", matrix
[i
][j
]); 
 419 /*-------------------------------------------------------------------. 
 420 | Return the transpose of R_ARG, of size N.  Destroy R_ARG, as it is | 
 421 | replaced with the result.                                          | 
 423 | R_ARG[I] is NULL or a -1 terminated list of numbers.               | 
 425 | RESULT[NUM] is NULL or the -1 terminated list of the I such as NUM | 
 427 `-------------------------------------------------------------------*/ 
 430 transpose (short **R_arg
, int n
) 
 433   short **new_R 
= XCALLOC (short *, n
); 
 434   /* END_R[I] -- next entry of NEW_R[I]. */ 
 435   short **end_R 
= XCALLOC (short *, n
); 
 436   /* NEDGES[I] -- total size of NEW_R[I]. */ 
 437   short *nedges 
= XCALLOC (short, n
); 
 442       fputs ("transpose: input\n", stderr
); 
 443       matrix_print (stderr
, R_arg
, n
); 
 447   for (i 
= 0; i 
< n
; i
++) 
 449       for (j 
= 0; R_arg
[i
][j
] >= 0; ++j
) 
 450         ++nedges
[R_arg
[i
][j
]]; 
 453   for (i 
= 0; i 
< n
; i
++) 
 456         short *sp 
= XCALLOC (short, nedges
[i
] + 1); 
 463   for (i 
= 0; i 
< n
; i
++) 
 465       for (j 
= 0; R_arg
[i
][j
] >= 0; ++j
) 
 467           *end_R
[R_arg
[i
][j
]] = i
; 
 468           ++end_R
[R_arg
[i
][j
]]; 
 474   /* Free the input: it is replaced with the result. */ 
 475   for (i 
= 0; i 
< n
; i
++) 
 481       fputs ("transpose: output\n", stderr
); 
 482       matrix_print (stderr
, new_R
, n
); 
 490 build_relations (void) 
 492   short *edge 
= XCALLOC (short, ngotos 
+ 1); 
 493   short *states 
= XCALLOC (short, ritem_longest_rhs () + 1); 
 496   includes 
= XCALLOC (short *, ngotos
); 
 498   for (i 
= 0; i 
< ngotos
; i
++) 
 501       int state1 
= from_state
[i
]; 
 502       int symbol1 
= state_table
[to_state
[i
]].accessing_symbol
; 
 505       for (rulep 
= derives
[symbol1
]; *rulep 
> 0; rulep
++) 
 509           int stateno 
= state1
; 
 513           for (rp 
= ritem 
+ rule_table
[*rulep
].rhs
; *rp 
> 0; rp
++) 
 515               shifts 
*sp 
= state_table
[stateno
].shift_table
; 
 517               for (j 
= 0; j 
< sp
->nshifts
; j
++) 
 519                   stateno 
= sp
->shifts
[j
]; 
 520                   if (state_table
[stateno
].accessing_symbol 
== *rp
) 
 524               states
[length
++] = stateno
; 
 527           if (!state_table
[stateno
].consistent
) 
 528             add_lookback_edge (stateno
, *rulep
, i
); 
 536               /* JF added rp>=ritem &&   I hope to god its right! */ 
 537               if (rp 
>= ritem 
&& ISVAR (*rp
)) 
 539                   stateno 
= states
[--length
]; 
 540                   edge
[nedges
++] = map_goto (stateno
, *rp
); 
 550           includes
[i
] = XCALLOC (short, nedges 
+ 1); 
 551           for (j 
= 0; j 
< nedges
; j
++) 
 552             includes
[i
][j
] = edge
[j
]; 
 553           includes
[i
][nedges
] = -1; 
 560   includes 
= transpose (includes
, ngotos
); 
 566 compute_FOLLOWS (void) 
 572   for (i 
= 0; i 
< ngotos
; i
++) 
 580 compute_lookaheads (void) 
 585   for (i 
= 0; i 
< state_table
[nstates
].lookaheads
; i
++) 
 586     for (sp 
= lookback
[i
]; sp
; sp 
= sp
->next
) 
 588         int size 
= LA (i 
+ 1) - LA (i
); 
 590         for (j 
= 0; j 
< size
; ++j
) 
 591           LA (i
)[j
] |= F (sp
->value
)[j
]; 
 595   for (i 
= 0; i 
< state_table
[nstates
].lookaheads
; i
++) 
 596     LIST_FREE (shorts
, lookback
[i
]); 
 606   tokensetsize 
= WORDSIZE (ntokens
); 
 614   compute_lookaheads ();