Module: ActiveFacts::CQL::ObjectTypes

Includes:
Treetop::Runtime
Included in:
CQL, ObjectTypesParser
Defined in:
lib/activefacts/cql/parser/ObjectTypes.rb

Defined Under Namespace

Modules: Basetype0, EntityClauses0, EntityClauses1, EntityType0, EntityType1, Identification0, Identification1, Identification2, Identification3, Identification4, MappingPragma0, MappingPragma1, MappingPragma2, MappingPragma3, MappingPragma4, MappingPragma5, MappingPragmas0, MappingPragmas1, MappingPragmas2, MappingPragmas3, RoleList0, RoleList1, RoleList2, RoleList3, RoleList4, Subtype0, SupertypeList0, SupertypeList1, SupertypeList2, SupertypeList3, TermOrUnary0, TermOrUnary1, TermOrUnary2, TermOrUnary3, UnaryText0, UnaryText1

Instance Method Summary collapse

Instance Method Details

#_nt_basetypeObject



245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
# File 'lib/activefacts/cql/parser/ObjectTypes.rb', line 245

def _nt_basetype
  start_index = index
  if node_cache[:basetype].has_key?(index)
    cached = node_cache[:basetype][index]
    if cached
      node_cache[:basetype][index] = cached = SyntaxNode.new(input, index...(index + 1)) if cached == true
      @index = cached.interval.end
    end
    return cached
  end

  r0 = _nt_basetype_expression
  r0.extend(Basetype0)
  r0.extend(Basetype0)

  node_cache[:basetype][start_index] = r0

  r0
end

#_nt_entity_clausesObject



1487
1488
1489
1490
1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
# File 'lib/activefacts/cql/parser/ObjectTypes.rb', line 1487

def _nt_entity_clauses
  start_index = index
  if node_cache[:entity_clauses].has_key?(index)
    cached = node_cache[:entity_clauses][index]
    if cached
      node_cache[:entity_clauses][index] = cached = SyntaxNode.new(input, index...(index + 1)) if cached == true
      @index = cached.interval.end
    end
    return cached
  end

  i0, s0 = index, []
  i1 = index
  if (match_len = has_terminal?(':', false, index))
    r2 = true
    @index += match_len
  else
    terminal_parse_failure('\':\'')
    r2 = nil
  end
  if r2
    r2 = SyntaxNode.new(input, (index-1)...index) if r2 == true
    r1 = r2
  else
    r3 = _nt_where
    if r3
      r3 = SyntaxNode.new(input, (index-1)...index) if r3 == true
      r1 = r3
    else
      @index = i1
      r1 = nil
    end
  end
  s0 << r1
  if r1
    r4 = _nt_s
    s0 << r4
    if r4
      r5 = _nt_query_clauses
      s0 << r5
    end
  end
  if s0.last
    r0 = instantiate_node(SyntaxNode,input, i0...index, s0)
    r0.extend(EntityClauses0)
    r0.extend(EntityClauses1)
  else
    @index = i0
    r0 = nil
  end

  node_cache[:entity_clauses][start_index] = r0

  r0
end

#_nt_entity_typeObject



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
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
# File 'lib/activefacts/cql/parser/ObjectTypes.rb', line 107

