module ScientificNameCanonical

Autogenerated from a Treetop grammar. Edits may be lost.

Public Instance Methods

_nt_garbage() click to toggle source
# File lib/biodiversity/parser/scientific_name_canonical.rb, line 389
def _nt_garbage
  start_index = index
  if node_cache[:garbage].has_key?(index)
    cached = node_cache[:garbage][index]
    if cached
      node_cache[:garbage][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_space
  s1 << r2
  if r2
    if (match_len = has_terminal?("$$g@rbg3$$", false, index))
      r3 = instantiate_node(SyntaxNode,input, index...(index + match_len))
      @index += match_len
    else
      terminal_parse_failure("$$g@rbg3$$")
      r3 = nil
    end
    s1 << r3
  end
  if s1.last
    r1 = instantiate_node(SyntaxNode,input, i1...index, s1)
    r1.extend(Garbage0)
  else
    @index = i1
    r1 = nil
  end
  if r1
    r1 = SyntaxNode.new(input, (index-1)...index) if r1 == true
    r0 = r1
  else
    i4, s4 = index, []
    r5 = _nt_space
    s4 << r5
    if r5
      if has_terminal?(@regexps[gr = '\A["\',.]'] ||= Regexp.new(gr), :regexp, index)
        r6 = true
        @index += 1
      else
        terminal_parse_failure('["\',.]')
        r6 = nil
      end
      s4 << r6
      if r6
        r7 = _nt_space
        s4 << r7
        if r7
          s8, i8 = [], index
          loop do
            if has_terminal?(@regexps[gr = '\A[^щ]'] ||= Regexp.new(gr), :regexp, index)
              r9 = true
              @index += 1
            else
              terminal_parse_failure('[^щ]')
              r9 = nil
            end
            if r9
              s8 << r9
            else
              break
            end
          end
          r8 = instantiate_node(SyntaxNode,input, i8...index, s8)
          s4 << r8
        end
      end
    end
    if s4.last
      r4 = instantiate_node(SyntaxNode,input, i4...index, s4)
      r4.extend(Garbage1)
    else
      @index = i4
      r4 = nil
    end
    if r4
      r4 = SyntaxNode.new(input, (index-1)...index) if r4 == true
      r0 = r4
    else
      i10, s10 = index, []
      r11 = _nt_space_hard
      s10 << r11
      if r11
        s12, i12 = [], index
        loop do
          if has_terminal?(@regexps[gr = '\A[^ш]'] ||= Regexp.new(gr), :regexp, index)
            r13 = true
            @index += 1
          else
            terminal_parse_failure('[^ш]')
            r13 = nil
          end
          if r13
            s12 << r13
          else
            break
          end
        end
        if s12.empty?
          @index = i12
          r12 = nil
        else
          r12 = instantiate_node(SyntaxNode,input, i12...index, s12)
        end
        s10 << r12
      end
      if s10.last
        r10 = instantiate_node(SyntaxNode,input, i10...index, s10)
        r10.extend(Garbage2)
      else
        @index = i10
        r10 = nil
      end
      if r10
        r10 = SyntaxNode.new(input, (index-1)...index) if r10 == true
        r0 = r10
      else
        @index = i0
        r0 = nil
      end
    end
  end

  node_cache[:garbage][start_index] = r0

  r0
end
_nt_multinomial_with_garbage() click to toggle source
# File lib/biodiversity/parser/scientific_name_canonical.rb, line 192
def _nt_multinomial_with_garbage
  start_index = index
  if node_cache[:multinomial_with_garbage].has_key?(index)
    cached = node_cache[:multinomial_with_garbage][index]
    if cached
      node_cache[:multinomial_with_garbage][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_genus
  s1 << r2
  if r2
    r3 = _nt_space
    s1 << r3
    if r3
      r4 = _nt_infragenus
      s1 << r4
      if r4
        r5 = _nt_space
        s1 << r5
        if r5
          r6 = _nt_species
          s1 << r6
          if r6
            r7 = _nt_garbage
            s1 << r7
          end
        end
      end
    end
  end
  if s1.last
    r1 = instantiate_node(SyntaxNode,input, i1...index, s1)
    r1.extend(MultinomialWithGarbage0)
    r1.extend(MultinomialWithGarbage1)
  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_genus
    s8 << r9
    if r9
      r10 = _nt_space
      s8 << r10
      if r10
        r11 = _nt_infragenus
        s8 << r11
        if r11
          r12 = _nt_garbage
          s8 << r12
        end
      end
    end
    if s8.last
      r8 = instantiate_node(SyntaxNode,input, i8...index, s8)
      r8.extend(MultinomialWithGarbage2)
      r8.extend(MultinomialWithGarbage3)
    else
      @index = i8
      r8 = nil
    end
    if r8
      r8 = SyntaxNode.new(input, (index-1)...index) if r8 == true
      r0 = r8
    else
      i13, s13 = index, []
      r14 = _nt_genus
      s13 << r14
      if r14
        r15 = _nt_space
        s13 << r15
        if r15
          r16 = _nt_species
          s13 << r16
          if r16
            r17 = _nt_garbage
            s13 << r17
          end
        end
      end
      if s13.last
        r13 = instantiate_node(SyntaxNode,input, i13...index, s13)
        r13.extend(MultinomialWithGarbage4)
        r13.extend(MultinomialWithGarbage5)
      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
  end

  node_cache[:multinomial_with_garbage][start_index] = r0

  r0
end
_nt_root() click to toggle source
# File lib/biodiversity/parser/scientific_name_canonical.rb, line 42
def _nt_root
  start_index = index
  if node_cache[:root].has_key?(index)
    cached = node_cache[:root][index]
    if cached
      node_cache[:root][index] = cached = SyntaxNode.new(input, index...(index + 1)) if cached == true
      @index = cached.interval.end
    end
    return cached
  end

  i0 = index
  r1 = _nt_multinomial_with_garbage
  r1.extend(Root0)
  if r1
    r1 = SyntaxNode.new(input, (index-1)...index) if r1 == true
    r0 = r1
  else
    r2 = _nt_uninomial_with_garbage
    r2.extend(Root1)
    if r2
      r2 = SyntaxNode.new(input, (index-1)...index) if r2 == true
      r0 = r2
    else
      @index = i0
      r0 = nil
    end
  end

  node_cache[:root][start_index] = r0

  r0
end
_nt_uninomial_with_garbage() click to toggle source
# File lib/biodiversity/parser/scientific_name_canonical.rb, line 332
def _nt_uninomial_with_garbage
  start_index = index
  if node_cache[:uninomial_with_garbage].has_key?(index)
    cached = node_cache[:uninomial_with_garbage][index]
    if cached
      node_cache[:uninomial_with_garbage][index] = cached = SyntaxNode.new(input, index...(index + 1)) if cached == true
      @index = cached.interval.end
    end
    return cached
  end

  i0, s0 = index, []
  r1 = _nt_uninomial_string
  s0 << r1
  if r1
    r2 = _nt_garbage
    s0 << r2
  end
  if s0.last
    r0 = instantiate_node(SyntaxNode,input, i0...index, s0)
    r0.extend(UninomialWithGarbage0)
    r0.extend(UninomialWithGarbage1)
  else
    @index = i0
    r0 = nil
  end

  node_cache[:uninomial_with_garbage][start_index] = r0

  r0
end
root() click to toggle source
# File lib/biodiversity/parser/scientific_name_canonical.rb, line 8
def root
  @root ||= :root
end