aboutsummaryrefslogtreecommitdiffstats
path: root/lib/arel/engines/sql/formatters.rb
diff options
context:
space:
mode:
Diffstat (limited to 'lib/arel/engines/sql/formatters.rb')
-rw-r--r--lib/arel/engines/sql/formatters.rb138
1 files changed, 0 insertions, 138 deletions
diff --git a/lib/arel/engines/sql/formatters.rb b/lib/arel/engines/sql/formatters.rb
deleted file mode 100644
index da899902ff..0000000000
--- a/lib/arel/engines/sql/formatters.rb
+++ /dev/null
@@ -1,138 +0,0 @@
-module Arel
- module Sql
- class Formatter
- attr_reader :environment, :christener, :engine
-
- def initialize(environment)
- @environment = environment
- @christener = environment.christener
- @engine = environment.engine
- end
-
- def name_for thing
- @christener.name_for thing
- end
-
- def quote_column_name name
- @engine.connection.quote_column_name name
- end
-
- def quote_table_name name
- @engine.connection.quote_table_name name
- end
-
- def quote value, column = nil
- @engine.connection.quote value, column
- end
- end
-
- class SelectClause < Formatter
- def attribute(attribute)
- "#{quote_table_name(name_for(attribute.original_relation))}.#{quote_column_name(attribute.name)}" +
- (attribute.alias ? " AS #{quote(attribute.alias.to_s)}" : "")
- end
-
- def expression(expression)
- if expression.function_sql == "DISTINCT"
- "#{expression.function_sql} #{expression.attribute.to_sql(self)}" +
- (expression.alias ? " AS #{quote_column_name(expression.alias)}" : '')
- else
- "#{expression.function_sql}(#{expression.attribute.to_sql(self)})" +
- (expression.alias ? " AS #{quote_column_name(expression.alias)}" : " AS #{expression.function_sql.to_s.downcase}_id")
- end
- end
-
- def select(select_sql, table)
- "(#{select_sql}) AS #{quote_table_name(name_for(table))}"
- end
-
- def value(value)
- value
- end
- end
-
- class PassThrough < Formatter
- def value(value)
- value
- end
- end
-
- class WhereClause < PassThrough
- end
-
- class OrderClause < PassThrough
- def ordering(ordering)
- "#{quote_table_name(name_for(ordering.attribute.original_relation))}.#{quote_column_name(ordering.attribute.name)} #{ordering.direction_sql}"
- end
- end
-
- class GroupClause < PassThrough
- def attribute(attribute)
- "#{quote_table_name(name_for(attribute.original_relation))}.#{quote_column_name(attribute.name)}"
- end
- end
-
- class HavingClause < PassThrough
- def attribute(attribute)
- attribute
- end
- end
-
- class WhereCondition < Formatter
- def attribute(attribute)
- "#{quote_table_name(name_for(attribute.original_relation))}.#{quote_column_name(attribute.name)}"
- end
-
- def expression(expression)
- "#{expression.function_sql}(#{expression.attribute.to_sql(self)})"
- end
-
- def value(value)
- value.to_sql(self)
- end
-
- def scalar(value, column = nil)
- quote(value, column)
- end
-
- def select(select_sql, table)
- "(#{select_sql})"
- end
- end
-
- class SelectStatement < Formatter
- def select(select_sql, table)
- select_sql
- end
- end
-
- class TableReference < Formatter
- def select(select_sql, table)
- "(#{select_sql}) #{quote_table_name(name_for(table))}"
- end
-
- def table(table)
- table_name = table.name
- return table_name if table_name =~ /\s/
-
- unique_name = name_for(table)
-
- quote_table_name(table_name) +
- (table_name != unique_name ? " #{quote_table_name(unique_name)}" : '')
- end
- end
-
- class Attribute < WhereCondition
- def scalar(scalar)
- quote(scalar, environment.column)
- end
-
- def range(left, right)
- "#{scalar(left)} AND #{scalar(right)}"
- end
- end
-
- class Value < WhereCondition
- end
- end
-end