summaryrefslogtreecommitdiff
path: root/src/thue/program.cr
blob: f449f5aaa49be4a7d960a68b9d19936c975fefa9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
require "./thue.cr"
require "./parser.cr"

class Thue::Program
  def initialize(@parser : Parser)
  end

  def interpret
    rules, state = @parser.parse

    loop do
      r = rules.find { |r| r.matches?(state) }
      break if r.nil?

      state = state.sub(r.pattern, r.replacement)
    end

    puts state
  end
end