yugabytedb-ysql 0.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (121) hide show
  1. checksums.yaml +7 -0
  2. data/.appveyor.yml +42 -0
  3. data/.gems +6 -0
  4. data/.gemtest +0 -0
  5. data/.github/workflows/binary-gems.yml +117 -0
  6. data/.github/workflows/source-gem.yml +143 -0
  7. data/.gitignore +24 -0
  8. data/.hgsigs +34 -0
  9. data/.hgtags +41 -0
  10. data/.irbrc +23 -0
  11. data/.pryrc +23 -0
  12. data/.tm_properties +21 -0
  13. data/.travis.yml +49 -0
  14. data/BSDL +22 -0
  15. data/Contributors.rdoc +46 -0
  16. data/Gemfile +18 -0
  17. data/History.md +901 -0
  18. data/LICENSE +56 -0
  19. data/Manifest.txt +73 -0
  20. data/POSTGRES +23 -0
  21. data/README-OS_X.rdoc +68 -0
  22. data/README-Windows.rdoc +56 -0
  23. data/README.ja.md +302 -0
  24. data/README.md +381 -0
  25. data/Rakefile +118 -0
  26. data/Rakefile.cross +299 -0
  27. data/certs/ged.pem +24 -0
  28. data/certs/kanis@comcard.de.pem +20 -0
  29. data/certs/larskanis-2022.pem +26 -0
  30. data/certs/larskanis-2023.pem +24 -0
  31. data/certs/larskanis-2024.pem +24 -0
  32. data/ext/errorcodes.def +1044 -0
  33. data/ext/errorcodes.rb +45 -0
  34. data/ext/errorcodes.txt +497 -0
  35. data/ext/extconf.rb +174 -0
  36. data/ext/gvl_wrappers.c +21 -0
  37. data/ext/gvl_wrappers.h +264 -0
  38. data/ext/pg.c +692 -0
  39. data/ext/pg.h +392 -0
  40. data/ext/pg_binary_decoder.c +308 -0
  41. data/ext/pg_binary_encoder.c +387 -0
  42. data/ext/pg_coder.c +624 -0
  43. data/ext/pg_connection.c +4681 -0
  44. data/ext/pg_copy_coder.c +917 -0
  45. data/ext/pg_errors.c +95 -0
  46. data/ext/pg_record_coder.c +522 -0
  47. data/ext/pg_result.c +1766 -0
  48. data/ext/pg_text_decoder.c +1005 -0
  49. data/ext/pg_text_encoder.c +827 -0
  50. data/ext/pg_tuple.c +572 -0
  51. data/ext/pg_type_map.c +200 -0
  52. data/ext/pg_type_map_all_strings.c +130 -0
  53. data/ext/pg_type_map_by_class.c +271 -0
  54. data/ext/pg_type_map_by_column.c +355 -0
  55. data/ext/pg_type_map_by_mri_type.c +313 -0
  56. data/ext/pg_type_map_by_oid.c +388 -0
  57. data/ext/pg_type_map_in_ruby.c +333 -0
  58. data/ext/pg_util.c +149 -0
  59. data/ext/pg_util.h +65 -0
  60. data/ext/vc/pg.sln +26 -0
  61. data/ext/vc/pg_18/pg.vcproj +216 -0
  62. data/ext/vc/pg_19/pg_19.vcproj +209 -0
  63. data/lib/pg/basic_type_map_based_on_result.rb +67 -0
  64. data/lib/pg/basic_type_map_for_queries.rb +202 -0
  65. data/lib/pg/basic_type_map_for_results.rb +104 -0
  66. data/lib/pg/basic_type_registry.rb +303 -0
  67. data/lib/pg/binary_decoder/date.rb +9 -0
  68. data/lib/pg/binary_decoder/timestamp.rb +26 -0
  69. data/lib/pg/binary_encoder/timestamp.rb +20 -0
  70. data/lib/pg/coder.rb +106 -0
  71. data/lib/pg/connection.rb +997 -0
  72. data/lib/pg/exceptions.rb +25 -0
  73. data/lib/pg/load_balance_service.rb +406 -0
  74. data/lib/pg/result.rb +43 -0
  75. data/lib/pg/text_decoder/date.rb +18 -0
  76. data/lib/pg/text_decoder/inet.rb +9 -0
  77. data/lib/pg/text_decoder/json.rb +14 -0
  78. data/lib/pg/text_decoder/numeric.rb +9 -0
  79. data/lib/pg/text_decoder/timestamp.rb +30 -0
  80. data/lib/pg/text_encoder/date.rb +12 -0
  81. data/lib/pg/text_encoder/inet.rb +28 -0
  82. data/lib/pg/text_encoder/json.rb +14 -0
  83. data/lib/pg/text_encoder/numeric.rb +9 -0
  84. data/lib/pg/text_encoder/timestamp.rb +24 -0
  85. data/lib/pg/tuple.rb +30 -0
  86. data/lib/pg/type_map_by_column.rb +16 -0
  87. data/lib/pg/version.rb +5 -0
  88. data/lib/ysql.rb +130 -0
  89. data/misc/openssl-pg-segfault.rb +31 -0
  90. data/misc/postgres/History.txt +9 -0
  91. data/misc/postgres/Manifest.txt +5 -0
  92. data/misc/postgres/README.txt +21 -0
  93. data/misc/postgres/Rakefile +21 -0
  94. data/misc/postgres/lib/postgres.rb +16 -0
  95. data/misc/ruby-pg/History.txt +9 -0
  96. data/misc/ruby-pg/Manifest.txt +5 -0
  97. data/misc/ruby-pg/README.txt +21 -0
  98. data/misc/ruby-pg/Rakefile +21 -0
  99. data/misc/ruby-pg/lib/ruby/pg.rb +16 -0
  100. data/rakelib/task_extension.rb +46 -0
  101. data/sample/array_insert.rb +20 -0
  102. data/sample/async_api.rb +102 -0
  103. data/sample/async_copyto.rb +39 -0
  104. data/sample/async_mixed.rb +56 -0
  105. data/sample/check_conn.rb +21 -0
  106. data/sample/copydata.rb +71 -0
  107. data/sample/copyfrom.rb +81 -0
  108. data/sample/copyto.rb +19 -0
  109. data/sample/cursor.rb +21 -0
  110. data/sample/disk_usage_report.rb +177 -0
  111. data/sample/issue-119.rb +94 -0
  112. data/sample/losample.rb +69 -0
  113. data/sample/minimal-testcase.rb +17 -0
  114. data/sample/notify_wait.rb +72 -0
  115. data/sample/pg_statistics.rb +285 -0
  116. data/sample/replication_monitor.rb +222 -0
  117. data/sample/test_binary_values.rb +33 -0
  118. data/sample/wal_shipper.rb +434 -0
  119. data/sample/warehouse_partitions.rb +311 -0
  120. data/yugabytedb-ysql.gemspec +33 -0
  121. metadata +232 -0
