duckdb 0.5.1 → 0.6.1

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: fb0ae46a8621f1ea98471f78e708c0a164af484accf51b46d629cce1298f2cd4
4
- data.tar.gz: 5f83eb6e97eefe61d8f2be889269b777717fac860d39cab28475aeb5719bcec9
3
+ metadata.gz: 9967f34d6c3a9f9d30fc9c406043230d86ffe98d0ca5cf55e74a547f6877b756
4
+ data.tar.gz: e28bce3d7b8410ceff6da630aaa54eab4d345bfab16748f9150dfef6e3836bfe
5
5
  SHA512:
6
- metadata.gz: c908703791872e519310118d53b16a8b855518bff749b00ec6538858e0ec1664586a799921fd84cd2d334ef4f2b3b384a632f476e0b61c84b6392deb9b0ff89d
7
- data.tar.gz: f83106674968f42a0d8ef7bb8cdee42c6124fbc10b5576faca26832e968ba7e7cca42f82fb74dd1fdb3482f4d3f27b9b3ca326e1f655a4841fb70e40e43cc987
6
+ metadata.gz: 834d11017be58ad60d8f8d8600e22f7e97dbac4ef2789921d2da8f76487e7df3c60a7458ece7e7d5f3fb7d1aca3bcf178557968131673055c2bf2d932bc982d6
7
+ data.tar.gz: f63d824d611095b857310f6f2f1c432d0129be7bbc3d03cb339baf938bd00c43e7911689b988494e4613f4199abf72a1b08c022d7adac26cc29f2e13ecd49883
@@ -15,11 +15,11 @@ jobs:
15
15
  runs-on: macos-latest
16
16
  strategy:
17
17
  matrix:
18
- ruby: ['2.6.10', '2.7.6', '3.0.4', '3.1.2', '3.2.0-preview2', 'head']
19
- duckdb: ['0.5.1', '0.5.0']
18
+ ruby: ['2.6.10', '2.7.7', '3.0.5', '3.1.3', '3.2.0', 'head']
19
+ duckdb: ['0.5.1', '0.6.1']
20
20
 
21
21
  steps:
22
- - uses: actions/checkout@v2
22
+ - uses: actions/checkout@v3
23
23
 
24
24
  - name: Set up Ruby
25
25
  uses: ruby/setup-ruby@v1
@@ -28,7 +28,7 @@ jobs:
28
28
 
29
29
  - name: duckdb cache
30
30
  id: duckdb-cache
31
- uses: actions/cache@v2
31
+ uses: actions/cache@v3
32
32
  with:
33
33
  path: duckdb-v${{ matrix.duckdb }}
34
34
  key: ${{ runner.os }}-duckdb-v${{ matrix.duckdb }}
@@ -15,11 +15,11 @@ jobs:
15
15
  runs-on: ubuntu-latest
16
16
  strategy:
17
17
  matrix:
18
- ruby: ['2.6.10', '2.7.6', '3.0.4', '3.1.2', '3.2.0-preview2', 'head']
19
- duckdb: ['0.5.1', '0.5.0']
18
+ ruby: ['2.6.10', '2.7.7', '3.0.5', '3.1.3', '3.2.0', 'head']
19
+ duckdb: ['0.5.1', '0.6.1']
20
20
 
21
21
  steps:
22
- - uses: actions/checkout@v2
22
+ - uses: actions/checkout@v3
23
23
 
24
24
  - name: Set up Ruby
25
25
  uses: ruby/setup-ruby@v1
@@ -28,7 +28,7 @@ jobs:
28
28
 
29
29
  - name: duckdb cache
30
30
  id: duckdb-cache
31
- uses: actions/cache@v2
31
+ uses: actions/cache@v3
32
32
  with:
33
33
  path: duckdb-v${{ matrix.duckdb }}
34
34
  key: ${{ runner.os }}-duckdb-v${{ matrix.duckdb }}
@@ -16,10 +16,10 @@ jobs:
16
16
  strategy:
17
17
  matrix:
18
18
  ruby: ['2.6.10', '2.7.6', '3.0.4', '3.1.2', 'ucrt', 'mingw', 'head']
19
- duckdb: ['0.5.1', '0.5.0']
19
+ duckdb: ['0.5.1', '0.6.1']
20
20
 