def _nt_entity_type
  start_index = index
  if node_cache[:entity_type].has_key?(index)
    cached = node_cache[:entity_type][index]
    if cached
      node_cache[:entity_type][index] = cached = SyntaxNode.new(input, index...(index + 1)) if cached == true
      @index = cached.interval.end
    end
    return cached
  end

  i0, s0 = index, []
  r1 = _nt_s
  s0 << r1
  if r1
    r3 = _nt_each
    if r3
      r2 = r3
    else
      r2 = instantiate_node(SyntaxNode,input, index...index)
    end
    s0 << r2
    if r2
      r4 = _nt_s
      s0 << r4
      if r4
        r5 = _nt_term_definition_name
        s0 << r5
        if r5
          r6 = _nt_mapping_pragmas
          s0 << r6
          if r6
            r8 = _nt_context_note
            if r8
              r7 = r8
            else
              r7 = instantiate_node(SyntaxNode,input, index...index)
            end
            s0 << r7
            if r7
              i9 = index
              r10 = _nt_basetype
              if r10
                r10 = SyntaxNode.new(input, (index-1)...index) if r10 == true
                r9 = r10
              else
                r11 = _nt_subtype
                if r11
                  r11 = SyntaxNode.new(input, (index-1)...index) if r11 == true
                  r9 = r11
                else
                  @index = i9
                  r9 = nil
                end
              end
              s0 << r9
              if r9
                i12 = index
                r13 = lambda {|s|
                            # There's an implicit type when we use an identification mode, register it:
                            mode = s[6].identification_mode
                            if mode
                              input.context.object_type(s[3].value+mode, "identification mode type")
                              input.context.object_type(s[3].value+' '+mode, "identification mode type")
                            end
                            true
                          }.call(s0)
                if !r13
                  terminal_parse_failure("<semantic predicate>")
                end
                if r13
                  @index = i12
                  r12 = instantiate_node(SyntaxNode,input, index...index)
                else
                  @index = i12
                  r12 = nil
                end
                s0 << r12
                if r12
                  r14 = _nt_mapping_pragmas
                  s0 << r14
                  if r14
                    r16 = _nt_context_note
                    if r16
                      r15 = r16
                    else
                      r15 = instantiate_node(SyntaxNode,input, index...index)
                    end
                    s0 << r15
                    if r15
                      r18 = _nt_entity_clauses
                      if r18
                        r17 = r18
                      else
                        r17 = instantiate_node(SyntaxNode,input, index...index)
                      end
                      s0 << r17
                      if r17
                        if (match_len = has_terminal?(';', false, index))
                          r19 = true
                          @index += match_len
                        else
                          terminal_parse_failure('\';\'')
                          r19 = nil
                        end
                        s0 << r19
                      end
                    end
                  end
                end
              end
            end
          end
        end
      end
    end
  end
  if s0.last
    r0 = instantiate_node(SyntaxNode,input, i0...index, s0)
    r0.extend(EntityType0)
    r0.extend(EntityType1)
  else
    @index = i0
    r0 = nil
  end

  node_cache[:entity_type][start_index] = r0

  r0
end

#_nt_identificationObject



526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
# File 'lib/activefacts/cql/parser/ObjectTypes.rb', line 526

def _nt_identification
  start_index = index
  if node_cache[:identification].has_key?(index)
    cached = node_cache[:identification][index]
    if cached
      node_cache[:identification][index] = cached = SyntaxNode.new(input, index...(index + 1)) if cached == true
      @index = cached.interval.end
    end
    return cached
  end

  i0 = index
  i1, s1 = index, []
  r2 = _nt_identified_by
  s1 << r2
  if r2
    r3 = _nt_its
    s1 << r3
    if r3
      r4 = _nt_s
      s1 << r4
      if r4
        i5 = index
        r6 = _nt_term
        if r6
          r6 = SyntaxNode.new(input, (index-1)...index) if r6 == true
          r5 = r6
        else
          r7 = _nt_implicit_value_type_name
          if r7
            r7 = SyntaxNode.new(input, (index-1)...index) if r7 == true
            r5 = r7
          else
            @index = i5
            r5 = nil
          end
        end
        s1 << r5
        if r5
          r8 = _nt_value_type_parameters
          s1 << r8
          if r8
            i10, s10 = index, []
            r11 = _nt_value_constraint
            s10 << r11
            if r11
              r12 = _nt_enforcement
              s10 << r12
            end
            if s10.last
              r10 = instantiate_node(SyntaxNode,input, i10...index, s10)
              r10.extend(Identification0)
            else
              @index = i10
              r10 = nil
            end
            if r10
              r9 = r10
            else
              r9 = instantiate_node(SyntaxNode,input, index...index)
            end
            s1 << r9
          end
        end
      end
    end
  end
  if s1.last
    r1 = instantiate_node(SyntaxNode,input, i1...index, s1)
    r1.extend(Identification1)
    r1.extend(Identification2)
  else
    @index = i1
    r1 = nil
  end
  if r1
    r1 = SyntaxNode.new(input, (index-1)...index) if r1 == true
    r0 = r1
  else
    i13, s13 = index, []
    r14 = _nt_identified_by
    s13 << r14
    if r14
      r15 = _nt_role_list
      s13 << r15
      if r15
        i16 = index
        r17 = lambda {|s|
                    role_list = s[-1]
                    forwards = role_list.ast.
                      map do |role|
                        next nil if role.is_a?(Compiler::Clause) # Can't forward-reference unaries
                        next nil if role.leading_adjective or role.trailing_adjective
                        role.term
                      end.
                      compact
                    input.context.allowed_forward_terms(forwards)
                    true
                  }.call(s13)
        if !r17
          terminal_parse_failure("<semantic predicate>")
        end
        if r17
          @index = i16
          r16 = instantiate_node(SyntaxNode,input, index...index)
        else
          @index = i16
          r16 = nil
        end
        s13 << r16
      end
    end
    if s13.last
      r13 = instantiate_node(SyntaxNode,input, i13...index, s13)
      r13.extend(Identification3)
      r13.extend(Identification4)
    else
      @index = i13
      r13 = nil
    end
    if r13
      r13 = SyntaxNode.new(input, (index-1)...index) if r13 == true
      r0 = r13
    else
      @index = i0
      r0 = nil
    end
  end

  node_cache[:identification][start_index] = r0

  r0
