aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2010-07-28 13:51:51 -0700
committerAaron Patterson <aaron.patterson@gmail.com>2010-07-28 14:55:00 -0700
commita0425099d78c1884478ee3e69a09ea5f7afa1aa9 (patch)
tree2ff8a1513ac3dad4f0ed6ea42ab7719c8881f9a1
parent8f808807a96c9755a3d0684900228ac594793d03 (diff)
downloadrails-a0425099d78c1884478ee3e69a09ea5f7afa1aa9.tar.gz
rails-a0425099d78c1884478ee3e69a09ea5f7afa1aa9.tar.bz2
rails-a0425099d78c1884478ee3e69a09ea5f7afa1aa9.zip
simplifying the Christener
-rw-r--r--lib/arel/algebra/attributes/attribute.rb6
-rw-r--r--lib/arel/engines/sql/christener.rb17
-rw-r--r--lib/arel/engines/sql/relations/table.rb1
3 files changed, 12 insertions, 12 deletions
diff --git a/lib/arel/algebra/attributes/attribute.rb b/lib/arel/algebra/attributes/attribute.rb
index 62c1a64324..90a3b13938 100644
--- a/lib/arel/algebra/attributes/attribute.rb
+++ b/lib/arel/algebra/attributes/attribute.rb
@@ -41,11 +41,9 @@ module Arel
row[self]
end
- module Transformations
- def self.included(klass)
- klass.send :alias_method, :eql?, :==
- end
+ alias :eql? :==
+ module Transformations
def hash
@hash ||= name.hash + root.relation.hash
end
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