blob: 9e64e8e590b708a49b8d3582c7641194161d6716 (
plain) (
tree)
|
|
module Arel
class Table
include Relation, Recursion::BaseCase
@@engine = nil
@@tables = nil
class << self # FIXME: Do we really need these?
def engine; @@engine; end
def engine= e; @@engine = e; end
def tables; @@tables; end
def tables= e; @@tables = e; end
end
attr_reader :name, :engine, :table_alias, :options
def initialize(name, options = {})
@name = name.to_s
@table_exists = nil
if options.is_a?(Hash)
@options = options
@engine = options[:engine] || Table.engine
if options[:as]
as = options[:as].to_s
@table_alias = as unless as == @name
end
else
@engine = options # Table.new('foo', engine)
end
if @engine.connection
begin
require "arel/engines/sql/compilers/#{@engine.adapter_name.downcase}_compiler"
rescue LoadError
begin
# try to load an externally defined compiler, in case this adapter has defined the compiler on its own.
require "#{@engine.adapter_name.downcase}/arel_compiler"
rescue LoadError
raise "#{@engine.adapter_name} is not supported by Arel."
end
end
@@tables ||= engine.connection.tables
end
end
def as(table_alias)
Table.new(name, options.merge(:as => table_alias))
end
def table_exists?
if @table_exists
true
else
@table_exists = @@tables.include?(name) || engine.table_exists?(name)
end
end
def attributes
return @attributes if defined?(@attributes)
if table_exists?
@attributes ||= begin
attrs = columns.collect do |column|
Sql::Attributes.for(column).new(column, self, column.name.to_sym)
end
Header.new(attrs)
end
else
Header.new
end
end
def eql?(other)
self == other
end
def hash
@hash ||= :name.hash
end
def column_for(attribute)
has_attribute?(attribute) and columns.detect { |c| c.name == attribute.name.to_s }
end
def columns
@columns ||= engine.connection.columns(name, "#{name} Columns")
end
def reset
@columns = nil
@attributes = Header.new([])
end
def ==(other)
super ||
Table === other &&
name == other.name &&
table_alias == other.table_alias
end
end
end
def Table(name, engine = Arel::Table.engine)
Arel::Table.new(name, engine)
end
|