diff options
author | Aaron Patterson <aaron.patterson@gmail.com> | 2011-03-21 14:58:15 -0700 |
---|---|---|
committer | Aaron Patterson <aaron.patterson@gmail.com> | 2011-03-21 14:58:15 -0700 |
commit | 83d045d2d8881e4310f0f54376a5e04d395f3c7a (patch) | |
tree | a2e88cd0c5d1aa629ac5702225c5ea48b807cb9f /lib/arel | |
parent | 856fd75c9b6defb7711f93e6ecda2932e98c4113 (diff) | |
parent | 05887fc406820f2e8fecc5cedcc42b87cf9f0ab1 (diff) | |
download | rails-83d045d2d8881e4310f0f54376a5e04d395f3c7a.tar.gz rails-83d045d2d8881e4310f0f54376a5e04d395f3c7a.tar.bz2 rails-83d045d2d8881e4310f0f54376a5e04d395f3c7a.zip |
Merge branch 'master' of github.com:rails/arel
* 'master' of github.com:rails/arel:
Make as factory method convert alias name to SqlLiteral
Replace MathOperation with InfixOperation to support more operators
Diffstat (limited to 'lib/arel')
-rw-r--r-- | lib/arel/math.rb | 4 | ||||
-rw-r--r-- | lib/arel/nodes.rb | 2 | ||||
-rw-r--r-- | lib/arel/nodes/infix_operation.rb | 42 | ||||
-rw-r--r-- | lib/arel/nodes/math_operation.rb | 15 | ||||
-rw-r--r-- | lib/arel/predications.rb | 2 | ||||
-rw-r--r-- | lib/arel/visitors/to_sql.rb | 19 |
6 files changed, 52 insertions, 32 deletions
diff --git a/lib/arel/math.rb b/lib/arel/math.rb index b7c2419233..f3dbc7bc49 100644 --- a/lib/arel/math.rb +++ b/lib/arel/math.rb @@ -5,11 +5,11 @@ module Arel end def +(other) - Arel::Nodes::Addition.new(self, other) + Arel::Nodes::Grouping.new(Arel::Nodes::Addition.new(self, other)) end def -(other) - Arel::Nodes::Subtraction.new(self, other) + Arel::Nodes::Grouping.new(Arel::Nodes::Subtraction.new(self, other)) end def /(other) diff --git a/lib/arel/nodes.rb b/lib/arel/nodes.rb index 4b97e28668..cf2aeb2ddc 100644 --- a/lib/arel/nodes.rb +++ b/lib/arel/nodes.rb @@ -18,7 +18,7 @@ require 'arel/nodes/join_source' require 'arel/nodes/ordering' require 'arel/nodes/delete_statement' require 'arel/nodes/table_alias' -require 'arel/nodes/math_operation' +require 'arel/nodes/infix_operation' # nary require 'arel/nodes/and' diff --git a/lib/arel/nodes/infix_operation.rb b/lib/arel/nodes/infix_operation.rb new file mode 100644 index 0000000000..6847650fe4 --- /dev/null +++ b/lib/arel/nodes/infix_operation.rb @@ -0,0 +1,42 @@ +module Arel + module Nodes + + class InfixOperation < Binary + include Arel::Expressions + include Arel::Predications + include Arel::Math + + attr_reader :operator + + def initialize operator, left, right + super(left, right) + @operator = operator + end + end + + class Multiplication < InfixOperation + def initialize left, right + super(:*, left, right) + end + end + + class Division < InfixOperation + def initialize left, right + super(:/, left, right) + end + end + + class Addition < InfixOperation + def initialize left, right + super(:+, left, right) + end + end + + class Subtraction < InfixOperation + def initialize left, right + super(:-, left, right) + end + end + + end +end
\ No newline at end of file diff --git a/lib/arel/nodes/math_operation.rb b/lib/arel/nodes/math_operation.rb deleted file mode 100644 index d9820f1ece..0000000000 --- a/lib/arel/nodes/math_operation.rb +++ /dev/null @@ -1,15 +0,0 @@ -module Arel - module Nodes - class MathOperation < Binary - include Arel::Expressions - include Arel::Predications - include Arel::Math - end - - class Multiplication < MathOperation; end - class Division < MathOperation; end - class Addition < MathOperation; end - class Subtraction < MathOperation; end - - end -end
\ No newline at end of file diff --git a/lib/arel/predications.rb b/lib/arel/predications.rb index 920a9ee374..75c4c75855 100644 --- a/lib/arel/predications.rb +++ b/lib/arel/predications.rb @@ -1,7 +1,7 @@ module Arel module Predications def as other - Nodes::As.new self, other + Nodes::As.new self, Nodes::SqlLiteral.new(other) end def not_eq other diff --git a/lib/arel/visitors/to_sql.rb b/lib/arel/visitors/to_sql.rb index 6bf5a3bb6b..1c91d7f5e6 100644 --- a/lib/arel/visitors/to_sql.rb +++ b/lib/arel/visitors/to_sql.rb @@ -374,21 +374,14 @@ key on UpdateManager using UpdateManager#key= alias :visit_Time :quoted alias :visit_TrueClass :quoted - def visit_Arel_Nodes_Multiplication o - "#{visit o.left} * #{visit o.right}" + def visit_Arel_Nodes_InfixOperation o + "#{visit o.left} #{o.operator} #{visit o.right}" end - def visit_Arel_Nodes_Division o - "#{visit o.left} / #{visit o.right}" - end - - def visit_Arel_Nodes_Addition o - "(#{visit o.left} + #{visit o.right})" - end - - def visit_Arel_Nodes_Subtraction o - "(#{visit o.left} - #{visit o.right})" - end + alias :visit_Arel_Nodes_Addition :visit_Arel_Nodes_InfixOperation + alias :visit_Arel_Nodes_Subtraction :visit_Arel_Nodes_InfixOperation + alias :visit_Arel_Nodes_Multiplication :visit_Arel_Nodes_InfixOperation + alias :visit_Arel_Nodes_Division :visit_Arel_Nodes_InfixOperation def visit_Array o o.empty? ? 'NULL' : o.map { |x| visit x }.join(', ') |