aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/arel/nodes.rb
diff options
context:
space:
mode:
authorMatthew Draper <matthew@trebex.net>2018-02-24 17:04:15 +1030
committerMatthew Draper <matthew@trebex.net>2018-02-24 17:15:32 +1030
commit17ca17072dcdff11b3702a6b45f2fb0c8f8fe9a4 (patch)
tree38afd3ed74f8afda1c2959fefbc13f70b2e448e2 /activerecord/lib/arel/nodes.rb
parent5ecbeda0e225e4961977b5c516088cf12d92319f (diff)
parenteb3f968b5ffdd3b343e7d190f1aa0b36864f56a2 (diff)
downloadrails-17ca17072dcdff11b3702a6b45f2fb0c8f8fe9a4.tar.gz
rails-17ca17072dcdff11b3702a6b45f2fb0c8f8fe9a4.tar.bz2
rails-17ca17072dcdff11b3702a6b45f2fb0c8f8fe9a4.zip
Merge Arel into Active Record
Diffstat (limited to 'activerecord/lib/arel/nodes.rb')
-rw-r--r--activerecord/lib/arel/nodes.rb66
1 files changed, 66 insertions, 0 deletions
diff --git a/activerecord/lib/arel/nodes.rb b/activerecord/lib/arel/nodes.rb
new file mode 100644
index 0000000000..8c6572dd6a
--- /dev/null
+++ b/activerecord/lib/arel/nodes.rb
@@ -0,0 +1,66 @@
+# frozen_string_literal: true
+# node
+require 'arel/nodes/node'
+require 'arel/nodes/node_expression'
+require 'arel/nodes/select_statement'
+require 'arel/nodes/select_core'
+require 'arel/nodes/insert_statement'
+require 'arel/nodes/update_statement'
+require 'arel/nodes/bind_param'
+
+# terminal
+
+require 'arel/nodes/terminal'
+require 'arel/nodes/true'
+require 'arel/nodes/false'
+
+# unary
+require 'arel/nodes/unary'
+require 'arel/nodes/grouping'
+require 'arel/nodes/ascending'
+require 'arel/nodes/descending'
+require 'arel/nodes/unqualified_column'
+require 'arel/nodes/with'
+
+# binary
+require 'arel/nodes/binary'
+require 'arel/nodes/equality'
+require 'arel/nodes/in' # Why is this subclassed from equality?
+require 'arel/nodes/join_source'
+require 'arel/nodes/delete_statement'
+require 'arel/nodes/table_alias'
+require 'arel/nodes/infix_operation'
+require 'arel/nodes/unary_operation'
+require 'arel/nodes/over'
+require 'arel/nodes/matches'
+require 'arel/nodes/regexp'
+
+# nary
+require 'arel/nodes/and'
+
+# function
+# FIXME: Function + Alias can be rewritten as a Function and Alias node.
+# We should make Function a Unary node and deprecate the use of "aliaz"
+require 'arel/nodes/function'
+require 'arel/nodes/count'
+require 'arel/nodes/extract'
+require 'arel/nodes/values'
+require 'arel/nodes/values_list'
+require 'arel/nodes/named_function'
+
+# windows
+require 'arel/nodes/window'
+
+# conditional expressions
+require 'arel/nodes/case'
+
+# joins
+require 'arel/nodes/full_outer_join'
+require 'arel/nodes/inner_join'
+require 'arel/nodes/outer_join'
+require 'arel/nodes/right_outer_join'
+require 'arel/nodes/string_join'
+
+require 'arel/nodes/sql_literal'
+
+require 'arel/nodes/casted'