querybuilder 0.8.2 → 0.8.3
Sign up to get free protection for your applications and to get access to all the features.
- data/History.txt +6 -0
- data/Rakefile +1 -0
- data/lib/query_builder/info.rb +1 -1
- data/lib/query_builder/parser.rb +1 -1
- data/lib/query_builder/processor.rb +11 -0
- data/lib/querybuilder_ext.c +1324 -1031
- data/lib/querybuilder_ext.rl +7 -0
- data/lib/querybuilder_rb.rb +1196 -914
- data/lib/querybuilder_rb.rl +4 -0
- data/lib/querybuilder_syntax.rl +3 -1
- data/querybuilder.gemspec +3 -2
- data/test/querybuilder/filters.yml +18 -0
- data/test/querybuilder/rubyless.yml +10 -1
- metadata +5 -5
data/lib/querybuilder_rb.rl
CHANGED
data/lib/querybuilder_syntax.rl
CHANGED
@@ -23,8 +23,10 @@
|
|
23
23
|
operator = (op %operator | text_op %operator ws+ );
|
24
24
|
interval = ws+ ('second'|'minute'|'hour'|'day'|'week'|'month'|'year') $str_a %interval 's'?;
|
25
25
|
value = ((field | string | number | rubyless) interval? | ws* '(' >goto_expr_p ws* ')');
|
26
|
+
in_value = (string | number | rubyless) (ws* ',' (string | number | rubyless))*;
|
27
|
+
in_expr = ws+ ('not' $str_a %operator ws+)? 'in' ws* '(' %in_op in_value ws* ')'; # wait until '(' to execute 'operator' to avoid confusion with scope
|
26
28
|
is_null = ws+ 'is' %is ws+ (('not' ws+)* ('null' | 'NULL')) $str_a %raw;
|
27
|
-
expr = value (operator value | is_null)*;
|
29
|
+
expr = value (operator value | in_expr | is_null)*;
|
28
30
|
expr_p := expr ws* ')' $expr_close;
|
29
31
|
|
30
32
|
relation = ws* var %relation;
|
data/querybuilder.gemspec
CHANGED
@@ -5,17 +5,18 @@
|
|
5
5
|
|
6
6
|
Gem::Specification.new do |s|
|
7
7
|
s.name = %q{querybuilder}
|
8
|
-
s.version = "0.8.
|
8
|
+
s.version = "0.8.3"
|
9
9
|
|
10
10
|
s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
|
11
11
|
s.authors = ["Gaspard Bucher"]
|
12
|
-
s.date = %q{2010-08-
|
12
|
+
s.date = %q{2010-08-31}
|
13
13
|
s.description = %q{QueryBuilder is an interpreter for the "pseudo sql" language. This language
|
14
14
|
can be used for two purposes:
|
15
15
|
|
16
16
|
1. protect your database from illegal SQL by securing queries
|
17
17
|
2. ease writing complex relational queries by abstracting table internals}
|
18
18
|
s.email = %q{gaspard@teti.ch}
|
19
|
+
s.extensions = ["lib/extconf.rb"]
|
19
20
|
s.extra_rdoc_files = [
|
20
21
|
"README.rdoc"
|
21
22
|
]
|
@@ -121,3 +121,21 @@ filter_empty_literal:
|
|
121
121
|
src: "objects where \"\" = ''"
|
122
122
|
sxp: '[:query, [:filter, [:relation, "objects"], [:"=", [:dstring, ""], [:string, ""]]]]'
|
123
123
|
sql: "SELECT objects.* FROM objects WHERE '' = '' AND objects.parent_id = 123"
|
124
|
+
|
125
|
+
filter_in_literal:
|
126
|
+
src: "objects where id in (1, 2 , 3,4) in site"
|
127
|
+
sxp: '[:query, [:scope, [:filter, [:relation, "objects"], [:in, [:field, "id"], [:integer, "1"], [:integer, "2"], [:integer, "3"], [:integer, "4"]]], "site"]]'
|
128
|
+
sql: "SELECT objects.* FROM objects WHERE objects.id IN (1,2,3,4)"
|
129
|
+
|
130
|
+
filter_in_string:
|
131
|
+
src: "objects where name in ('paul', 'john') in site"
|
132
|
+
sql: "SELECT objects.* FROM objects WHERE objects.name IN ('paul','john')"
|
133
|
+
|
134
|
+
filter_in_single_literal:
|
135
|
+
src: "objects where id in (1) in site"
|
136
|
+
sql: "SELECT objects.* FROM objects WHERE objects.id IN (1)"
|
137
|
+
|
138
|
+
filter_not_in_literal:
|
139
|
+
src: "objects where id not in (1, 2 , 3,4) in site"
|
140
|
+
sxp: '[:query, [:scope, [:filter, [:relation, "objects"], [:not, [:in, [:field, "id"], [:integer, "1"], [:integer, "2"], [:integer, "3"], [:integer, "4"]]]], "site"]]'
|
141
|
+
sql: "SELECT objects.* FROM objects WHERE objects.id NOT IN (1,2,3,4)"
|
@@ -12,4 +12,13 @@ eval:
|
|
12
12
|
|
13
13
|
date_function:
|
14
14
|
src: 'objects where name = #{params[:name]}.year'
|
15
|
-
res: "/objects.name = strftime\('%Y',\?\)/"
|
15
|
+
res: "/objects.name = strftime\('%Y',\?\)/"
|
16
|
+
|
17
|
+
filter_in_rubyless:
|
18
|
+
src: "objects where id in (#{params[:d]}) in site"
|
19
|
+
sxp: '[:query, [:scope, [:filter, [:relation, "objects"], [:in, [:field, "id"], [:rubyless, "params[:d]"]]], "site"]]'
|
20
|
+
res: "[%Q{SELECT objects.* FROM objects WHERE objects.id IN (?)}, get_params[:d]]"
|
21
|
+
|
22
|
+
filter_in_mixed:
|
23
|
+
src: 'objects where name in ("hello", #{params[:p]})'
|
24
|
+
res: "[%Q{SELECT objects.* FROM objects WHERE objects.name IN ('hello',?) AND objects.parent_id = ?}, get_params[:p], id]"
|
metadata
CHANGED
@@ -5,8 +5,8 @@ version: !ruby/object:Gem::Version
|
|
5
5
|
segments:
|
6
6
|
- 0
|
7
7
|
- 8
|
8
|
-
-
|
9
|
-
version: 0.8.
|
8
|
+
- 3
|
9
|
+
version: 0.8.3
|
10
10
|
platform: ruby
|
11
11
|
authors:
|
12
12
|
- Gaspard Bucher
|
@@ -14,7 +14,7 @@ autorequire:
|
|
14
14
|
bindir: bin
|
15
15
|
cert_chain: []
|
16
16
|
|
17
|
-
date: 2010-08-
|
17
|
+
date: 2010-08-31 00:00:00 +02:00
|
18
18
|
default_executable:
|
19
19
|
dependencies:
|
20
20
|
- !ruby/object:Gem::Dependency
|
@@ -66,8 +66,8 @@ description: |-
|
|
66
66
|
email: gaspard@teti.ch
|
67
67
|
executables: []
|
68
68
|
|
69
|
-
extensions:
|
70
|
-
|
69
|
+
extensions:
|
70
|
+
- lib/extconf.rb
|
71
71
|
extra_rdoc_files:
|
72
72
|
- README.rdoc
|
73
73
|
files:
|