end

#_nt_mapping_pragmaObject



1358
1359
1360
1361
1362
1363
1364
1365
1366
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
1382
1383
1384
1385
1386
1387
1388
1389
1390
1391
1392
1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
1424
1425
1426
1427
1428
1429
1430
1431
1432
1433
1434
1435
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455
1456
1457
1458
1459
1460
1461
1462
1463
1464
1465
1466
1467
1468
1469
# File 'lib/activefacts/cql/parser/ObjectTypes.rb', line 1358

def _nt_mapping_pragma
  start_index = index
  if node_cache[:mapping_pragma].has_key?(index)
    cached = node_cache[:mapping_pragma][index]
    if cached
      node_cache[:mapping_pragma][index] = cached = SyntaxNode.new(input, index...(index + 1)) if cached == true
      @index = cached.interval.end
    end
    return cached
  end

  i0 = index
  i1, s1 = index, []
  r2 = _nt_was
  s1 << r2
  if r2
    r3 = _nt_s
    s1 << r3
    if r3
      s4, i4 = [], index
      loop do
        i5, s5 = index, []
        r6 = _nt_id
        s5 << r6
        if r6
          r7 = _nt_s
          s5 << r7
        end
        if s5.last
          r5 = instantiate_node(SyntaxNode,input, i5...index, s5)
          r5.extend(MappingPragma0)
        else
          @index = i5
          r5 = nil
        end
        if r5
          s4 << r5
        else
          break
        end
      end
      if s4.empty?
        @index = i4
        r4 = nil
      else
        r4 = instantiate_node(SyntaxNode,input, i4...index, s4)
      end
      s1 << r4
    end
  end
  if s1.last
    r1 = instantiate_node(SyntaxNode,input, i1...index, s1)
    r1.extend(MappingPragma1)
    r1.extend(MappingPragma2)
  else
    @index = i1
    r1 = nil
  end
  if r1
    r1 = SyntaxNode.new(input, (index-1)...index) if r1 == true
    r0 = r1
  else
    i8, s8 = index, []
    r9 = _nt_id
    s8 << r9
    if r9
      s10, i10 = [], index
      loop do
        i11, s11 = index, []
        r12 = _nt_s
        s11 << r12
        if r12
          r13 = _nt_id
          s11 << r13
        end
        if s11.last
          r11 = instantiate_node(SyntaxNode,input, i11...index, s11)
          r11.extend(MappingPragma3)
        else
          @index = i11
          r11 = nil
        end
        if r11
          s10 << r11
        else
          break
        end
      end
      r10 = instantiate_node(SyntaxNode,input, i10...index, s10)
      s8 << r10
    end
    if s8.last
      r8 = instantiate_node(SyntaxNode,input, i8...index, s8)
      r8.extend(MappingPragma4)
      r8.extend(MappingPragma5)
    else
      @index = i8
      r8 = nil
    end
    if r8
      r8 = SyntaxNode.new(input, (index-1)...index) if r8 == true
      r0 = r8
    else
      @index = i0
      r0 = nil
    end
  end

  node_cache[:mapping_pragma][start_index] = r0

  r0
