File: simulator.rb

package info (click to toggle)
ruby-journey 1.0.4-2.1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, sid, trixie
  • size: 288 kB
  • sloc: ruby: 2,830; javascript: 113; yacc: 42; makefile: 2
file content (43 lines) | stat: -rw-r--r-- 796 bytes parent folder | download | duplicates (3)
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
require 'strscan'

module Journey
  module GTG
    class MatchData
      attr_reader :memos

      def initialize memos
        @memos = memos
      end
    end

    class Simulator
      attr_reader :tt

      def initialize transition_table
        @tt = transition_table
      end

      def simulate string
        input = StringScanner.new string
        state = [0]
        while sym = input.scan(/[\/\.\?]|[^\/\.\?]+/)
          state = tt.move(state, sym)
        end

        acceptance_states = state.find_all { |s|
          tt.accepting? s
        }

        return if acceptance_states.empty?

        memos = acceptance_states.map { |x| tt.memo x }.flatten.compact

        MatchData.new memos
      end

      alias :=~    :simulate
      alias :match :simulate
    end
  end
end