diff options
author | thedarkone <thedarkone2@gmail.com> | 2013-09-05 00:16:25 +0200 |
---|---|---|
committer | thedarkone <thedarkone2@gmail.com> | 2013-09-28 19:19:07 +0200 |
commit | f31ec1c4720abfc51f7f74d23d328eaa1401336e (patch) | |
tree | 19505536933415416d7527250dc9686433f4dc57 | |
parent | 28572f59f828cc2b8309e8c477658fed2a38f83b (diff) | |
download | rails-f31ec1c4720abfc51f7f74d23d328eaa1401336e.tar.gz rails-f31ec1c4720abfc51f7f74d23d328eaa1401336e.tar.bz2 rails-f31ec1c4720abfc51f7f74d23d328eaa1401336e.zip |
Make GTG::TransTable thread safe.
From now on only the `[]=` method is allowed to modify the internal states hashes.
-rw-r--r-- | actionpack/lib/action_dispatch/journey/gtg/transition_table.rb | 35 |
1 files changed, 23 insertions, 12 deletions
diff --git a/actionpack/lib/action_dispatch/journey/gtg/transition_table.rb b/actionpack/lib/action_dispatch/journey/gtg/transition_table.rb index da0cddd93c..971cb3447f 100644 --- a/actionpack/lib/action_dispatch/journey/gtg/transition_table.rb +++ b/actionpack/lib/action_dispatch/journey/gtg/transition_table.rb @@ -9,8 +9,8 @@ module ActionDispatch attr_reader :memos def initialize - @regexp_states = Hash.new { |h,k| h[k] = {} } - @string_states = Hash.new { |h,k| h[k] = {} } + @regexp_states = {} + @string_states = {} @accepting = {} @memos = Hash.new { |h,k| h[k] = [] } end @@ -111,14 +111,8 @@ module ActionDispatch end def []=(from, to, sym) - case sym - when String - @string_states[from][sym] = to - when Regexp - @regexp_states[from][sym] = to - else - raise ArgumentError, 'unknown symbol: %s' % sym.class - end + to_mappings = states_hash_for(sym)[from] ||= {} + to_mappings[sym] = to end def states @@ -137,18 +131,35 @@ module ActionDispatch private + def states_hash_for(sym) + case sym + when String + @string_states + when Regexp + @regexp_states + else + raise ArgumentError, 'unknown symbol: %s' % sym.class + end + end + def move_regexp(t, a) return [] if t.empty? t.map { |s| - @regexp_states[s].map { |re, v| re === a ? v : nil } + if states = @regexp_states[s] + states.map { |re, v| re === a ? v : nil } + end }.flatten.compact.uniq end def move_string(t, a) return [] if t.empty? - t.map { |s| @string_states[s][a] }.compact + t.map do |s| + if states = @string_states[s] + states[a] + end + end.compact end end end |