@@ -0,0 +1,311 @@
1
+ # -*- ruby -*-
2
+ # vim: set nosta noet ts=4 sw=4:
3
+ #
4
+ # Script to automatically move partitioned tables and their indexes
5
+ # to a separate area on disk.
6
+ #
7
+ # Mahlon E. Smith <mahlon@martini.nu>
8
+ #
9
+ # Example use case:
10
+ #
11
+ # - You've got a heavy insert table, such as syslog data.
12
+ # - This table has a partitioning trigger (or is manually partitioned)
13
+ # by date, to separate incoming stuff from archival/report stuff.
14
+ # - You have a tablespace on cheap or slower disk (maybe even
15
+ # ZFS compressed, or some such!)
16
+ #
17
+ # The only assumption this script makes is that your tables are dated, and
18
+ # the tablespace they're moving into already exists.
19
+ #
20
+ # A full example, using the syslog idea from above, where each child
21
+ # table is date partitioned by a convention of "syslog_YEAR-WEEKOFYEAR":
22
+ #
23
+ # syslog # <--- parent
24
+ # syslog_2012_06 # <--- inherited
25
+ # syslog_2012_07 # <--- inherited
26
+ # syslog_2012_08 # <--- inherited
27
+ # ...
28
+ #
29
+ # You'd run this script like so:
30
+ #
31
+ # ./warehouse_partitions.rb -F syslog_%Y_%U
32
+ #
33
+ # Assuming this was week 12 of the year, tables syslog_2012_06 through
34
+ # syslog_2012_11 would start sequentially migrating into the tablespace
35
+ # called 'warehouse'.
36
+ #
37
+
38
+
39
+ require 'date'
40
+ require 'ostruct'
41
+ require 'optparse'
42
+ require 'pathname'
43
+ require 'etc'
44
+ require 'ysql'
45
+
46
+
47
+ ### A tablespace migration class.
48
+ ###
49
+ class PGWarehouse
50
+
51
+ def initialize( opts )
52
+ @opts = opts
53
+ @db = YSQL.connect(
54
+ :dbname => opts.database,
55
+ :host => opts.host,
56
+ :port => opts.port,
57
+ :user => opts.user,
58
+ :password => opts.pass,
59
+ :sslmode => 'prefer'
60
+ )
61
+ @db.exec "SET search_path TO %s" % [ opts.schema ] if opts.schema
62
+
63
+ @relations = self.relations
64
+ end
65
+
66
+ attr_reader :db
67
+
68
+ ######
69
+ public
70
+ ######
71
+
72
+ ### Perform the tablespace moves.
73
+ ###
74
+ def migrate
75
+ if @relations.empty?
76
+ $stderr.puts 'No tables were found for warehousing.'
77
+ return
78
+ end
79
+
80
+ $stderr.puts "Found %d relation%s to move." % [ relations.length, relations.length == 1 ? '' : 's' ]
81
+ @relations.sort_by{|_,v| v[:name] }.each do |_, val|
82
+ $stderr.print " - Moving table '%s' to '%s'... " % [
83
+ val[:name], @opts.tablespace
84
+ ]
85
+
86
+ if @opts.dryrun
87
+ $stderr.puts '(not really)'
88
+
89
+ else
90
+ age = self.timer do
91
+ db.exec "ALTER TABLE %s SET TABLESPACE %s;" % [
92
+ val[:name], @opts.tablespace
93
+ ]
94
+ end
95
+ puts age
96
+ end
97
+
98
+ val[ :indexes ].each do |idx|
99
+ $stderr.print " - Moving index '%s' to '%s'... " % [
100
+ idx, @opts.tablespace
101
+ ]
102
+ if @opts.dryrun
103
+ $stderr.puts '(not really)'
104
+
105
+ else
106
+ age = self.timer do
107
+ db.exec "ALTER INDEX %s SET TABLESPACE %s;" % [
108
+ idx, @opts.tablespace
109
+ ]
110
+ end
111
+ puts age
112
+ end
113
+ end
114
+ end
115
+ end
116
+
117
+
118
+ #########
119
+ protected
120
+ #########
121
+
122
+ ### Get OIDs and current tablespaces for everything under the
123
+ ### specified schema.
124
+ ###
125
+ def relations
126
+ return @relations if @relations
127
+ relations = {}
128
+
129
+ query = %q{
130
+ SELECT c.oid AS oid,
131
+ c.relname AS name,
132
+ c.relkind AS kind,
133
+ t.spcname AS tspace
134
+ FROM pg_class AS c
135
+ LEFT JOIN pg_namespace n ON n.oid = c.relnamespace
136
+ LEFT JOIN pg_tablespace t ON t.oid = c.reltablespace
137
+ WHERE c.relkind = 'r' }
138
+ query << "AND n.nspname='#{@opts.schema}'" if @opts.schema
139
+
140
+ # Get the relations list, along with each element's current tablespace.
141
+ #
142
+ self.db.exec( query ) do |res|
143
+ res.each do |row|
144
+ relations[ row['oid'] ] = {
145
+ :name => row['name'],
146
+ :tablespace => row['tspace'],
147
+ :indexes => [],
148
+ :parent => nil
149
+ }
150
+ end
151
+ end
152
+
153
+ # Add table inheritance information.
154
+ #
155
+ db.exec 'SELECT inhrelid AS oid, inhparent AS parent FROM pg_inherits' do |res|
156
+ res.each do |row|
157
+ relations[ row['oid'] ][ :parent ] = row['parent']
158
+ end
159
+ end
160
+
161
+ # Remove tables that don't qualify for warehousing.
162
+ #
163
+ # - Tables that are not children of a parent
164
+ # - Tables that are already in the warehouse tablespace
165
+ # - The currently active child (it's likely being written to!)
166
+ # - Any table that can't be parsed into the specified format
167
+ #
168
+ relations.reject! do |oid, val|
169
+ begin
170
+ val[:parent].nil? ||
171
+ val[:tablespace] == @opts.tablespace ||
172
+ val[:name] == Time.now.strftime( @opts.format ) ||
173
+ ! DateTime.strptime( val[:name], @opts.format )
174
+ rescue ArgumentError
175
+ true
176
+ end
177
+ end
178
+
179
+ query = %q{
180
+ SELECT c.oid AS oid,
181
+ i.indexname AS name
182
+ FROM pg_class AS c
183
+ INNER JOIN pg_indexes AS i
184
+ ON i.tablename = c.relname }
185
+ query << "AND i.schemaname='#{@opts.schema}'" if @opts.schema
186
+
187
+ # Attach index names to tables.
188
+ #
189
+ db.exec( query ) do |res|
190
+ res.each do |row|
191
+ relations[ row['oid'] ][ :indexes ] << row['name'] if relations[ row['oid'] ]
192
+ end
193
+ end
194
+
195
+ return relations
196
+ end
197
+
198
+
199
+ ### Wrap arbitrary commands in a human readable timer.
200
+ ###
201
+ def timer
202
+ start = Time.now
203
+ yield
204
+ age = Time.now - start
205
+
206
+ diff = age
207
+ secs = diff % 60
208
+ diff = ( diff - secs ) / 60
209
+ mins = diff % 60
210
+ diff = ( diff - mins ) / 60
211
+ hour = diff % 24
212
+
213
+ return "%02d:%02d:%02d" % [ hour, mins, secs ]
214
+ end
215
+ end
216
+
217
+
218
+ ### Parse command line arguments. Return a struct of global options.
219
+ ###
220
+ def parse_args( args )
221
+ options = OpenStruct.new
222
+ options.database = Etc.getpwuid( Process.uid ).name
223
+ options.host = '127.0.0.1'
224
+ options.port = 5432
225
+ options.user = Etc.getpwuid( Process.uid ).name
226
+ options.sslmode = 'prefer'
227
+ options.tablespace = 'warehouse'
228
+
229
+ opts = OptionParser.new do |opts|
230
+ opts.banner = "Usage: #{$0} [options]"
231
+
232
+ opts.separator ''
233
+ opts.separator 'Connection options:'
234
+
235
+ opts.on( '-d', '--database DBNAME',
236
+ "specify the database to connect to (default: \"#{options.database}\")" ) do |db|
237
+ options.database = db
238
+ end
239
+
240
+ opts.on( '-h', '--host HOSTNAME', 'database server host' ) do |host|
241
+ options.host = host
242
+ end
243
+
244
+ opts.on( '-p', '--port PORT', Integer,
245
+ "database server port (default: \"#{options.port}\")" ) do |port|
246
+ options.port = port
247
+ end
248
+
249
+ opts.on( '-n', '--schema SCHEMA', String,
250
+ "operate on the named schema only (default: none)" ) do |schema|
251
+ options.schema = schema
252
+ end
253
+
254
+ opts.on( '-T', '--tablespace SPACE', String,
255
+ "move old tables to this tablespace (default: \"#{options.tablespace}\")" ) do |tb|
256
+ options.tablespace = tb
257
+ end
258
+
259
+ opts.on( '-F', '--tableformat FORMAT', String,
260
+ "The naming format (strftime) for the inherited tables (default: none)" ) do |format|
261
+ options.format = format
262
+ end
263
+
264
+ opts.on( '-U', '--user NAME',
265
+ "database user name (default: \"#{options.user}\")" ) do |user|
266
+ options.user = user
267
+ end
268
+
269
+ opts.on( '-W', 'force password prompt' ) do |pw|
270
+ print 'Password: '
271
+ begin
272
+ system 'stty -echo'
273
+ options.pass = gets.chomp
274
+ ensure
275
+ system 'stty echo'
276
+ puts
277
+ end
278
+ end
279
+
280
+ opts.separator ''
281
+ opts.separator 'Other options:'
282
+
283
+ opts.on_tail( '--dry-run', "don't actually do anything" ) do
284
+ options.dryrun = true
285
+ end
286
+
287
+ opts.on_tail( '--help', 'show this help, then exit' ) do
288
+ $stderr.puts opts
289
+ exit
290
+ end
291
+
292
+ opts.on_tail( '--version', 'output version information, then exit' ) do
293
+ puts Stats::VERSION
294
+ exit
295
+ end
296
+ end
297
+
298
+ opts.parse!( args )
299
+ return options
300
+ end
301
+
302
+
303
+ if __FILE__ == $0
304
+ opts = parse_args( ARGV )
305
+ raise ArgumentError, "A naming format (-F) is required." unless opts.format
306
+
307
+ $stdout.sync = true
308
+ PGWarehouse.new( opts ).migrate
309
+ end
310
+
311
+
@@ -0,0 +1,33 @@
1
+ # frozen_string_literal: true
2
+ # -*- encoding: utf-8 -*-
3
+
4
+ require_relative 'lib/pg/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "yugabytedb-ysql"
8
+ spec.version = YSQL::VERSION
9
+ spec.authors = ["Michael Granger", "Lars Kanis", "YugabyteDB Dev Team"]
10
+ spec.email = ["ged@FaerieMUD.org", "lars@greiz-reinsdorf.de", "info@yugabyte.com"]
11
+
12
+ spec.summary = "The Ruby interface to YugabyteDB, based on PG Ruby Driver v#{YSQL::PG_VERSION}"
13
+ spec.description = "Pg_YugabyteDB is the Ruby interface to the PostgreSQL-compatible YugabyteDB. It works with YugabyteDB 2.20 and later."
14
+ spec.homepage = "https://github.com/yugabyte/ruby-pg"
15
+ spec.license = "BSD-2-Clause"
16
+ spec.required_ruby_version = ">= 2.5"
17
+
18
+ spec.metadata["homepage_uri"] = spec.homepage
19
+ spec.metadata["source_code_uri"] = "https://github.com/yugabyte/ruby-pg"
20
+ spec.metadata["changelog_uri"] = "https://github.com/yugabyte/ruby-pg/blob/master/History.md"
21
+ spec.metadata["documentation_uri"] = "http://deveiate.org/code/pg"
22
+
23
+ # Specify which files should be added to the gem when it is released.
24
+ # The `git ls-files -z` loads the files in the RubyGem that have been added into git.
25
+ spec.files = Dir.chdir(File.expand_path(__dir__)) do
26
+ `git ls-files -z`.split("\x0").reject { |f| f.match(%r{\A(?:test|spec|features|translation)/}) }
27
+ end
28
+ spec.extensions = ["ext/extconf.rb"]
29
+ spec.require_paths = ["lib"]
30
+ spec.rdoc_options = ["--main", "README.md",
31
+ "--title", "YSQL: The Ruby Driver for YugabyteDB (YSQL)"]
32
+ spec.extra_rdoc_files = `git ls-files -z *.rdoc *.md lib/*.rb lib/*/*.rb lib/*/*/*.rb ext/*.c ext/*.h`.split("\x0")
33
+ end
metadata ADDED
@@ -0,0 +1,232 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: yugabytedb-ysql
3
+ version: !ruby/object:Gem::Version
4
+ version: '0.3'
5
+ platform: ruby
6
+ authors:
7
+ - Michael Granger
8
+ - Lars Kanis
9
+ - YugabyteDB Dev Team
10
+ autorequire:
11
+ bindir: bin
12
+ cert_chain: []
13
+ date: 2024-07-03 00:00:00.000000000 Z
14
+ dependencies: []
15
+ description: Pg_YugabyteDB is the Ruby interface to the PostgreSQL-compatible YugabyteDB.
16
+ It works with YugabyteDB 2.20 and later.
17
+ email:
18
+ - ged@FaerieMUD.org
19
+ - lars@greiz-reinsdorf.de
20
+ - info@yugabyte.com
21
+ executables: []
22
+ extensions:
23
+ - ext/extconf.rb
24
+ extra_rdoc_files:
25
+ - Contributors.rdoc
26
+ - History.md
27
+ - README-OS_X.rdoc
28
+ - README-Windows.rdoc
29
+ - README.ja.md
30
+ - README.md
31
+ - ext/gvl_wrappers.c
32
+ - ext/gvl_wrappers.h
33
+ - ext/pg.c
34
+ - ext/pg.h
35
+ - ext/pg_binary_decoder.c
36
+ - ext/pg_binary_encoder.c
37
+ - ext/pg_coder.c
38
+ - ext/pg_connection.c
39
+ - ext/pg_copy_coder.c
40
+ - ext/pg_errors.c
41
+ - ext/pg_record_coder.c
42
+ - ext/pg_result.c
43
+ - ext/pg_text_decoder.c
44
+ - ext/pg_text_encoder.c
45
+ - ext/pg_tuple.c
46
+ - ext/pg_type_map.c
47
+ - ext/pg_type_map_all_strings.c
48
+ - ext/pg_type_map_by_class.c
49
+ - ext/pg_type_map_by_column.c
50
+ - ext/pg_type_map_by_mri_type.c
51
+ - ext/pg_type_map_by_oid.c
52
+ - ext/pg_type_map_in_ruby.c
53
+ - ext/pg_util.c
54
+ - ext/pg_util.h
55
+ - lib/pg/basic_type_map_based_on_result.rb
56
+ - lib/pg/basic_type_map_for_queries.rb
57
+ - lib/pg/basic_type_map_for_results.rb
58
+ - lib/pg/basic_type_registry.rb
59
+ - lib/pg/binary_decoder/date.rb
60
+ - lib/pg/binary_decoder/timestamp.rb
61
+ - lib/pg/binary_encoder/timestamp.rb
62
+ - lib/pg/coder.rb
63
+ - lib/pg/connection.rb
64
+ - lib/pg/exceptions.rb
65
+ - lib/pg/load_balance_service.rb
66
+ - lib/pg/result.rb
67
+ - lib/pg/text_decoder/date.rb
68
+ - lib/pg/text_decoder/inet.rb
69
+ - lib/pg/text_decoder/json.rb
70
+ - lib/pg/text_decoder/numeric.rb
71
+ - lib/pg/text_decoder/timestamp.rb
72
+ - lib/pg/text_encoder/date.rb
73
+ - lib/pg/text_encoder/inet.rb
74
+ - lib/pg/text_encoder/json.rb
75
+ - lib/pg/text_encoder/numeric.rb
76
+ - lib/pg/text_encoder/timestamp.rb
77
+ - lib/pg/tuple.rb
78
+ - lib/pg/type_map_by_column.rb
79
+ - lib/pg/version.rb
80
+ - lib/ysql.rb
81
+ files:
82
+ - ".appveyor.yml"
83
+ - ".gems"
84
+ - ".gemtest"
85
+ - ".github/workflows/binary-gems.yml"
86
+ - ".github/workflows/source-gem.yml"
87
+ - ".gitignore"
88
+ - ".hgsigs"
89
+ - ".hgtags"
90
+ - ".irbrc"
91
+ - ".pryrc"
92
+ - ".tm_properties"
93
+ - ".travis.yml"
94
+ - BSDL
95
+ - Contributors.rdoc
96
+ - Gemfile
97
+ - History.md
98
+ - LICENSE
99
+ - Manifest.txt
100
+ - POSTGRES
101
+ - README-OS_X.rdoc
102
+ - README-Windows.rdoc
103
+ - README.ja.md
104
+ - README.md
105
+ - Rakefile
106
+ - Rakefile.cross
107
+ - certs/ged.pem
108
+ - certs/kanis@comcard.de.pem
109
+ - certs/larskanis-2022.pem
110
+ - certs/larskanis-2023.pem
111
+ - certs/larskanis-2024.pem
112
+ - ext/errorcodes.def
113
+ - ext/errorcodes.rb
114
+ - ext/errorcodes.txt
115
+ - ext/extconf.rb
116
+ - ext/gvl_wrappers.c
117
+ - ext/gvl_wrappers.h
118
+ - ext/pg.c
119
+ - ext/pg.h
120
+ - ext/pg_binary_decoder.c
121
+ - ext/pg_binary_encoder.c
122
+ - ext/pg_coder.c
123
+ - ext/pg_connection.c
124
+ - ext/pg_copy_coder.c
125
+ - ext/pg_errors.c
126
+ - ext/pg_record_coder.c
127
+ - ext/pg_result.c
128
+ - ext/pg_text_decoder.c
129
+ - ext/pg_text_encoder.c
130
+ - ext/pg_tuple.c
131
+ - ext/pg_type_map.c
132
+ - ext/pg_type_map_all_strings.c
133
+ - ext/pg_type_map_by_class.c
134
+ - ext/pg_type_map_by_column.c
135
+ - ext/pg_type_map_by_mri_type.c
136
+ - ext/pg_type_map_by_oid.c
137
+ - ext/pg_type_map_in_ruby.c
138
+ - ext/pg_util.c
139
+ - ext/pg_util.h
140
+ - ext/vc/pg.sln
141
+ - ext/vc/pg_18/pg.vcproj
142
+ - ext/vc/pg_19/pg_19.vcproj
143
+ - lib/pg/basic_type_map_based_on_result.rb
144
+ - lib/pg/basic_type_map_for_queries.rb
145
+ - lib/pg/basic_type_map_for_results.rb
146
+ - lib/pg/basic_type_registry.rb
147
+ - lib/pg/binary_decoder/date.rb
148
+ - lib/pg/binary_decoder/timestamp.rb
149
+ - lib/pg/binary_encoder/timestamp.rb
150
+ - lib/pg/coder.rb
151
+ - lib/pg/connection.rb
152
+ - lib/pg/exceptions.rb
153
+ - lib/pg/load_balance_service.rb
154
+ - lib/pg/result.rb
155
+ - lib/pg/text_decoder/date.rb
156
+ - lib/pg/text_decoder/inet.rb
157
+ - lib/pg/text_decoder/json.rb
158
+ - lib/pg/text_decoder/numeric.rb
159
+ - lib/pg/text_decoder/timestamp.rb
160
+ - lib/pg/text_encoder/date.rb
161
+ - lib/pg/text_encoder/inet.rb
162
+ - lib/pg/text_encoder/json.rb
163
+ - lib/pg/text_encoder/numeric.rb
164
+ - lib/pg/text_encoder/timestamp.rb
165
+ - lib/pg/tuple.rb
166
+ - lib/pg/type_map_by_column.rb
167
+ - lib/pg/version.rb
168
+ - lib/ysql.rb
169
+ - misc/openssl-pg-segfault.rb
170
+ - misc/postgres/History.txt
171
+ - misc/postgres/Manifest.txt
172
+ - misc/postgres/README.txt
173
+ - misc/postgres/Rakefile
174
+ - misc/postgres/lib/postgres.rb
175
+ - misc/ruby-pg/History.txt
176
+ - misc/ruby-pg/Manifest.txt
177
+ - misc/ruby-pg/README.txt
178
+ - misc/ruby-pg/Rakefile
179
+ - misc/ruby-pg/lib/ruby/pg.rb
180
+ - rakelib/task_extension.rb
181
+ - sample/array_insert.rb
182
+ - sample/async_api.rb
183
+ - sample/async_copyto.rb
184
+ - sample/async_mixed.rb
185
+ - sample/check_conn.rb
186
+ - sample/copydata.rb
187
+ - sample/copyfrom.rb
188
+ - sample/copyto.rb
189
+ - sample/cursor.rb
190
+ - sample/disk_usage_report.rb
191
+ - sample/issue-119.rb
192
+ - sample/losample.rb
193
+ - sample/minimal-testcase.rb
194
+ - sample/notify_wait.rb
195
+ - sample/pg_statistics.rb
196
+ - sample/replication_monitor.rb
197
+ - sample/test_binary_values.rb
198
+ - sample/wal_shipper.rb
199
+ - sample/warehouse_partitions.rb
200
+ - yugabytedb-ysql.gemspec
201
+ homepage: https://github.com/yugabyte/ruby-pg
202
+ licenses:
203
+ - BSD-2-Clause
204
+ metadata:
205
+ homepage_uri: https://github.com/yugabyte/ruby-pg
206
+ source_code_uri: https://github.com/yugabyte/ruby-pg
207
+ changelog_uri: https://github.com/yugabyte/ruby-pg/blob/master/History.md
208
+ documentation_uri: http://deveiate.org/code/pg
209
+ post_install_message:
210
+ rdoc_options:
211
+ - "--main"
212
+ - README.md
213
+ - "--title"
214
+ - 'YSQL: The Ruby Driver for YugabyteDB (YSQL)'
215
+ require_paths:
216
+ - lib
217
+ required_ruby_version: !ruby/object:Gem::Requirement
218
+ requirements:
219
+ - - ">="
220
+ - !ruby/object:Gem::Version
221
+ version: '2.5'
222
+ required_rubygems_version: !ruby/object:Gem::Requirement
223
+ requirements:
224
+ - - ">="
225
+ - !ruby/object:Gem::Version
226
+ version: '0'
227
+ requirements: []
228
+ rubygems_version: 3.3.27
229
+ signing_key:
230
+ specification_version: 4
231
+ summary: The Ruby interface to YugabyteDB, based on PG Ruby Driver v1.5.6
232
+ test_files: []