blob: a409d8223f016d16fd58078147e849cb5f11935c (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
module Arel
class Table < Relation
include Recursion::BaseCase
cattr_accessor :engine
attr_reader :name, :engine, :table_alias, :options
def initialize(name, options = {})
@name = name.to_s
if options.is_a?(Hash)
@options = options
@engine = options[:engine] || Table.engine
@table_alias = options[:as].to_s if options[:as].present? && options[:as].to_s != @name
else
@engine = options # Table.new('foo', engine)
end
end
def as(table_alias)
Table.new(name, options.merge(:as => table_alias))
end
def attributes
@attributes ||= columns.collect do |column|
Attribute.new(self, column.name.to_sym)
end
end
def eql?(other)
self == other
end
def hash
@hash ||= :name.hash
end
def format(attribute, value)
attribute.column.type_cast(value)
end
def column_for(attribute)
has_attribute?(attribute) and columns.detect { |c| c.name == attribute.name.to_s }
end
def columns
@columns ||= engine.columns(name, "#{name} Columns")
end
def reset
@attributes = @columns = nil
end
def ==(other)
Table === other and
name == other.name and
table_alias == other.table_alias
end
end
end
def Table(name, engine = Arel::Table.engine)
Arel::Table.new(name, engine)
end
|