end

#_nt_mapping_pragmasObject



1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220
1221
1222
1223
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
1296
1297
1298
# File 'lib/activefacts/cql/parser/ObjectTypes.rb', line 1184

def _nt_mapping_pragmas
  start_index = index
  if node_cache[:mapping_pragmas].has_key?(index)
    cached = node_cache[:mapping_pragmas][index]
    if cached
      node_cache[:mapping_pragmas][index] = cached = SyntaxNode.new(input, index...(index + 1)) if cached == true
      @index = cached.interval.end
    end
    return cached
  end

  i0 = index
  i1, s1 = index, []
  if (match_len = has_terminal?('[', false, index))
    r2 = true
    @index += match_len
  else
    terminal_parse_failure('\'[\'')
    r2 = nil
  end
  s1 << r2
  if r2
    r3 = _nt_s
    s1 << r3
    if r3
      r4 = _nt_mapping_pragma
      s1 << r4
      if r4
        s5, i5 = [], index
        loop do
          i6, s6 = index, []
          r7 = _nt_s
          s6 << r7
          if r7
            if (match_len = has_terminal?(',', false, index))
              r8 = true
              @index += match_len
            else
              terminal_parse_failure('\',\'')
              r8 = nil
            end
            s6 << r8
            if r8
              r9 = _nt_s
              s6 << r9
              if r9
                r10 = _nt_mapping_pragma
                s6 << r10
              end
            end
          end
          if s6.last
            r6 = instantiate_node(SyntaxNode,input, i6...index, s6)
            r6.extend(MappingPragmas0)
          else
            @index = i6
            r6 = nil
          end
          if r6
            s5 << r6
          else
            break
          end
        end
        r5 = instantiate_node(SyntaxNode,input, i5...index, s5)
        s1 << r5
        if r5
          r11 = _nt_s
          s1 << r11
          if r11
            if (match_len = has_terminal?(']', false, index))
              r12 = true
              @index += match_len
            else
              terminal_parse_failure('\']\'')
              r12 = nil
            end
            s1 << r12
            if r12
              r13 = _nt_s
              s1 << r13
            end
          end
        end
      end
    end
  end
  if s1.last
    r1 = instantiate_node(SyntaxNode,input, i1...index, s1)
    r1.extend(MappingPragmas1)
    r1.extend(MappingPragmas2)
  else
    @index = i1
    r1 = nil
  end
  if r1
    r1 = SyntaxNode.new(input, (index-1)...index) if r1 == true
    r0 = r1
  else
    r14 = _nt_s
    r14.extend(MappingPragmas3)
    r14.extend(MappingPragmas3)
    if r14
      r14 = SyntaxNode.new(input, (index-1)...index) if r14 == true
      r0 = r14
    else
      @index = i0
      r0 = nil
    end
  end

  node_cache[:mapping_pragmas][start_index] = r0

  r0
end

#_nt_object_typeObject



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
# File 'lib/activefacts/cql/parser/ObjectTypes.rb', line 19

