diff options
-rw-r--r-- | databases/rubygem-dbd-pg/Makefile | 1 | ||||
-rw-r--r-- | databases/rubygem-dbd-pg/files/patch-database.rb | 74 | ||||
-rw-r--r-- | databases/rubygem-dbd-pg/files/patch-statement.rb | 20 |
3 files changed, 95 insertions, 0 deletions
diff --git a/databases/rubygem-dbd-pg/Makefile b/databases/rubygem-dbd-pg/Makefile index cf1ae1900bff..19605c4f3ff3 100644 --- a/databases/rubygem-dbd-pg/Makefile +++ b/databases/rubygem-dbd-pg/Makefile @@ -2,6 +2,7 @@ PORTNAME= dbd-pg PORTVERSION= 0.3.9 +PORTREVISION= 1 CATEGORIES= databases rubygems MASTER_SITES= RG diff --git a/databases/rubygem-dbd-pg/files/patch-database.rb b/databases/rubygem-dbd-pg/files/patch-database.rb new file mode 100644 index 000000000000..00ff711b0d55 --- /dev/null +++ b/databases/rubygem-dbd-pg/files/patch-database.rb @@ -0,0 +1,74 @@ +--- lib/dbd/pg/database.rb.orig 2018-03-17 05:55:55 UTC ++++ lib/dbd/pg/database.rb +@@ -48,7 +48,7 @@ class DBI::DBD::Pg::Database < DBI::Base + hash['tty'] ||= '' + hash['port'] = hash['port'].to_i unless hash['port'].nil? + +- @connection = PGconn.new(hash['host'], hash['port'], hash['options'], hash['tty'], ++ @connection = PG::Connection.new(hash['host'], hash['port'], hash['options'], hash['tty'], + hash['dbname'] || hash['database'], user, auth) + + @exec_method = :exec +@@ -78,7 +78,7 @@ class DBI::DBD::Pg::Database < DBI::Base + + self['AutoCommit'] = true # Postgres starts in unchained mode (AutoCommit=on) by default + +- rescue PGError => err ++ rescue PG::Error => err + raise DBI::OperationalError.new(err.message) + end + +@@ -443,7 +443,7 @@ class DBI::DBD::Pg::Database < DBI::Base + # + # Create a BLOB. + # +- def __blob_create(mode=PGconn::INV_READ) ++ def __blob_create(mode=PG::Connection::INV_READ) + start_transaction unless @in_transaction + @connection.lo_creat(mode) + rescue PGError => err +@@ -453,7 +453,7 @@ class DBI::DBD::Pg::Database < DBI::Base + # + # Open a BLOB. + # +- def __blob_open(oid, mode=PGconn::INV_READ) ++ def __blob_open(oid, mode=PG::Connection::INV_READ) + start_transaction unless @in_transaction + @connection.lo_open(oid.to_i, mode) + rescue PGError => err +@@ -474,7 +474,7 @@ class DBI::DBD::Pg::Database < DBI::Base + # Read a BLOB and return the data. + # + def __blob_read(oid, length) +- blob = @connection.lo_open(oid.to_i, PGconn::INV_READ) ++ blob = @connection.lo_open(oid.to_i, PG::Connection::INV_READ) + + if length.nil? + data = @connection.lo_read(blob) +@@ -485,7 +485,7 @@ class DBI::DBD::Pg::Database < DBI::Base + # FIXME it doesn't like to close here either. + # @connection.lo_close(blob) + data +- rescue PGError => err ++ rescue PG::Error => err + raise DBI::DatabaseError.new(err.message) + end + +@@ -494,7 +494,7 @@ class DBI::DBD::Pg::Database < DBI::Base + # + def __blob_write(oid, value) + start_transaction unless @in_transaction +- blob = @connection.lo_open(oid.to_i, PGconn::INV_WRITE) ++ blob = @connection.lo_open(oid.to_i, PG::Connection::INV_WRITE) + res = @connection.lo_write(blob, value) + # FIXME not sure why PG doesn't like to close here -- seems to be + # working but we should make sure it's not eating file descriptors +@@ -510,7 +510,7 @@ class DBI::DBD::Pg::Database < DBI::Base + # + def __set_notice_processor(proc) + @connection.set_notice_processor proc +- rescue PGError => err ++ rescue PG::Error => err + raise DBI::DatabaseError.new(err.message) + end + end # Database diff --git a/databases/rubygem-dbd-pg/files/patch-statement.rb b/databases/rubygem-dbd-pg/files/patch-statement.rb new file mode 100644 index 000000000000..4f8f3915f97b --- /dev/null +++ b/databases/rubygem-dbd-pg/files/patch-statement.rb @@ -0,0 +1,20 @@ +--- lib/dbd/pg/statement.rb.orig 2018-03-17 05:55:55 UTC ++++ lib/dbd/pg/statement.rb +@@ -18,7 +18,7 @@ class DBI::DBD::Pg::Statement < DBI::Bas + @result = nil + @bindvars = [] + @prepared = false +- rescue PGError => err ++ rescue PG::Error => err + raise DBI::ProgrammingError.new(err.message) + end + +@@ -58,7 +58,7 @@ class DBI::DBD::Pg::Statement < DBI::Bas + end + + @result = DBI::DBD::Pg::Tuples.new(@db, pg_result) +- rescue PGError, RuntimeError => err ++ rescue PG::Error, RuntimeError => err + raise DBI::ProgrammingError.new(err.message) + end + |