sqlite3 1.7.3 → 2.5.0
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 +4 -4
- data/CHANGELOG.md +292 -0
- data/CONTRIBUTING.md +33 -7
- data/FAQ.md +43 -77
- data/INSTALLATION.md +14 -6
- data/LICENSE +18 -22
- data/README.md +97 -9
- data/dependencies.yml +10 -11
- data/ext/sqlite3/aggregator.c +142 -145
- data/ext/sqlite3/aggregator.h +2 -4
- data/ext/sqlite3/backup.c +74 -65
- data/ext/sqlite3/backup.h +2 -2
- data/ext/sqlite3/database.c +621 -493
- data/ext/sqlite3/database.h +13 -4
- data/ext/sqlite3/exception.c +116 -92
- data/ext/sqlite3/exception.h +5 -1
- data/ext/sqlite3/extconf.rb +33 -24
- data/ext/sqlite3/sqlite3.c +176 -115
- data/ext/sqlite3/sqlite3_ruby.h +2 -2
- data/ext/sqlite3/statement.c +553 -300
- data/ext/sqlite3/statement.h +4 -3
- data/ext/sqlite3/timespec.h +20 -0
- data/lib/sqlite3/constants.rb +195 -47
- data/lib/sqlite3/database.rb +223 -187
- data/lib/sqlite3/errors.rb +54 -1
- data/lib/sqlite3/fork_safety.rb +66 -0
- data/lib/sqlite3/pragmas.rb +140 -136
- data/lib/sqlite3/resultset.rb +14 -97
- data/lib/sqlite3/statement.rb +58 -13
- data/lib/sqlite3/value.rb +17 -20
- data/lib/sqlite3/version.rb +2 -21
- data/lib/sqlite3/version_info.rb +17 -0
- data/lib/sqlite3.rb +8 -4
- data/ports/archives/sqlite-autoconf-3470200.tar.gz +0 -0
- metadata +9 -37
- data/API_CHANGES.md +0 -49
- data/ChangeLog.cvs +0 -88
- data/Gemfile +0 -10
- data/LICENSE-DEPENDENCIES +0 -20
- data/lib/sqlite3/translator.rb +0 -117
- data/ports/archives/sqlite-autoconf-3450200.tar.gz +0 -0
- data/test/helper.rb +0 -27
- data/test/test_backup.rb +0 -33
- data/test/test_collation.rb +0 -82
- data/test/test_database.rb +0 -668
- data/test/test_database_flags.rb +0 -95
- data/test/test_database_readonly.rb +0 -36
- data/test/test_database_readwrite.rb +0 -41
- data/test/test_deprecated.rb +0 -49
- data/test/test_encoding.rb +0 -165
- data/test/test_integration.rb +0 -507
- data/test/test_integration_aggregate.rb +0 -336
- data/test/test_integration_open_close.rb +0 -30
- data/test/test_integration_pending.rb +0 -115
- data/test/test_integration_resultset.rb +0 -142
- data/test/test_integration_statement.rb +0 -194
- data/test/test_pragmas.rb +0 -22
- data/test/test_result_set.rb +0 -47
- data/test/test_sqlite3.rb +0 -30
- data/test/test_statement.rb +0 -290
- data/test/test_statement_execute.rb +0 -39
data/ext/sqlite3/backup.c
CHANGED
@@ -8,11 +8,12 @@
|
|
8
8
|
|
9
9
|
VALUE cSqlite3Backup;
|
10
10
|
|
11
|
-
static size_t
|
11
|
+
static size_t
|
12
|
+
backup_memsize(const void *data)
|
12
13
|
{
|
13
|
-
|
14
|
-
|
15
|
-
|
14
|
+
sqlite3BackupRubyPtr ctx = (sqlite3BackupRubyPtr)data;
|
15
|
+
// NB: can't account for ctx->p because the type is incomplete.
|
16
|
+
return sizeof(*ctx);
|
16
17
|
}
|
17
18
|
|
18
19
|
static const rb_data_type_t backup_type = {
|
@@ -27,10 +28,11 @@ static const rb_data_type_t backup_type = {
|
|
27
28
|
RUBY_TYPED_FREE_IMMEDIATELY | RUBY_TYPED_WB_PROTECTED,
|
28
29
|
};
|
29
30
|
|
30
|
-
static VALUE
|
31
|
+
static VALUE
|
32
|
+
allocate(VALUE klass)
|
31
33
|
{
|
32
|
-
|
33
|
-
|
34
|
+
sqlite3BackupRubyPtr ctx;
|
35
|
+
return TypedData_Make_Struct(klass, sqlite3BackupRuby, &backup_type, ctx);
|
34
36
|
}
|
35
37
|
|
36
38
|
/* call-seq: SQLite3::Backup.new(dstdb, dstname, srcdb, srcname)
|
@@ -69,31 +71,33 @@ static VALUE allocate(VALUE klass)
|
|
69
71
|
* b.finish
|
70
72
|
*
|
71
73
|
*/
|
72
|
-
static VALUE
|
74
|
+
static VALUE
|
75
|
+
initialize(VALUE self, VALUE dstdb, VALUE dstname, VALUE srcdb, VALUE srcname)
|
73
76
|
{
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
77
|
+
sqlite3BackupRubyPtr ctx;
|
78
|
+
sqlite3RubyPtr ddb_ctx, sdb_ctx;
|
79
|
+
sqlite3_backup *pBackup;
|
80
|
+
|
81
|
+
TypedData_Get_Struct(self, sqlite3BackupRuby, &backup_type, ctx);
|
82
|
+
ddb_ctx = sqlite3_database_unwrap(dstdb);
|
83
|
+
sdb_ctx = sqlite3_database_unwrap(srcdb);
|
84
|
+
|
85
|
+
if (!sdb_ctx->db) {
|
86
|
+
rb_raise(rb_eArgError, "cannot backup from a closed database");
|
87
|
+
}
|
88
|
+
if (!ddb_ctx->db) {
|
89
|
+
rb_raise(rb_eArgError, "cannot backup to a closed database");
|
90
|
+
}
|
91
|
+
|
92
|
+
pBackup = sqlite3_backup_init(ddb_ctx->db, StringValuePtr(dstname),
|
93
|
+
sdb_ctx->db, StringValuePtr(srcname));
|
94
|
+
if (pBackup) {
|
95
|
+
ctx->p = pBackup;
|
96
|
+
} else {
|
97
|
+
CHECK(ddb_ctx->db, sqlite3_errcode(ddb_ctx->db));
|
98
|
+
}
|
99
|
+
|
100
|
+
return self;
|
97
101
|
}
|
98
102
|
|
99
103
|
/* call-seq: SQLite3::Backup#step(nPage)
|
@@ -105,30 +109,32 @@ static VALUE initialize(VALUE self, VALUE dstdb, VALUE dstname, VALUE srcdb, VAL
|
|
105
109
|
* When coping is not done, it returns SQLite3::Constants::ErrorCode::OK.
|
106
110
|
* When some errors occur, it returns the error code.
|
107
111
|
*/
|
108
|
-
static VALUE
|
112
|
+
static VALUE
|
113
|
+
step(VALUE self, VALUE nPage)
|
109
114
|
{
|
110
|
-
|
111
|
-
|
115
|
+
sqlite3BackupRubyPtr ctx;
|
116
|
+
int status;
|
112
117
|
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
118
|
+
TypedData_Get_Struct(self, sqlite3BackupRuby, &backup_type, ctx);
|
119
|
+
REQUIRE_OPEN_BACKUP(ctx);
|
120
|
+
status = sqlite3_backup_step(ctx->p, NUM2INT(nPage));
|
121
|
+
return INT2NUM(status);
|
117
122
|
}
|
118
123
|
|
119
124
|
/* call-seq: SQLite3::Backup#finish
|
120
125
|
*
|
121
126
|
* Destroy the backup object.
|
122
127
|
*/
|
123
|
-
static VALUE
|
128
|
+
static VALUE
|
129
|
+
finish(VALUE self)
|
124
130
|
{
|
125
|
-
|
131
|
+
sqlite3BackupRubyPtr ctx;
|
126
132
|
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
133
|
+
TypedData_Get_Struct(self, sqlite3BackupRuby, &backup_type, ctx);
|
134
|
+
REQUIRE_OPEN_BACKUP(ctx);
|
135
|
+
(void)sqlite3_backup_finish(ctx->p);
|
136
|
+
ctx->p = NULL;
|
137
|
+
return Qnil;
|
132
138
|
}
|
133
139
|
|
134
140
|
/* call-seq: SQLite3::Backup#remaining
|
@@ -138,13 +144,14 @@ static VALUE finish(VALUE self)
|
|
138
144
|
* Note that the value is only updated after step() is called,
|
139
145
|
* so before calling step() returned value is invalid.
|
140
146
|
*/
|
141
|
-
static VALUE
|
147
|
+
static VALUE
|
148
|
+
remaining(VALUE self)
|
142
149
|
{
|
143
|
-
|
150
|
+
sqlite3BackupRubyPtr ctx;
|
144
151
|
|
145
|
-
|
146
|
-
|
147
|
-
|
152
|
+
TypedData_Get_Struct(self, sqlite3BackupRuby, &backup_type, ctx);
|
153
|
+
REQUIRE_OPEN_BACKUP(ctx);
|
154
|
+
return INT2NUM(sqlite3_backup_remaining(ctx->p));
|
148
155
|
}
|
149
156
|
|
150
157
|
/* call-seq: SQLite3::Backup#pagecount
|
@@ -154,28 +161,30 @@ static VALUE remaining(VALUE self)
|
|
154
161
|
* Note that the value is only updated after step() is called,
|
155
162
|
* so before calling step() returned value is invalid.
|
156
163
|
*/
|
157
|
-
static VALUE
|
164
|
+
static VALUE
|
165
|
+
pagecount(VALUE self)
|
158
166
|
{
|
159
|
-
|
167
|
+
sqlite3BackupRubyPtr ctx;
|
160
168
|
|
161
|
-
|
162
|
-
|
163
|
-
|
169
|
+
TypedData_Get_Struct(self, sqlite3BackupRuby, &backup_type, ctx);
|
170
|
+
REQUIRE_OPEN_BACKUP(ctx);
|
171
|
+
return INT2NUM(sqlite3_backup_pagecount(ctx->p));
|
164
172
|
}
|
165
173
|
|
166
|
-
void
|
174
|
+
void
|
175
|
+
init_sqlite3_backup(void)
|
167
176
|
{
|
168
177
|
#if 0
|
169
|
-
|
178
|
+
VALUE mSqlite3 = rb_define_module("SQLite3");
|
170
179
|
#endif
|
171
|
-
|
172
|
-
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
180
|
+
cSqlite3Backup = rb_define_class_under(mSqlite3, "Backup", rb_cObject);
|
181
|
+
|
182
|
+
rb_define_alloc_func(cSqlite3Backup, allocate);
|
183
|
+
rb_define_method(cSqlite3Backup, "initialize", initialize, 4);
|
184
|
+
rb_define_method(cSqlite3Backup, "step", step, 1);
|
185
|
+
rb_define_method(cSqlite3Backup, "finish", finish, 0);
|
186
|
+
rb_define_method(cSqlite3Backup, "remaining", remaining, 0);
|
187
|
+
rb_define_method(cSqlite3Backup, "pagecount", pagecount, 0);
|
179
188
|
}
|
180
189
|
|
181
190
|
#endif
|
data/ext/sqlite3/backup.h
CHANGED
@@ -4,11 +4,11 @@
|
|
4
4
|
#include <sqlite3_ruby.h>
|
5
5
|
|
6
6
|
struct _sqlite3BackupRuby {
|
7
|
-
|
7
|
+
sqlite3_backup *p;
|
8
8
|
};
|
9
9
|
|
10
10
|
typedef struct _sqlite3BackupRuby sqlite3BackupRuby;
|
11
|
-
typedef sqlite3BackupRuby *
|
11
|
+
typedef sqlite3BackupRuby *sqlite3BackupRubyPtr;
|
12
12
|
|
13
13
|
void init_sqlite3_backup();
|
14
14
|
|