def _nt_object_type
  start_index = index
  if node_cache[:object_type].has_key?(index)
    cached = node_cache[:object_type][index]
    if cached
      node_cache[:object_type][index] = cached = SyntaxNode.new(input, index...(index + 1)) if cached == true
      @index = cached.interval.end
    end
    return cached
  end

  i0 = index
  r1 = _nt_value_type
  if r1
    r1 = SyntaxNode.new(input, (index-1)...index) if r1 == true
    r0 = r1
  else
    r2 = _nt_entity_type
    if r2
      r2 = SyntaxNode.new(input, (index-1)...index) if r2 == true
      r0 = r2
    else
      r3 = _nt_fact_type
      if r3
        r3 = SyntaxNode.new(input, (index-1)...index) if r3 == true
        r0 = r3
      else
        @index = i0
        r0 = nil
      end
    end
  end

  node_cache[:object_type][start_index] = r0

  r0
end

#_nt_role_listObject



718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
# File 'lib/activefacts/cql/parser/ObjectTypes.rb', line 718

def _nt_role_list
  start_index = index
  if node_cache[:role_list].has_key?(index)
    cached = node_cache[:role_list][index]
    if cached
      node_cache[:role_list][index] = cached = SyntaxNode.new(input, index...(index + 1)) if cached == true
      @index = cached.interval.end
    end
    return cached
  end

  i0, s0 = index, []
  r2 = _nt_any
  if r2
    r1 = r2
  else
    r1 = instantiate_node(SyntaxNode,input, index...index)
  end
  s0 << r1
  if r1
    r3 = _nt_s
    s0 << r3
    if r3
      r4 = _nt_term_or_unary
      s0 << r4
      if r4
        r5 = _nt_s
        s0 << r5
        if r5
          s6, i6 = [], index
          loop do
            i7, s7 = index, []
            i8 = index
            i9, s9 = index, []
            r10 = _nt_and
            s9 << r10
            if r10
              r11 = _nt_S
              s9 << r11
            end
            if s9.last
              r9 = instantiate_node(SyntaxNode,input, i9...index, s9)
              r9.extend(RoleList0)
            else
              @index = i9
              r9 = nil
            end
            if r9
              r9 = SyntaxNode.new(input, (index-1)...index) if r9 == true
              r8 = r9
            else
              i12, s12 = index, []
              if (match_len = has_terminal?(',', false, index))
                r13 = true
                @index += match_len
              else
                terminal_parse_failure('\',\'')
                r13 = nil
              end
              s12 << r13
              if r13
                r14 = _nt_s
                s12 << r14
              end
              if s12.last
                r12 = instantiate_node(SyntaxNode,input, i12...index, s12)
                r12.extend(RoleList1)
              else
                @index = i12
                r12 = nil
              end
              if r12
                r12 = SyntaxNode.new(input, (index-1)...index) if r12 == true
                r8 = r12
              else
                @index = i8
                r8 = nil
              end
            end
            s7 << r8
            if r8
              r16 = _nt_any
              if r16
                r15 = r16
              else
                r15 = instantiate_node(SyntaxNode,input, index...index)
              end
              s7 << r15
              if r15
                r17 = _nt_s
                s7 << r17
                if r17
                  r18 = _nt_term_or_unary
                  s7 << r18
                  if r18
                    r19 = _nt_s
                    s7 << r19
                  end
                end
              end
            end
            if s7.last
              r7 = instantiate_node(SyntaxNode,input, i7...index, s7)
              r7.extend(RoleList2)
            else
              @index = i7
              r7 = nil
            end
            if r7
              s6 << r7
            else
              break
            end
          end
          r6 = instantiate_node(SyntaxNode,input, i6...index, s6)
          s0 << r6
        end
      end
    end
  end
  if s0.last
    r0 = instantiate_node(SyntaxNode,input, i0...index, s0)
    r0.extend(RoleList3)
    r0.extend(RoleList4)
  else
    @index = i0
    r0 = nil
  end

  node_cache[:role_list][start_index] = r0

  r0
end

#_nt_subtypeObject



272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
# File 'lib/activefacts/cql/parser/ObjectTypes.rb', line 272

def _nt_subtype
  start_index = index
  if node_cache[:subtype].has_key?(index)
    cached = node_cache[:subtype][index]
    if cached
      node_cache[:subtype][index] = cached = SyntaxNode.new(input, index...(index + 1)) if cached == true
      @index = cached.interval.end
    end
    return cached
  end

  r0 = _nt_subtype_expression
  r0.extend(Subtype0)
  r0.extend(Subtype0)

  node_cache[:subtype][start_index] = r0

  r0
