aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2010-09-23 15:45:00 -0700
committerAaron Patterson <aaron.patterson@gmail.com>2010-09-23 15:45:00 -0700
commit03724fb1789198cc394f6e8b69cf9404e03eddd7 (patch)
tree8ed6edcf715e1ecf6e96a091132ba96d85b088de /lib
parent2473eae11f16ec953a33b26a65c5f74be5382015 (diff)
downloadrails-03724fb1789198cc394f6e8b69cf9404e03eddd7.tar.gz
rails-03724fb1789198cc394f6e8b69cf9404e03eddd7.tar.bz2
rails-03724fb1789198cc394f6e8b69cf9404e03eddd7.zip
caching visitor on a per engine basis
Diffstat (limited to 'lib')
-rw-r--r--lib/arel/tree_manager.rb17
-rw-r--r--lib/arel/visitors.rb20
2 files changed, 22 insertions, 15 deletions
diff --git a/lib/arel/tree_manager.rb b/lib/arel/tree_manager.rb
index fb5037cd9f..8a13345c91 100644
--- a/lib/arel/tree_manager.rb
+++ b/lib/arel/tree_manager.rb
@@ -3,30 +3,17 @@ module Arel
# FIXME: Remove this.
include Arel::Relation
- VISITORS = {
- 'postgresql' => Arel::Visitors::PostgreSQL,
- 'mysql' => Arel::Visitors::MySQL,
- 'mysql2' => Arel::Visitors::MySQL,
- }
-
- attr_writer :visitor
+ attr_accessor :visitor
def initialize engine
@engine = engine
- @visitor = nil
+ @visitor = Visitors.visitor_for @engine
end
def to_dot
Visitors::Dot.new.accept @head
end
- def visitor
- return @visitor if @visitor
- pool = @engine.connection_pool
- adapter = pool.spec.config[:adapter]
- @visitor = (VISITORS[adapter] || Visitors::ToSql).new(@engine)
- end
-
def to_sql
visitor.accept @head
end
diff --git a/lib/arel/visitors.rb b/lib/arel/visitors.rb
index 22077d5943..879635575b 100644
--- a/lib/arel/visitors.rb
+++ b/lib/arel/visitors.rb
@@ -4,3 +4,23 @@ require 'arel/visitors/mysql'
require 'arel/visitors/join_sql'
require 'arel/visitors/order_clauses'
require 'arel/visitors/dot'
+
+module Arel
+ module Visitors
+ VISITORS = {
+ 'postgresql' => Arel::Visitors::PostgreSQL,
+ 'mysql' => Arel::Visitors::MySQL,
+ 'mysql2' => Arel::Visitors::MySQL,
+ }
+
+ ENGINE_VISITORS = Hash.new do |hash, engine|
+ pool = engine.connection_pool
+ adapter = pool.spec.config[:adapter]
+ hash[engine] = (VISITORS[adapter] || Visitors::ToSql).new(engine)
+ end
+
+ def self.visitor_for engine
+ ENGINE_VISITORS[engine]
+ end
+ end
+end