pg 1.4.4-x64-mingw-ucrt → 1.4.6-x64-mingw-ucrt
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
- checksums.yaml.gz.sig +0 -0
- data/.appveyor.yml +14 -8
- data/.github/workflows/binary-gems.yml +42 -11
- data/.github/workflows/source-gem.yml +24 -18
- data/.gitignore +8 -2
- data/.travis.yml +2 -2
- data/{History.rdoc → History.md} +174 -150
- data/README.ja.md +266 -0
- data/README.md +272 -0
- data/Rakefile +13 -4
- data/Rakefile.cross +7 -11
- data/certs/larskanis-2023.pem +24 -0
- data/ext/errorcodes.def +4 -0
- data/ext/errorcodes.txt +2 -1
- data/ext/pg.c +3 -0
- data/ext/pg_connection.c +110 -27
- data/lib/3.1/pg_ext.so +0 -0
- data/lib/3.2/pg_ext.so +0 -0
- data/lib/pg/connection.rb +21 -19
- data/lib/pg/exceptions.rb +7 -0
- data/lib/pg/version.rb +1 -1
- data/lib/pg.rb +0 -6
- data/lib/x64-mingw-ucrt/libpq.dll +0 -0
- data/pg.gemspec +4 -2
- data/rakelib/task_extension.rb +1 -1
- data/translation/.po4a-version +7 -0
- data/translation/po/all.pot +875 -0
- data/translation/po/ja.po +868 -0
- data/translation/po4a.cfg +9 -0
- data.tar.gz.sig +0 -0
- metadata +89 -31
- metadata.gz.sig +0 -0
- data/README.ja.rdoc +0 -13
- data/README.rdoc +0 -233
data/ext/errorcodes.txt
CHANGED
@@ -2,7 +2,7 @@
|
|
2
2
|
# errcodes.txt
|
3
3
|
# PostgreSQL error codes
|
4
4
|
#
|
5
|
-
# Copyright (c) 2003-
|
5
|
+
# Copyright (c) 2003-2022, PostgreSQL Global Development Group
|
6
6
|
#
|
7
7
|
# This list serves as the basis for generating source files containing error
|
8
8
|
# codes. It is kept in a common format to make sure all these source files have
|
@@ -222,6 +222,7 @@ Section: Class 22 - Data Exception
|
|
222
222
|
2203D E ERRCODE_TOO_MANY_JSON_ARRAY_ELEMENTS too_many_json_array_elements
|
223
223
|
2203E E ERRCODE_TOO_MANY_JSON_OBJECT_MEMBERS too_many_json_object_members
|
224
224
|
2203F E ERRCODE_SQL_JSON_SCALAR_REQUIRED sql_json_scalar_required
|
225
|
+
2203G E ERRCODE_SQL_JSON_ITEM_CANNOT_BE_CAST_TO_TARGET_TYPE sql_json_item_cannot_be_cast_to_target_type
|
225
226
|
|
226
227
|
Section: Class 23 - Integrity Constraint Violation
|
227
228
|
|
data/ext/pg.c
CHANGED
@@ -679,6 +679,9 @@ Init_pg_ext(void)
|
|
679
679
|
rb_define_const(rb_mPGconstants, "INVALID_OID", INT2FIX(InvalidOid));
|
680
680
|
rb_define_const(rb_mPGconstants, "InvalidOid", INT2FIX(InvalidOid));
|
681
681
|
|
682
|
+
/* PostgreSQL compiled in default port */
|
683
|
+
rb_define_const(rb_mPGconstants, "DEF_PGPORT", INT2FIX(DEF_PGPORT));
|
684
|
+
|
682
685
|
/* Add the constants to the toplevel namespace */
|
683
686
|
rb_include_module( rb_mPG, rb_mPGconstants );
|
684
687
|
|
data/ext/pg_connection.c
CHANGED
@@ -702,7 +702,10 @@ static VALUE
|
|
702
702
|
pgconn_port(VALUE self)
|
703
703
|
{
|
704
704
|
char* port = PQport(pg_get_pgconn(self));
|
705
|
-
|
705
|
+
if (!port || port[0] == '\0')
|
706
|
+
return INT2NUM(DEF_PGPORT);
|
707
|
+
else
|
708
|
+
return INT2NUM(atoi(port));
|
706
709
|
}
|
707
710
|
|
708
711
|
/*
|
@@ -2443,8 +2446,9 @@ pgconn_async_flush(VALUE self)
|
|
2443
2446
|
VALUE socket_io = pgconn_socket_io(self);
|
2444
2447
|
events = RB_NUM2INT(pg_rb_io_wait(socket_io, RB_INT2NUM(PG_RUBY_IO_READABLE | PG_RUBY_IO_WRITABLE), Qnil));
|
2445
2448
|
|
2446
|
-
if (events & PG_RUBY_IO_READABLE)
|
2449
|
+
if (events & PG_RUBY_IO_READABLE){
|
2447
2450
|
pgconn_consume_input(self);
|
2451
|
+
}
|
2448
2452
|
}
|
2449
2453
|
return Qtrue;
|
2450
2454
|
}
|
@@ -3123,8 +3127,14 @@ pgconn_async_get_last_result(VALUE self)
|
|
3123
3127
|
* conn.discard_results()
|
3124
3128
|
*
|
3125
3129
|
* Silently discard any prior query result that application didn't eat.
|
3126
|
-
* This is
|
3127
|
-
*
|
3130
|
+
* This is internally used prior to Connection#exec and sibling methods.
|
3131
|
+
* It doesn't raise an exception on connection errors, but returns +false+ instead.
|
3132
|
+
*
|
3133
|
+
* Returns:
|
3134
|
+
* * +nil+ when the connection is already idle
|
3135
|
+
* * +true+ when some results have been discarded
|
3136
|
+
* * +false+ when a failure occured and the connection was closed
|
3137
|
+
*
|
3128
3138
|
*/
|
3129
3139
|
static VALUE
|
3130
3140
|
pgconn_discard_results(VALUE self)
|
@@ -3132,8 +3142,12 @@ pgconn_discard_results(VALUE self)
|
|
3132
3142
|
PGconn *conn = pg_get_pgconn(self);
|
3133
3143
|
VALUE socket_io;
|
3134
3144
|
|
3135
|
-
|
3136
|
-
|
3145
|
+
switch( PQtransactionStatus(conn) ) {
|
3146
|
+
case PQTRANS_IDLE:
|
3147
|
+
case PQTRANS_INTRANS:
|
3148
|
+
case PQTRANS_INERROR:
|
3149
|
+
return Qnil;
|
3150
|
+
default:;
|
3137
3151
|
}
|
3138
3152
|
|
3139
3153
|
socket_io = pgconn_socket_io(self);
|
@@ -3146,10 +3160,21 @@ pgconn_discard_results(VALUE self)
|
|
3146
3160
|
* To avoid this call pg_rb_io_wait() and PQconsumeInput() without rb_raise().
|
3147
3161
|
*/
|
3148
3162
|
while( gvl_PQisBusy(conn) ){
|
3149
|
-
|
3150
|
-
|
3151
|
-
|
3152
|
-
|
3163
|
+
int events;
|
3164
|
+
|
3165
|
+
switch( PQflush(conn) ) {
|
3166
|
+
case 1:
|
3167
|
+
events = RB_NUM2INT(pg_rb_io_wait(socket_io, RB_INT2NUM(PG_RUBY_IO_READABLE | PG_RUBY_IO_WRITABLE), Qnil));
|
3168
|
+
if (events & PG_RUBY_IO_READABLE){
|
3169
|
+
if ( PQconsumeInput(conn) == 0 ) goto error;
|
3170
|
+
}
|
3171
|
+
break;
|
3172
|
+
case 0:
|
3173
|
+
pg_rb_io_wait(socket_io, RB_INT2NUM(PG_RUBY_IO_READABLE), Qnil);
|
3174
|
+
if ( PQconsumeInput(conn) == 0 ) goto error;
|
3175
|
+
break;
|
3176
|
+
default:
|
3177
|
+
goto error;
|
3153
3178
|
}
|
3154
3179
|
}
|
3155
3180
|
|
@@ -3159,7 +3184,9 @@ pgconn_discard_results(VALUE self)
|
|
3159
3184
|
status = PQresultStatus(cur);
|
3160
3185
|
PQclear(cur);
|
3161
3186
|
if (status == PGRES_COPY_IN){
|
3162
|
-
gvl_PQputCopyEnd(conn, "COPY terminated by new
|
3187
|
+
while( gvl_PQputCopyEnd(conn, "COPY terminated by new query or discard_results") == 0 ){
|
3188
|
+
pgconn_async_flush(self);
|
3189
|
+
}
|
3163
3190
|
}
|
3164
3191
|
if (status == PGRES_COPY_OUT){
|
3165
3192
|
for(;;) {
|
@@ -3168,10 +3195,7 @@ pgconn_discard_results(VALUE self)
|
|
3168
3195
|
if( st == 0 ) {
|
3169
3196
|
/* would block -> wait for readable data */
|
3170
3197
|
pg_rb_io_wait(socket_io, RB_INT2NUM(PG_RUBY_IO_READABLE), Qnil);
|
3171
|
-
if ( PQconsumeInput(conn) == 0 )
|
3172
|
-
pgconn_close_socket_io(self);
|
3173
|
-
return Qfalse;
|
3174
|
-
}
|
3198
|
+
if ( PQconsumeInput(conn) == 0 ) goto error;
|
3175
3199
|
} else if( st > 0 ) {
|
3176
3200
|
/* some data retrieved -> discard it */
|
3177
3201
|
PQfreemem(buffer);
|
@@ -3184,6 +3208,10 @@ pgconn_discard_results(VALUE self)
|
|
3184
3208
|
}
|
3185
3209
|
|
3186
3210
|
return Qtrue;
|
3211
|
+
|
3212
|
+
error:
|
3213
|
+
pgconn_close_socket_io(self);
|
3214
|
+
return Qfalse;
|
3187
3215
|
}
|
3188
3216
|
|
3189
3217
|
/*
|
@@ -3640,6 +3668,14 @@ pgconn_send_flush_request(VALUE self)
|
|
3640
3668
|
* LARGE OBJECT SUPPORT
|
3641
3669
|
**************************************************************************/
|
3642
3670
|
|
3671
|
+
#define BLOCKING_BEGIN(conn) do { \
|
3672
|
+
int old_nonblocking = PQisnonblocking(conn); \
|
3673
|
+
PQsetnonblocking(conn, 0);
|
3674
|
+
|
3675
|
+
#define BLOCKING_END(th) \
|
3676
|
+
PQsetnonblocking(conn, old_nonblocking); \
|
3677
|
+
} while(0);
|
3678
|
+
|
3643
3679
|
/*
|
3644
3680
|
* call-seq:
|
3645
3681
|
* conn.lo_creat( [mode] ) -> Integer
|
@@ -3660,7 +3696,10 @@ pgconn_locreat(int argc, VALUE *argv, VALUE self)
|
|
3660
3696
|
else
|
3661
3697
|
mode = NUM2INT(nmode);
|
3662
3698
|
|
3663
|
-
|
3699
|
+
BLOCKING_BEGIN(conn)
|
3700
|
+
lo_oid = lo_creat(conn, mode);
|
3701
|
+
BLOCKING_END(conn)
|
3702
|
+
|
3664
3703
|
if (lo_oid == 0)
|
3665
3704
|
pg_raise_conn_error( rb_ePGerror, self, "lo_creat failed");
|
3666
3705
|
|
@@ -3705,7 +3744,10 @@ pgconn_loimport(VALUE self, VALUE filename)
|
|
3705
3744
|
|
3706
3745
|
Check_Type(filename, T_STRING);
|
3707
3746
|
|
3708
|
-
|
3747
|
+
BLOCKING_BEGIN(conn)
|
3748
|
+
lo_oid = lo_import(conn, StringValueCStr(filename));
|
3749
|
+
BLOCKING_END(conn)
|
3750
|
+
|
3709
3751
|
if (lo_oid == 0) {
|
3710
3752
|
pg_raise_conn_error( rb_ePGerror, self, "%s", PQerrorMessage(conn));
|
3711
3753
|
}
|
@@ -3723,11 +3765,16 @@ pgconn_loexport(VALUE self, VALUE lo_oid, VALUE filename)
|
|
3723
3765
|
{
|
3724
3766
|
PGconn *conn = pg_get_pgconn(self);
|
3725
3767
|
Oid oid;
|
3768
|
+
int ret;
|
3726
3769
|
Check_Type(filename, T_STRING);
|
3727
3770
|
|
3728
3771
|
oid = NUM2UINT(lo_oid);
|
3729
3772
|
|
3730
|
-
|
3773
|
+
BLOCKING_BEGIN(conn)
|
3774
|
+
ret = lo_export(conn, oid, StringValueCStr(filename));
|
3775
|
+
BLOCKING_END(conn)
|
3776
|
+
|
3777
|
+
if (ret < 0) {
|
3731
3778
|
pg_raise_conn_error( rb_ePGerror, self, "%s", PQerrorMessage(conn));
|
3732
3779
|
}
|
3733
3780
|
return Qnil;
|
@@ -3758,7 +3805,11 @@ pgconn_loopen(int argc, VALUE *argv, VALUE self)
|
|
3758
3805
|
else
|
3759
3806
|
mode = NUM2INT(nmode);
|
3760
3807
|
|
3761
|
-
|
3808
|
+
BLOCKING_BEGIN(conn)
|
3809
|
+
fd = lo_open(conn, lo_oid, mode);
|
3810
|
+
BLOCKING_END(conn)
|
3811
|
+
|
3812
|
+
if(fd < 0) {
|
3762
3813
|
pg_raise_conn_error( rb_ePGerror, self, "can't open large object: %s", PQerrorMessage(conn));
|
3763
3814
|
}
|
3764
3815
|
return INT2FIX(fd);
|
@@ -3783,8 +3834,12 @@ pgconn_lowrite(VALUE self, VALUE in_lo_desc, VALUE buffer)
|
|
3783
3834
|
if( RSTRING_LEN(buffer) < 0) {
|
3784
3835
|
pg_raise_conn_error( rb_ePGerror, self, "write buffer zero string");
|
3785
3836
|
}
|
3786
|
-
|
3787
|
-
|
3837
|
+
BLOCKING_BEGIN(conn)
|
3838
|
+
n = lo_write(conn, fd, StringValuePtr(buffer),
|
3839
|
+
RSTRING_LEN(buffer));
|
3840
|
+
BLOCKING_END(conn)
|
3841
|
+
|
3842
|
+
if(n < 0) {
|
3788
3843
|
pg_raise_conn_error( rb_ePGerror, self, "lo_write failed: %s", PQerrorMessage(conn));
|
3789
3844
|
}
|
3790
3845
|
|
@@ -3812,7 +3867,12 @@ pgconn_loread(VALUE self, VALUE in_lo_desc, VALUE in_len)
|
|
3812
3867
|
pg_raise_conn_error( rb_ePGerror, self, "negative length %d given", len);
|
3813
3868
|
|
3814
3869
|
buffer = ALLOC_N(char, len);
|
3815
|
-
|
3870
|
+
|
3871
|
+
BLOCKING_BEGIN(conn)
|
3872
|
+
ret = lo_read(conn, lo_desc, buffer, len);
|
3873
|
+
BLOCKING_END(conn)
|
3874
|
+
|
3875
|
+
if(ret < 0)
|
3816
3876
|
pg_raise_conn_error( rb_ePGerror, self, "lo_read failed");
|
3817
3877
|
|
3818
3878
|
if(ret == 0) {
|
@@ -3842,7 +3902,11 @@ pgconn_lolseek(VALUE self, VALUE in_lo_desc, VALUE offset, VALUE whence)
|
|
3842
3902
|
int lo_desc = NUM2INT(in_lo_desc);
|
3843
3903
|
int ret;
|
3844
3904
|
|
3845
|
-
|
3905
|
+
BLOCKING_BEGIN(conn)
|
3906
|
+
ret = lo_lseek(conn, lo_desc, NUM2INT(offset), NUM2INT(whence));
|
3907
|
+
BLOCKING_END(conn)
|
3908
|
+
|
3909
|
+
if(ret < 0) {
|
3846
3910
|
pg_raise_conn_error( rb_ePGerror, self, "lo_lseek failed");
|
3847
3911
|
}
|
3848
3912
|
|
@@ -3862,7 +3926,11 @@ pgconn_lotell(VALUE self, VALUE in_lo_desc)
|
|
3862
3926
|
PGconn *conn = pg_get_pgconn(self);
|
3863
3927
|
int lo_desc = NUM2INT(in_lo_desc);
|
3864
3928
|
|
3865
|
-
|
3929
|
+
BLOCKING_BEGIN(conn)
|
3930
|
+
position = lo_tell(conn, lo_desc);
|
3931
|
+
BLOCKING_END(conn)
|
3932
|
+
|
3933
|
+
if(position < 0)
|
3866
3934
|
pg_raise_conn_error( rb_ePGerror, self, "lo_tell failed");
|
3867
3935
|
|
3868
3936
|
return INT2FIX(position);
|
@@ -3880,8 +3948,13 @@ pgconn_lotruncate(VALUE self, VALUE in_lo_desc, VALUE in_len)
|
|
3880
3948
|
PGconn *conn = pg_get_pgconn(self);
|
3881
3949
|
int lo_desc = NUM2INT(in_lo_desc);
|
3882
3950
|
size_t len = NUM2INT(in_len);
|
3951
|
+
int ret;
|
3952
|
+
|
3953
|
+
BLOCKING_BEGIN(conn)
|
3954
|
+
ret = lo_truncate(conn,lo_desc,len);
|
3955
|
+
BLOCKING_END(conn)
|
3883
3956
|
|
3884
|
-
if(
|
3957
|
+
if(ret < 0)
|
3885
3958
|
pg_raise_conn_error( rb_ePGerror, self, "lo_truncate failed");
|
3886
3959
|
|
3887
3960
|
return Qnil;
|
@@ -3898,8 +3971,13 @@ pgconn_loclose(VALUE self, VALUE in_lo_desc)
|
|
3898
3971
|
{
|
3899
3972
|
PGconn *conn = pg_get_pgconn(self);
|
3900
3973
|
int lo_desc = NUM2INT(in_lo_desc);
|
3974
|
+
int ret;
|
3975
|
+
|
3976
|
+
BLOCKING_BEGIN(conn)
|
3977
|
+
ret = lo_close(conn,lo_desc);
|
3978
|
+
BLOCKING_END(conn)
|
3901
3979
|
|
3902
|
-
if(
|
3980
|
+
if(ret < 0)
|
3903
3981
|
pg_raise_conn_error( rb_ePGerror, self, "lo_close failed");
|
3904
3982
|
|
3905
3983
|
return Qnil;
|
@@ -3916,8 +3994,13 @@ pgconn_lounlink(VALUE self, VALUE in_oid)
|
|
3916
3994
|
{
|
3917
3995
|
PGconn *conn = pg_get_pgconn(self);
|
3918
3996
|
Oid oid = NUM2UINT(in_oid);
|
3997
|
+
int ret;
|
3998
|
+
|
3999
|
+
BLOCKING_BEGIN(conn)
|
4000
|
+
ret = lo_unlink(conn,oid);
|
4001
|
+
BLOCKING_END(conn)
|
3919
4002
|
|
3920
|
-
if(
|
4003
|
+
if(ret < 0)
|
3921
4004
|
pg_raise_conn_error( rb_ePGerror, self, "lo_unlink failed");
|
3922
4005
|
|
3923
4006
|
return Qnil;
|
data/lib/3.1/pg_ext.so
CHANGED
Binary file
|
data/lib/3.2/pg_ext.so
ADDED
Binary file
|
data/lib/pg/connection.rb
CHANGED
@@ -196,11 +196,19 @@ class PG::Connection
|
|
196
196
|
yield res
|
197
197
|
rescue Exception => err
|
198
198
|
errmsg = "%s while copy data: %s" % [ err.class.name, err.message ]
|
199
|
-
|
200
|
-
|
201
|
-
|
199
|
+
begin
|
200
|
+
put_copy_end( errmsg )
|
201
|
+
rescue PG::Error
|
202
|
+
# Ignore error in cleanup to avoid losing original exception
|
203
|
+
end
|
204
|
+
discard_results
|
205
|
+
raise err
|
202
206
|
else
|
203
|
-
|
207
|
+
begin
|
208
|
+
put_copy_end
|
209
|
+
rescue PG::Error => err
|
210
|
+
raise PG::LostCopyState.new("#{err} (probably by executing another SQL query while running a COPY command)", connection: self)
|
211
|
+
end
|
204
212
|
get_last_result
|
205
213
|
ensure
|
206
214
|
self.encoder_for_put_copy_data = old_coder if coder
|
@@ -213,24 +221,17 @@ class PG::Connection
|
|
213
221
|
self.decoder_for_get_copy_data = coder
|
214
222
|
end
|
215
223
|
yield res
|
216
|
-
rescue Exception
|
224
|
+
rescue Exception
|
217
225
|
cancel
|
218
|
-
|
219
|
-
|
220
|
-
end
|
221
|
-
rescue PG::Error
|
222
|
-
# Ignore error in cleanup to avoid losing original exception
|
223
|
-
end
|
224
|
-
while get_result
|
225
|
-
end
|
226
|
-
raise err
|
226
|
+
discard_results
|
227
|
+
raise
|
227
228
|
else
|
228
229
|
res = get_last_result
|
229
|
-
if !res
|
230
|
-
|
231
|
-
|
232
|
-
|
233
|
-
|
230
|
+
if !res
|
231
|
+
discard_results
|
232
|
+
raise PG::LostCopyState.new("Lost COPY state (probably by executing another SQL query while running a COPY command)", connection: self)
|
233
|
+
elsif res.result_status != PGRES_COMMAND_OK
|
234
|
+
discard_results
|
234
235
|
raise PG::NotAllCopyDataRetrieved.new("Not all COPY data retrieved", connection: self)
|
235
236
|
end
|
236
237
|
res
|
@@ -723,6 +724,7 @@ class PG::Connection
|
|
723
724
|
# This requires PostgreSQL-10+, so no DNS resolving is done on earlier versions.
|
724
725
|
ihosts = iopts[:host].split(",", -1)
|
725
726
|
iports = iopts[:port].split(",", -1)
|
727
|
+
iports = [nil] if iports.size == 0
|
726
728
|
iports = iports * ihosts.size if iports.size == 1
|
727
729
|
raise PG::ConnectionBad, "could not match #{iports.size} port numbers to #{ihosts.size} hosts" if iports.size != ihosts.size
|
728
730
|
|
data/lib/pg/exceptions.rb
CHANGED
data/lib/pg/version.rb
CHANGED
data/lib/pg.rb
CHANGED
Binary file
|
data/pg.gemspec
CHANGED
@@ -17,7 +17,7 @@ Gem::Specification.new do |spec|
|
|
17
17
|
|
18
18
|
spec.metadata["homepage_uri"] = spec.homepage
|
19
19
|
spec.metadata["source_code_uri"] = "https://github.com/ged/ruby-pg"
|
20
|
-
spec.metadata["changelog_uri"] = "https://github.com/ged/ruby-pg/blob/master/History.
|
20
|
+
spec.metadata["changelog_uri"] = "https://github.com/ged/ruby-pg/blob/master/History.md"
|
21
21
|
spec.metadata["documentation_uri"] = "http://deveiate.org/code/pg"
|
22
22
|
|
23
23
|
# Specify which files should be added to the gem when it is released.
|
@@ -28,5 +28,7 @@ Gem::Specification.new do |spec|
|
|
28
28
|
spec.extensions = ["ext/extconf.rb"]
|
29
29
|
spec.require_paths = ["lib"]
|
30
30
|
spec.cert_chain = ["certs/ged.pem"]
|
31
|
-
spec.rdoc_options = ["--main", "README.
|
31
|
+
spec.rdoc_options = ["--main", "README.md",
|
32
|
+
"--title", "PG: The Ruby PostgreSQL Driver"]
|
33
|
+
spec.extra_rdoc_files = `git ls-files -z *.rdoc *.md lib/*.rb lib/*/*.rb ext/*.c ext/*.h`.split("\x0")
|
32
34
|
end
|
data/rakelib/task_extension.rb
CHANGED
@@ -0,0 +1,7 @@
|
|
1
|
+
po4a version 0.69.
|
2
|
+
Written by Martin Quinson and Denis Barbier.
|
3
|
+
|
4
|
+
Copyright © 2002-2022 Software in the Public Interest, Inc.
|
5
|
+
This is free software; see source code for copying
|
6
|
+
conditions. There is NO warranty; not even for
|
7
|
+
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|