firebird_adapter 1.0.9 → 1.0.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: b883397149a00311a5ec04e597e2ae4305564be4163a1474cd657b97138f5fb1
|
4
|
+
data.tar.gz: bb47ae1a74848ffac5c1d496a19bd2bc58c957b2aec6d95852136efb0a419365
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: bbcc9993628a18def8bd607746d0dba75ec04ff43a4e741a31772d063b7032813724ef4bb4d0e306d576e377e17d24f75e4cfc8847daf63ded2d669eebbca95a
|
7
|
+
data.tar.gz: b86601ebd799a76f3506b9455ca1c4ac75c8db220504ae37dbf6967f00ee64a8d253aeaa5afaad3f597b8b1b56000c5232087634c8da073d7ff059ad403beb24
|
@@ -52,9 +52,11 @@ module ActiveRecord::ConnectionAdapters::Firebird::DatabaseStatements
|
|
52
52
|
else
|
53
53
|
ActiveRecord::Result.new([], [])
|
54
54
|
end
|
55
|
-
rescue RangeError
|
56
|
-
ActiveRecord::Result.new([], [])
|
55
|
+
rescue RangeError => e
|
56
|
+
return ActiveRecord::Result.new([], []) if sql.downcase.start_with? 'select'
|
57
|
+
raise e
|
57
58
|
rescue Exception => e
|
59
|
+
result.close if result.is_a?(Fb::Cursor)
|
58
60
|
raise e.message.encode('UTF-8', @connection.encoding)
|
59
61
|
end
|
60
62
|
end
|
@@ -109,6 +109,10 @@ module ActiveRecord::ConnectionAdapters::Firebird::SchemaStatements
|
|
109
109
|
|
110
110
|
private
|
111
111
|
|
112
|
+
def remove_column_for_alter(table_name, column_name, type = nil, options = {})
|
113
|
+
"DROP #{quote_column_name(column_name)}"
|
114
|
+
end
|
115
|
+
|
112
116
|
def column_definitions(table_name)
|
113
117
|
@connection.columns(table_name)
|
114
118
|
end
|
@@ -1,63 +1,88 @@
|
|
1
|
-
|
1
|
+
module Arel
|
2
|
+
class SelectManager
|
3
|
+
attr_reader :parentheses_ignored
|
2
4
|
|
3
|
-
|
5
|
+
def ignore_parentheses
|
6
|
+
@parentheses_ignored = true
|
7
|
+
self
|
8
|
+
end
|
9
|
+
end
|
4
10
|
|
5
|
-
|
6
|
-
|
11
|
+
class Visitors::Firebird < Arel::Visitors::ToSql
|
12
|
+
private
|
7
13
|
|
8
|
-
|
14
|
+
def visit_Arel_Nodes_SelectCore(o, collector, select_statement)
|
15
|
+
collector << 'SELECT'
|
9
16
|
|
10
|
-
|
17
|
+
visit_Arel_Nodes_SelectOptions(select_statement, collector)
|
11
18
|
|
12
|
-
|
19
|
+
collector = maybe_visit o.top, collector
|
13
20
|
|
14
|
-
|
21
|
+
collector = maybe_visit o.set_quantifier, collector
|
15
22
|
|
16
|
-
|
17
|
-
collector << ' FROM '
|
18
|
-
collector = visit o.source, collector
|
19
|
-
end
|
23
|
+
collect_nodes_for o.projections, collector, SPACE
|
20
24
|
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
inject_join o.havings, collector, AND
|
26
|
-
end
|
27
|
-
collect_nodes_for o.windows, collector, WINDOW
|
25
|
+
if o.source && !o.source.empty?
|
26
|
+
collector << ' FROM '
|
27
|
+
collector = visit o.source, collector
|
28
|
+
end
|
28
29
|
|
29
|
-
|
30
|
-
|
30
|
+
collect_nodes_for o.wheres, collector, WHERE, AND
|
31
|
+
collect_nodes_for o.groups, collector, GROUP_BY
|
32
|
+
unless o.havings.empty?
|
33
|
+
collector << ' HAVING '
|
34
|
+
inject_join o.havings, collector, AND
|
35
|
+
end
|
36
|
+
collect_nodes_for o.windows, collector, WINDOW
|
31
37
|
|
32
|
-
|
33
|
-
if o.with
|
34
|
-
collector = visit o.with, collector
|
35
|
-
collector << SPACE
|
38
|
+
collector
|
36
39
|
end
|
37
40
|
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
+
def visit_Arel_Nodes_SelectStatement o, collector
|
42
|
+
if o.with
|
43
|
+
collector = visit o.with, collector
|
44
|
+
collector << SPACE
|
45
|
+
end
|
41
46
|
|
42
|
-
|
43
|
-
|
44
|
-
len = o.orders.length - 1
|
45
|
-
o.orders.each_with_index { |x, i|
|
46
|
-
collector = visit(x, collector)
|
47
|
-
collector << COMMA unless len == i
|
47
|
+
collector = o.cores.inject(collector) { |c,x|
|
48
|
+
visit_Arel_Nodes_SelectCore(x, c, o)
|
48
49
|
}
|
50
|
+
|
51
|
+
unless o.orders.empty?
|
52
|
+
collector << ORDER_BY
|
53
|
+
len = o.orders.length - 1
|
54
|
+
o.orders.each_with_index { |x, i|
|
55
|
+
collector = visit(x, collector)
|
56
|
+
collector << COMMA unless len == i
|
57
|
+
}
|
58
|
+
end
|
59
|
+
|
60
|
+
collector
|
49
61
|
end
|
50
62
|
|
51
|
-
collector
|
52
|
-
|
63
|
+
def visit_Arel_Nodes_Limit(o, collector)
|
64
|
+
collector << 'FIRST '
|
65
|
+
visit o.expr, collector
|
66
|
+
end
|
53
67
|
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
68
|
+
def visit_Arel_Nodes_Offset(o, collector)
|
69
|
+
collector << 'SKIP '
|
70
|
+
visit o.expr, collector
|
71
|
+
end
|
72
|
+
|
73
|
+
def visit_Arel_SelectManager o, collector
|
74
|
+
return visit(o.ast, collector) if o.parentheses_ignored
|
75
|
+
|
76
|
+
collector << '('
|
77
|
+
visit(o.ast, collector) << ')'
|
78
|
+
end
|
79
|
+
|
80
|
+
def visit_Arel_Nodes_Union o, collector
|
81
|
+
infix_value(o, collector, ' UNION ')
|
82
|
+
end
|
58
83
|
|
59
|
-
|
60
|
-
|
61
|
-
|
84
|
+
def visit_Arel_Nodes_UnionAll o, collector
|
85
|
+
infix_value(o, collector, ' UNION ALL ')
|
86
|
+
end
|
62
87
|
end
|
63
|
-
end
|
88
|
+
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: firebird_adapter
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.0.
|
4
|
+
version: 1.0.14
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Fábio Rodrigues
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2020-12-21 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|
@@ -143,8 +143,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
143
143
|
- !ruby/object:Gem::Version
|
144
144
|
version: '0'
|
145
145
|
requirements: []
|
146
|
-
|
147
|
-
rubygems_version: 2.7.7
|
146
|
+
rubygems_version: 3.0.3
|
148
147
|
signing_key:
|
149
148
|
specification_version: 4
|
150
149
|
summary: ActiveRecord Firebird Adapter for Rails 5.
|