21
21
  steps:
22
- - uses: actions/checkout@v2
22
+ - uses: actions/checkout@v3
23
23
 
24
24
  - name: Set up Ruby
25
25
  uses: ruby/setup-ruby@v1
data/CHANGELOG.md CHANGED
@@ -1,13 +1,30 @@
1
1
  # ChangeLog
2
2
 
3
+ # 0.6.1
4
+ - bump Ruby to 3.2.0 on CI
5
+ - fix deprected warning (double_heap is deprecated in GC.verify_compaction_references) with Ruby 3.2.0 on CI
6
+ - bump duckdb to 0.6.1 on CI
7
+ - add DuckDB::PreparedStatement#bind_hugeint_internal
8
+ - fix gem install error on M1 MacOS
9
+ - implement DuckDB.library_version
10
+ - use duckdb_value_string instead of duckdb_value_varchar if duckdb_value_string is available.
11
+ - bump Ruby to 3.2.0rc1
12
+ - bump duckdb to 0.6.0
13
+
14
+ ## Breaking Change
15
+ - drop duckdb <= 0.4.x. ruby-duckdb supports duckdb >= 0.5.0
16
+
17
+ # 0.5.1.1
18
+ - bug fix: reading the boolean column
19
+
3
20
  # 0.5.1
4
- - bump duckdb 0.5.1
21
+ - bump duckdb to 0.5.1
5
22
 
6
23
  # 0.5.0
7
24
  - update bundle version of Gemfile.lock
8
25
  - add ruby ucrt test on Windows
9
26
  - use TypedData_Wrap_Struct, TypedData_Get_Struct
10
- - bump duckdb 0.5.0
27
+ - bump duckdb to 0.5.0
11
28
  - fix utf-8 encoding.
12
29
  - add DuckDB::Result#enum_dictionary_values
13
30
  - add DuckDB::Result#row_count, DuckDB::Result#row_size(alias of row_count).
@@ -17,19 +34,19 @@
17
34
  - bind_varchar does not raised DuckDB::Error when the binding column is date or datetime.
18
35
 
19
36
  # 0.3.4.0
20
- - bump duckdb 0.3.4
37
+ - bump duckdb to 0.3.4
21
38
 
22
39
  # 0.3.3.0
23
40
  - DuckDB::Column#type supports :decimal.
24
- - bump duckdb 0.3.3.
25
- - bump Ruby 2.6.10, 2.7.6, 3.0.4, 3.1.2.
41
+ - bump duckdb to 0.3.3.
42
+ - bump Ruby to 2.6.10, 2.7.6, 3.0.4, 3.1.2.
26
43
 
27
44
  # 0.3.2.0
28
45
 
29
46
  - bind_time, bind_timestamp, bind_date, bind_timeinterval to DuckDB::PreparedStatement
30
47
  - bump duckdb 0.3.2
31
- - bump Ruby 3.1.1, add Ruby mingw in CI.
32
- - bump Ruby 2.6.9, 2.7.5, 3.0.3 in CI.
48
+ - bump Ruby to 3.1.1, add Ruby mingw in CI.
49
+ - bump Ruby to 2.6.9, 2.7.5, 3.0.3 in CI.
33
50
 
34
51
  ## BREAKING CHANGE
35
52
  - drop duckdb <= 0.2.8
data/Gemfile.lock CHANGED
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- duckdb (0.5.1)
4
+ duckdb (0.6.1)
5
5
 
6
6
  GEM
7
7
  remote: https://rubygems.org/
data/ext/duckdb/duckdb.c CHANGED
@@ -2,10 +2,24 @@
2
2
 
3
3
  VALUE mDuckDB;
4
4
 
5
+ #ifdef HAVE_DUCKDB_H_GE_V060
6
+ static VALUE duckdb_s_library_version(VALUE self);
7
+ #endif
8
+
9
+ #ifdef HAVE_DUCKDB_H_GE_V060
10
+ static VALUE duckdb_s_library_version(VALUE self) {
11
+ return rb_str_new2(duckdb_library_version());
12
+ }
13
+ #endif
14
+
5
15
  void
