File: setitems.cc

package info (click to toggle)
bisonc%2B%2B 6.09.02-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 5,984 kB
  • sloc: cpp: 9,375; ansic: 1,505; fortran: 1,134; makefile: 1,062; sh: 526; yacc: 84; lex: 60
file content (73 lines) | stat: -rw-r--r-- 2,694 bytes parent folder | download | duplicates (6)
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
#include "state.ih"

//  Walk over all state items. See the tables below for an explanation
//
//  Production rules of N-symbols following the dot-position (e.g., S, L, R) 
//  are added to d_itemVector.
//
//  Each of these N symbols will be added to the state's d_nextVector (unless
//  it's already there).
//
//  If the symbol N is already in d_nextVector (addDependent()): 
//      1. the index of the item containing N (e.g., 0 for S, 1 for L) is
//          added to d_nextVector
//      2 the index of the N symbol in d_nextVector (e.g., 0 for S) is stored
//          in the itemVector's element containing the production rule of the N
//          symbol (for S: offset in d_next in d_itemVector[0] is 0).
//      3. the indices of all stateitems starting at N are stored in d_child:
//          these items depend on the item having N at dot (e.g., for S: 1, 2)
//
//  If the symbol is a new symbol (addNext()):
//      1. The N symbol's d_itemVector element's d_next offset is given the
//          size of d_nextVector (e.g., for S: 0, since there's no d_next
//          yet. In general: d_nextVector's size is the index of the next
//          element to be added to d_nextVector.
//      2. a new element is added to d_nextVector, containing the symbol, the
//          items's stateType, and the item's index in d_itemVector (e.g., for
//          S: Next(S, 0, type)
//
//  Terminal symbols will simply be added to d_nextVector, together with their
//  d_itemVector offsets (as they don't have production rules)
//
//  StateItems (in d_itemVector):
//  ------------------------------------------------------------
//  item            LA-set  dependent   offet in 
//                          stateitems  d_next
//  ------------------------------------------------
//  S* -> . S,      EOF,    (1, 2)      0
//  S  -> . L = R           (3,  )      1
//  S  -> . R
//  L  -> . * R
//  ... (etc)
//  ------------------------------------------------
//
//  Moreover, the Next vector will be adapted:
//
//  Next (in d_nextVector)
//  -------------------------------
//  On          next    next kernel
//  Symbol      state   from items
//  -------------------------------
//  S           ?       (0, 1)
//  L
//  R
//  *
//  ...
//  -------------------------------


void State::setItems()
{
    size_t idx = 0;                 // do not use a for stmnt here, as
                                    // notReducible may extend d_itemVector

    while (idx < d_itemVector.size())
    {
        if (d_itemVector[idx].isReducible())
            d_reducible.push_back(idx);
        else
            notReducible(idx);

        ++idx;              // inspect the next element
    }   
}