diff options
author | Aaron Patterson <aaron.patterson@gmail.com> | 2010-07-28 13:51:51 -0700 |
---|---|---|
committer | Aaron Patterson <aaron.patterson@gmail.com> | 2010-07-28 14:55:00 -0700 |
commit | a0425099d78c1884478ee3e69a09ea5f7afa1aa9 (patch) | |
tree | 2ff8a1513ac3dad4f0ed6ea42ab7719c8881f9a1 /lib/arel/engines/sql | |
parent | 8f808807a96c9755a3d0684900228ac594793d03 (diff) | |
download | rails-a0425099d78c1884478ee3e69a09ea5f7afa1aa9.tar.gz rails-a0425099d78c1884478ee3e69a09ea5f7afa1aa9.tar.bz2 rails-a0425099d78c1884478ee3e69a09ea5f7afa1aa9.zip |
simplifying the Christener
Diffstat (limited to 'lib/arel/engines/sql')
-rw-r--r-- | lib/arel/engines/sql/christener.rb | 17 | ||||
-rw-r--r-- | lib/arel/engines/sql/relations/table.rb | 1 |
2 files changed, 10 insertions, 8 deletions
diff --git a/lib/arel/engines/sql/christener.rb b/lib/arel/engines/sql/christener.rb index 6160f244f7..3c7fb0425e 100644 --- a/lib/arel/engines/sql/christener.rb +++ b/lib/arel/engines/sql/christener.rb @@ -2,17 +2,18 @@ module Arel module Sql class Christener def initialize - # FIXME: this exists because all objects hash the same. :'( - @used_names = Hash.new(0) - @relation_names = Hash.new do |hash, relation| - name = relation.table_alias || relation.name - @used_names[name] += 1 - hash[relation] = name + (@used_names[name] > 1 ? "_#{@used_names[name]}" : '') - end + @names = {} end def name_for(relation) - @relation_names[relation.table] + table = relation.table + name = table.table_alias || table.name + @names[name] ||= [] + + @names[name] << table unless @names[name].include? table + + idx = @names[name].index table + name + (idx == 0 ? '' : "_#{idx + 1}") end end end diff --git a/lib/arel/engines/sql/relations/table.rb b/lib/arel/engines/sql/relations/table.rb index 9ad939b896..d9ff95265b 100644 --- a/lib/arel/engines/sql/relations/table.rb +++ b/lib/arel/engines/sql/relations/table.rb @@ -17,6 +17,7 @@ module Arel def initialize(name, options = {}) @name = name.to_s @table_exists = nil + @table_alias = nil if options.is_a?(Hash) @options = options |