6
16
  Init_duckdb_native(void) {
7
17
  mDuckDB = rb_define_module("DuckDB");
8
18
 
19
+ #ifdef HAVE_DUCKDB_H_GE_V060
20
+ rb_define_singleton_method(mDuckDB, "library_version", duckdb_s_library_version, 0);
21
+ #endif
22
+
9
23
  init_duckdb_error();
10
24
  init_duckdb_database();
11
25
  init_duckdb_connection();
@@ -1,15 +1,34 @@
1
1
  require 'mkmf'
2
2
 
3
- dir_config('duckdb')
3
+ def duckdb_library_available?(func)
4
+ header = find_header('duckdb.h') || find_header('duckdb.h', '/opt/homebrew/include')
5
+ library = have_func('duckdb', func) || find_library('duckdb', func, '/opt/homebrew/opt/duckdb/lib')
6
+ header && library
7
+ end
8
+
9
+ def check_duckdb_library(func, version)
10
+ return if duckdb_library_available?(func)
4
11
 
5
- raise 'duckdb library is not found. Install duckdb library file and header file.' unless have_library('duckdb')
12
+ msg = "duckdb >= #{version} is not found. Install duckdb >= #{version} library and header file."
13
+ puts ''
14
+ puts '*' * 80
15
+ puts msg
16
+ puts '*' * 80
17
+ puts ''
18
+ raise msg
19
+ end
6
20
 
7
- raise 'duckdb >= 0.2.9 is required. Install duckdb >= 0.2.9' unless have_func('duckdb_value_is_null', 'duckdb.h')
21
+ dir_config('duckdb')
22
+
23
+ check_duckdb_library('duckdb_pending_prepared', '0.5.0')
8
24
 
9
25
  # check duckdb >= 0.3.3
10
26
  # ducdb >= 0.3.3 if duckdb_append_data_chunk() is defined.
11
27
  have_func('duckdb_append_data_chunk', 'duckdb.h')
12
28
 
29
+ # check duckdb >= 0.6.0
30
+ have_func('duckdb_value_string', 'duckdb.h')
31
+
13
32
  have_func('duckdb_free', 'duckdb.h')
14
33
 
15
34
  create_makefile('duckdb/duckdb_native')
@@ -23,6 +23,7 @@ static VALUE duckdb_prepared_statement__bind_date(VALUE self, VALUE vidx, VALUE
23
23
  static VALUE duckdb_prepared_statement__bind_time(VALUE self, VALUE vidx, VALUE hour, VALUE min, VALUE sec, VALUE micros);
24
24
  static VALUE duckdb_prepared_statement__bind_timestamp(VALUE self, VALUE vidx, VALUE year, VALUE month, VALUE day, VALUE hour, VALUE min, VALUE sec, VALUE micros);
25
25
  static VALUE duckdb_prepared_statement__bind_interval(VALUE self, VALUE vidx, VALUE months, VALUE days, VALUE micros);
26
+ static VALUE duckdb_prepared_statement__bind_hugeint(VALUE self, VALUE vidx, VALUE lower, VALUE upper);
26
27
 
27
28
  static const rb_data_type_t prepared_statement_data_type = {
28
29
  "DuckDB/PreparedStatement",
@@ -283,6 +284,22 @@ static VALUE duckdb_prepared_statement__bind_interval(VALUE self, VALUE vidx, VA
283
284
  return self;
284
285
  }
285
286
 
287
+ static VALUE duckdb_prepared_statement__bind_hugeint(VALUE self, VALUE vidx, VALUE lower, VALUE upper) {
288
+ duckdb_hugeint hugeint;
289
+ rubyDuckDBPreparedStatement *ctx;
290
+ idx_t idx = check_index(vidx);
291
+
292
+ TypedData_Get_Struct(self, rubyDuckDBPreparedStatement, &prepared_statement_data_type, ctx);
293
+ hugeint.lower = NUM2ULL(lower);
294
+ hugeint.upper = NUM2LL(upper);
295
+
296
+ if (duckdb_bind_hugeint(ctx->prepared_statement, idx, hugeint) == DuckDBError) {
297
+ rb_raise(eDuckDBError, "fail to bind %llu parameter", (unsigned long long)idx);
298
+ }
299
+
300
+ return self;
301
+ }
302
+
286
303
  void init_duckdb_prepared_statement(void) {
287
304
  cDuckDBPreparedStatement = rb_define_class_under(mDuckDB, "PreparedStatement", rb_cObject);
288
305
 
@@ -305,4 +322,5 @@ void init_duckdb_prepared_statement(void) {
305
322
  rb_define_private_method(cDuckDBPreparedStatement, "_bind_time", duckdb_prepared_statement__bind_time, 5);
306
323
  rb_define_private_method(cDuckDBPreparedStatement, "_bind_timestamp", duckdb_prepared_statement__bind_timestamp, 8);
307
324
  rb_define_private_method(cDuckDBPreparedStatement, "_bind_interval", duckdb_prepared_statement__bind_interval, 4);
325
+ rb_define_private_method(cDuckDBPreparedStatement, "_bind_hugeint", duckdb_prepared_statement__bind_hugeint, 3);
308
326
  }
data/ext/duckdb/result.c CHANGED
@@ -62,7 +62,7 @@ rubyDuckDBResult *get_struct_result(VALUE obj) {
62
62
 
63
63
  static VALUE to_ruby_obj_boolean(duckdb_result *result, idx_t col_idx, idx_t row_idx) {
64
64
  bool bval = duckdb_value_boolean(result, col_idx, row_idx);
65
- return bval ? Qtrue : Qnil;
65
+ return bval ? Qtrue : Qfalse;
66
66
  }
67
67
 
68
68
  static VALUE to_ruby_obj_smallint(duckdb_result *result, idx_t col_idx, idx_t row_idx) {
@@ -271,14 +271,25 @@ static VALUE duckdb_result__to_double(VALUE oDuckDBResult, VALUE row_idx, VALUE
271
271
 
272
272
  static VALUE duckdb_result__to_string(VALUE oDuckDBResult, VALUE row_idx, VALUE col_idx) {
273
273
  rubyDuckDBResult *ctx;
274
+ #ifdef HAVE_DUCKDB_H_GE_V060
275
+ duckdb_string p;
276
+ #else
274
277
  char *p;
278
+ #endif
275
279
  VALUE obj;
276
280
  TypedData_Get_Struct(oDuckDBResult, rubyDuckDBResult, &result_data_type, ctx);
277
281
 
282
+ #ifdef HAVE_DUCKDB_H_GE_V060
283
+ p = duckdb_value_string(&(ctx->result), NUM2LL(col_idx), NUM2LL(row_idx));
284
+ if (p.data) {
285
+ obj = rb_utf8_str_new(p.data, p.size);
286
+ duckdb_free(p.data);
287
+ #else
278
288
  p = duckdb_value_varchar(&(ctx->result), NUM2LL(col_idx), NUM2LL(row_idx));
279
289
  if (p) {
280
290
  obj = rb_utf8_str_new_cstr(p);
281
291
  duckdb_free(p);
292
+ #endif
282
293
  return obj;
283
294
  }
284
295
  return Qnil;
@@ -8,6 +8,10 @@
8
8
  #define HAVE_DUCKDB_H_GE_V033 1
9
9
  #endif
10
10
 
11
+ #ifdef HAVE_DUCKDB_VALUE_STRING
12
+ #define HAVE_DUCKDB_H_GE_V060 1
13
+ #endif
14
+
11
15
  #include "./error.h"
12
16
  #include "./database.h"
13
17
  #include "./connection.h"
@@ -33,15 +33,8 @@ module DuckDB
33
33
  # .end_row
34
34
  #
35
35
  def append_hugeint(value)
36
- case value
37
- when Integer
38
- half = 1 << 64
39
- upper = value / half
40
- lower = value - upper * half
41
- _append_hugeint(lower, upper)
42
- else
43
- raise(ArgumentError, "2nd argument `#{value}` must be Integer.")
44
- end
36
+ lower, upper = integer_to_hugeint(value)
37
+ _append_hugeint(lower, upper)
45
38
  end
46
39
 
47
40
  #
@@ -1,7 +1,20 @@
1
1
  module DuckDB
2
2
  module Converter
3
+ HALF_HUGEINT = 1 << 64
4
+
3
5
  private
4
6
 
7
+ def integer_to_hugeint(value)
8
+ case value
9
+ when Integer
10
+ upper = value / HALF_HUGEINT
11
+ lower = value - upper * HALF_HUGEINT
12
+ [lower, upper]
13
+ else
14
+ raise(ArgumentError, "2nd argument `#{value}` must be Integer.")
15
+ end
16
+ end
17
+
5
18
  def iso8601_interval_to_hash(value)
6
19
  digit = ''
7
20
  time = false
@@ -15,10 +15,21 @@ module DuckDB
15
15
  class PreparedStatement
16
16
  include DuckDB::Converter
17
17
 
18
- RANGE_INT16 = -32768..32767
19
- RANGE_INT32 = -2147483648..2147483647
20
- RANGE_INT64 = -9223372036854775808..9223372036854775807
18
+ RANGE_INT16 = -32_768..32_767
19
+ RANGE_INT32 = -2_147_483_648..2_147_483_647
20
+ RANGE_INT64 = -9_223_372_036_854_775_808..9_223_372_036_854_775_807
21
21
 
22
+ # binds i-th parameter with SQL prepared statement.
23
+ # The first argument is index of parameter.
24
+ # The index of first parameter is 1 not 0.
25
+ # The second argument value is to expected Integer value.
26
+ # This method uses bind_varchar internally.
27
+ # require 'duckdb'
28
+ # db = DuckDB::Database.open('duckdb_database')
29
+ # con = db.connect
30
+ # sql ='SELECT name FROM users WHERE bigint_col = ?'
31
+ # stmt = PreparedStatement.new(con, sql)
32
+ # stmt.bind_hugeint(1, 1_234_567_890_123_456_789_012_345)
22
33
  def bind_hugeint(i, value)
23
34
  case value
24
35
  when Integer
@@ -28,6 +39,22 @@ module DuckDB
28
39
  end
29
40
  end
30
41
 
42
+ # binds i-th parameter with SQL prepared statement.
43
+ # The first argument is index of parameter.
44
+ # The index of first parameter is 1 not 0.
45
+ # The second argument value must be Integer value.
46
+ # This method uses duckdb_bind_hugeint internally.
47
+ # require 'duckdb'
48
+ # db = DuckDB::Database.open('duckdb_database')
49
+ # con = db.connect
50
+ # sql ='SELECT name FROM users WHERE bigint_col = ?'
51
+ # stmt = PreparedStatement.new(con, sql)
52
+ # stmt.bind_hugeint_internal(1, 1_234_567_890_123_456_789_012_345)
53
+ def bind_hugeint_internal(index, value)
54
+ lower, upper = integer_to_hugeint(value)
55
+ _bind_hugeint(index, lower, upper)
56
+ end
57
+
31
58
  # binds i-th parameter with SQL prepared statement.
32
59
  # The first argument is index of parameter.
33
60
  # The index of first parameter is 1 not 0.
@@ -1,5 +1,5 @@
1
1
  module DuckDB
2
2
  # The version string of ruby-duckdb.
3
3
  # Currently, ruby-duckdb is NOT semantic versioning.
4
- VERSION = '0.5.1'.freeze
4
+ VERSION = '0.6.1'.freeze
5
5
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: duckdb
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.5.1
4
+ version: 0.6.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Masaki Suketa
8
- autorequire:
8
+ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2022-10-15 00:00:00.000000000 Z
11
+ date: 2022-12-30 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler
@@ -129,7 +129,7 @@ metadata:
129
129
  homepage_uri: https://github.com/suketa/ruby-duckdb
130
130
  source_code_uri: https://github.com/suketa/ruby-duckdb
131
131
  changelog_uri: https://github.com/suketa/ruby-duckdb/blob/master/CHANGELOG.md
132
- post_install_message:
132
+ post_install_message:
133
133
  rdoc_options: []
134
134
  require_paths:
135
135
  - lib
@@ -144,8 +144,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
144
144
  - !ruby/object:Gem::Version
145
145
  version: '0'
146
146
  requirements: []
147
- rubygems_version: 3.3.22
148
- signing_key:
147
+ rubygems_version: 3.4.1
148
+ signing_key:
149
149
  specification_version: 4
150
150
  summary: This module is Ruby binding for DuckDB database engine.
151
151
  test_files: []