end

#_nt_supertype_listObject



329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
# File 'lib/activefacts/cql/parser/ObjectTypes.rb', line 329

def _nt_supertype_list
  start_index = index
  if node_cache[:supertype_list].has_key?(index)
    cached = node_cache[:supertype_list][index]
    if cached
      node_cache[:supertype_list][index] = cached = SyntaxNode.new(input, index...(index + 1)) if cached == true
      @index = cached.interval.end
    end
    return cached
  end

  i0, s0 = index, []
  r1 = _nt_term
  s0 << r1
  if r1
    r2 = _nt_s
    s0 << r2
    if r2
      s3, i3 = [], index
      loop do
        i4, s4 = index, []
        i5 = index
        if (match_len = has_terminal?(',', false, index))
          r6 = true
          @index += match_len
        else
          terminal_parse_failure('\',\'')
          r6 = nil
        end
        if r6
          r6 = SyntaxNode.new(input, (index-1)...index) if r6 == true
          r5 = r6
        else
          i7, s7 = index, []
          if (match_len = has_terminal?('and', false, index))
            r8 = instantiate_node(SyntaxNode,input, index...(index + match_len))
            @index += match_len
          else
            terminal_parse_failure('\'and\'')
            r8 = nil
          end
          s7 << r8
          if r8
            i9 = index
            r10 = _nt_alpha
            if r10
              @index = i9
              r9 = nil
            else
              @index = i9
              r9 = instantiate_node(SyntaxNode,input, index...index)
            end
            s7 << r9
          end
          if s7.last
            r7 = instantiate_node(SyntaxNode,input, i7...index, s7)
            r7.extend(SupertypeList0)
          else
            @index = i7
            r7 = nil
          end
          if r7
            r7 = SyntaxNode.new(input, (index-1)...index) if r7 == true
            r5 = r7
          else
            @index = i5
            r5 = nil
          end
        end
        s4 << r5
        if r5
          r11 = _nt_s
          s4 << r11
          if r11
            i12 = index
            r13 = _nt_identified_by
            if r13
              @index = i12
              r12 = nil
            else
              @index = i12
              r12 = instantiate_node(SyntaxNode,input, index...index)
            end
            s4 << r12
            if r12
              r14 = _nt_term
              s4 << r14
              if r14
                r15 = _nt_s
                s4 << r15
              end
            end
          end
        end
        if s4.last
          r4 = instantiate_node(SyntaxNode,input, i4...index, s4)
          r4.extend(SupertypeList1)
        else
          @index = i4
          r4 = nil
        end
        if r4
          s3 << r4
        else
          break
        end
      end
      r3 = instantiate_node(SyntaxNode,input, i3...index, s3)
      s0 << r3
    end
  end
  if s0.last
    r0 = instantiate_node(SyntaxNode,input, i0...index, s0)
    r0.extend(SupertypeList2)
    r0.extend(SupertypeList3)
  else
    @index = i0
    r0 = nil
  end

  node_cache[:supertype_list][start_index] = r0

  r0
end

#_nt_term_or_unaryObject



1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
# File 'lib/activefacts/cql/parser/ObjectTypes.rb', line 1014

def _nt_term_or_unary
  start_index = index
  if node_cache[:term_or_unary].has_key?(index)
    cached = node_cache[:term_or_unary][index]
    if cached
      node_cache[:term_or_unary][index] = cached = SyntaxNode.new(input, index...(index + 1)) if cached == true
      @index = cached.interval.end
    end
    return cached
  end

  i0 = index
  i1, s1 = index, []
  r2 = _nt_unary_text
  s1 << r2
  if r2
    r3 = _nt_s
    s1 << r3
    if r3
      r4 = _nt_term
      s1 << r4
      if r4
        r5 = _nt_unary_text
        s1 << r5
        if r5
          r6 = _nt_s
          s1 << r6
          if r6
            r8 = _nt_subscript
            if r8
              r7 = r8
            else
              r7 = instantiate_node(SyntaxNode,input, index...index)
            end
            s1 << r7
          end
        end
      end
    end
  end
  if s1.last
    r1 = instantiate_node(SyntaxNode,input, i1...index, s1)
    r1.extend(TermOrUnary0)
    r1.extend(TermOrUnary1)
  else
    @index = i1
    r1 = nil
  end
  if r1
    r1 = SyntaxNode.new(input, (index-1)...index) if r1 == true
    r0 = r1
  else
    i9, s9 = index, []
    r10 = _nt_s
    s9 << r10
    if r10
      i11 = index
      r12 = _nt_non_phrase
      if r12
        @index = i11
        r11 = nil
      else
        @index = i11
        r11 = instantiate_node(SyntaxNode,input, index...index)
      end
      s9 << r11
      if r11
        r13 = _nt_id
        s9 << r13
        if r13
          r14 = _nt_s
          s9 << r14
          if r14
            i15 = index
            r16 = _nt_non_phrase
            if r16
              @index = i15
              r15 = instantiate_node(SyntaxNode,input, index...index)
            else
              @index = i15
              r15 = nil
            end
            s9 << r15
            if r15
              r17 = _nt_s
              s9 << r17
              if r17
                r19 = _nt_subscript
                if r19
                  r18 = r19
                else
                  r18 = instantiate_node(SyntaxNode,input, index...index)
                end
                s9 << r18
              end
            end
          end
        end
      end
    end
    if s9.last
      r9 = instantiate_node(SyntaxNode,input, i9...index, s9)
      r9.extend(TermOrUnary2)
      r9.extend(TermOrUnary3)
    else
      @index = i9
      r9 = nil
    end
    if r9
      r9 = SyntaxNode.new(input, (index-1)...index) if r9 == true
      r0 = r9
    else
      @index = i0
      r0 = nil
    end
  end

  node_cache[:term_or_unary][start_index] = r0

  r0
end

#_nt_unary_textObject



866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
# File 'lib/activefacts/cql/parser/ObjectTypes.rb', line 866

def _nt_unary_text
  start_index = index
  if node_cache[:unary_text].has_key?(index)
    cached = node_cache[:unary_text][index]
    if cached
      node_cache[:unary_text][index] = cached = SyntaxNode.new(input, index...(index + 1)) if cached == true
      @index = cached.interval.end
    end
    return cached
  end

  s0, i0 = [], index
  loop do
    i1, s1 = index, []
    r2 = _nt_s
    s1 << r2
    if r2
      i3 = index
      r4 = _nt_any
      if r4
        @index = i3
        r3 = nil
      else
        @index = i3
        r3 = instantiate_node(SyntaxNode,input, index...index)
      end
      s1 << r3
      if r3
        i5 = index
        r6 = _nt_non_phrase
        if r6
          @index = i5
          r5 = nil
        else
          @index = i5
          r5 = instantiate_node(SyntaxNode,input, index...index)
        end
        s1 << r5
        if r5
          i7 = index
          r8 = _nt_term
          if r8
            @index = i7
            r7 = nil
          else
            @index = i7
            r7 = instantiate_node(SyntaxNode,input, index...index)
          end
          s1 << r7
          if r7
            r9 = _nt_id
            s1 << r9
          end
        end
      end
    end
    if s1.last
      r1 = instantiate_node(SyntaxNode,input, i1...index, s1)
      r1.extend(UnaryText0)
    else
      @index = i1
      r1 = nil
    end
    if r1
      s0 << r1
    else
      break
    end
  end
  r0 = instantiate_node(SyntaxNode,input, i0...index, s0)
  r0.extend(UnaryText1)
  r0.extend(UnaryText1)

  node_cache[:unary_text][start_index] = r0

  r0
end

#rootObject



15
16
17
# File 'lib/activefacts/cql/parser/ObjectTypes.rb', line 15

def root
  @root ||= :object_type
end