tapsoob 0.5.23 → 0.5.25

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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: d7a84b5a6f4398257b459a0a8b74ff67bfcac3f50620b7e7e72c9ebd513b5211
4
- data.tar.gz: 037127603d8cae32df3a0b71d2ffd89f4631632ee1d5d726e6105d2e5e0fccee
3
+ metadata.gz: 87f86ef24606eac9b07a505455b518402d33d522b8e14420dfe36fbcc38beb78
4
+ data.tar.gz: 46722746c4d5c6ec5247f28cb5d05d33f55d78e3a8fd7ee560096c097351c9fd
5
5
  SHA512:
6
- metadata.gz: 5158318d197305651b772044b98a614638d3c1e3e540ade7e1997b2799fef2607914442c1ce4050023516cef8fdec00c4e31379720288b6ea2714e59840243d5
7
- data.tar.gz: 4bba24e4863a6034611da2d055766e87deb680e63291e32ef13993364937c109f1979799496700656edfb24dfa1173883d34303c188598842584f54340faca09
6
+ metadata.gz: 2de7d2c3841e96e5b322cec4079b6d70a6b8fe761fde5e4b3799676cb61af6f2f38efed8a95ff40470b783db0897e21e93e44da541507b351e0f7c814fb18242
7
+ data.tar.gz: 363345d8ad6ce7847e1480c70e26cfabc6f27a8d9581b1f33e7bd7c9df3d270b8d9f7cec4cb6e267e234fbc15f3f5b70a5e5d559f979fbf09e15621f8b235789
data/.gitignore CHANGED
File without changes
data/.rspec CHANGED
File without changes
data/Gemfile CHANGED
@@ -35,7 +35,7 @@ end
35
35
  gemspec
36
36
 
37
37
  group :development do
38
- gem 'warbler', '~> 2.0.4', platform: :jruby, require: false
38
+ gem 'warbler', '~> 2.0.5', platform: :jruby, github: "jruby/warbler", require: false
39
39
  end
40
40
 
41
41
  group :test do
data/README.md CHANGED
File without changes
data/Rakefile CHANGED
File without changes
File without changes
File without changes
@@ -59,11 +59,6 @@ module Tapsoob
59
59
  end
60
60
  end
61
61
 
62
- def ripl
63
- require 'ripl'
64
- Ripl.start
65
- end
66
-
67
62
  desc "version", "Show tapsoob version"
68
63
  def version
69
64
  puts Tapsoob::VERSION.dup
@@ -9,8 +9,9 @@ module Tapsoob
9
9
  desc "console DATABASE_URL", "Create an IRB REPL connected to a database"
10
10
  def console(database_url)
11
11
  $db = Sequel.connect(database_url)
12
- require 'ripl'
13
- Ripl.start binding: binding
12
+ require 'irb'
13
+ ARGV.clear # otherwise all script parameters get passed to IRB
14
+ IRB.start
14
15
  end
15
16
 
16
17
  desc "dump DATABASE_URL", "Dump a database using a database URL"
data/lib/tapsoob/cli.rb CHANGED
File without changes
File without changes
@@ -87,14 +87,34 @@ module Tapsoob
87
87
 
88
88
  def fetch_file(dump_path)
89
89
  #state[:chunksize] = fetch_chunksize
90
- ds = JSON.parse(File.read(File.join(dump_path, "data", "#{table_name}.json")))
91
- state[:size] = ds["data"].size
90
+ # Read NDJSON format - each line is a separate JSON chunk
91
+ file_path = File.join(dump_path, "data", "#{table_name}.json")
92
+
93
+ # Parse all chunks and combine them
94
+ all_data = []
95
+ table_name_val = nil
96
+ header_val = nil
97
+ types_val = nil
98
+
99
+ File.readlines(file_path).each do |line|
100
+ chunk = JSON.parse(line.strip)
101
+ table_name_val ||= chunk["table_name"]
102
+ header_val ||= chunk["header"]
103
+ types_val ||= chunk["types"]
104
+ all_data.concat(chunk["data"]) if chunk["data"]
105
+ end
106
+
107
+ # Apply skip-duplicates if needed
108
+ all_data = all_data.uniq if @options[:"skip-duplicates"]
109
+
110
+ state[:size] = all_data.size
92
111
  log.debug "DataStream#fetch_file"
112
+
93
113
  rows = {
94
- :table_name => ds["table_name"],
95
- :header => ds["header"],
96
- :data => ((@options[:"skip-duplicates"] ? ds["data"].uniq : ds["data"])[state[:offset], (state[:offset] + state[:chunksize])] || [ ]),
97
- :types => ds["types"]
114
+ :table_name => table_name_val,
115
+ :header => header_val,
116
+ :data => (all_data[state[:offset], state[:chunksize]] || []),
117
+ :types => types_val
98
118
  }
99
119
  update_chunksize_stats
100
120
  rows
File without changes
data/lib/tapsoob/log.rb CHANGED
File without changes
@@ -375,7 +375,9 @@ module Tapsoob
375
375
  idxs = {}
376
376
  table_idxs = Dir.glob(File.join(dump_path, "indexes", "*.json")).map { |path| File.basename(path, '.json') }
377
377
  table_idxs.each do |table_idx|
378
- idxs[table_idx] = JSON.parse(File.read(File.join(dump_path, "indexes", "#{table_idx}.json")))
378
+ # Read NDJSON format - each line is a separate index
379
+ index_file = File.join(dump_path, "indexes", "#{table_idx}.json")
380
+ idxs[table_idx] = File.readlines(index_file).map { |line| JSON.parse(line.strip) }
379
381
  end
380
382
 
381
383
  return unless idxs.size > 0
File without changes
File without changes
File without changes
data/lib/tapsoob/utils.rb CHANGED
@@ -143,26 +143,21 @@ Data : #{data}
143
143
  end
144
144
 
145
145
  def export_indexes(dump_path, table, index_data)
146
- data = [index_data]
147
- if File.exist?(File.join(dump_path, "indexes", "#{table}.json"))
148
- previous_data = JSON.parse(File.read(File.join(dump_path, "indexes", "#{table}.json")))
149
- data = data + previous_data
150
- end
146
+ # Use append-only writes to avoid O(n²) complexity
147
+ index_file = File.join(dump_path, "indexes", "#{table}.json")
151
148
 
152
- File.open(File.join(dump_path, "indexes", "#{table}.json"), 'w') do |file|
153
- file.write(JSON.generate(data))
149
+ File.open(index_file, 'a') do |file|
150
+ file.write(JSON.generate(index_data) + "\n")
154
151
  end
155
152
  end
156
153
 
157
154
  def export_rows(dump_path, table, row_data)
158
- data = row_data
159
- if File.exist?(File.join(dump_path, "data", "#{table}.json"))
160
- previous_data = JSON.parse(File.read(File.join(dump_path, "data", "#{table}.json")))
161
- data[:data] = previous_data["data"] + row_data[:data] unless row_data[:data].nil?
162
- end
155
+ # Use append-only writes to avoid O(n²) complexity
156
+ # Store metadata separately and append data chunks as NDJSON
157
+ data_file = File.join(dump_path, "data", "#{table}.json")
163
158
 
164
- File.open(File.join(dump_path, "data", "#{table}.json"), 'w') do |file|
165
- file.write(JSON.generate(data))
159
+ File.open(data_file, 'a') do |file|
160
+ file.write(JSON.generate(row_data) + "\n")
166
161
  end
167
162
  end
168
163
 
@@ -1,4 +1,4 @@
1
1
  # -*- encoding : utf-8 -*-
2
2
  module Tapsoob
3
- VERSION = "0.5.23".freeze
3
+ VERSION = "0.5.25".freeze
4
4
  end
data/lib/tapsoob.rb CHANGED
File without changes
File without changes
File without changes
File without changes
data/spec/spec_helper.rb CHANGED
File without changes
data/tapsoob.gemspec CHANGED
@@ -20,19 +20,18 @@ Gem::Specification.new do |s|
20
20
  s.require_paths = ["lib"]
21
21
 
22
22
  # Dependencies
23
- s.add_dependency "ripl", "~> 0.7.1"
24
- s.add_dependency "sequel", "~> 5.70.0"
25
- s.add_dependency "thor", "~> 1.2.1"
23
+ s.add_dependency "sequel", "~> 5.96.0"
24
+ s.add_dependency "thor", "~> 1.4.0"
26
25
 
27
26
  if (RUBY_PLATFORM =~ /java/).nil?
28
- s.add_development_dependency "mysql2", "~> 0.4.10"
29
- s.add_development_dependency "pg", "~> 0.21.0"
30
- s.add_development_dependency "sqlite3", "~> 1.3.11"
27
+ s.add_development_dependency "mysql2", "~> 0.5.7"
28
+ s.add_development_dependency "pg", "~> 1.6.2"
29
+ s.add_development_dependency "sqlite3", "~> 2.7.4"
31
30
  else
32
31
  s.platform = 'java'
33
32
 
34
- s.add_dependency "jdbc-mysql", "~> 5.1.44"
35
- s.add_dependency "jdbc-postgres", "~> 42.2.25"
36
- s.add_dependency "jdbc-sqlite3", "~> 3.28.0"
33
+ s.add_dependency "jdbc-mysql", "~> 9.1.0.1"
34
+ s.add_dependency "jdbc-postgres", "~> 42.6.0"
35
+ s.add_dependency "jdbc-sqlite3", "~> 3.46.1.1"
37
36
  end
38
37
  end
metadata CHANGED
@@ -1,100 +1,85 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: tapsoob
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.5.23
4
+ version: 0.5.25
5
5
  platform: ruby
6
6
  authors:
7
7
  - Félix Bellanger
8
8
  - Michael Chrisco
9
- autorequire:
10
9
  bindir: bin
11
10
  cert_chain: []
12
- date: 2024-01-03 00:00:00.000000000 Z
11
+ date: 1980-01-02 00:00:00.000000000 Z
13
12
  dependencies:
14
- - !ruby/object:Gem::Dependency
15
- name: ripl
16
- requirement: !ruby/object:Gem::Requirement
17
- requirements:
18
- - - "~>"
19
- - !ruby/object:Gem::Version
20
- version: 0.7.1
21
- type: :runtime
22
- prerelease: false
23
- version_requirements: !ruby/object:Gem::Requirement
24
- requirements:
25
- - - "~>"
26
- - !ruby/object:Gem::Version
27
- version: 0.7.1
28
13
  - !ruby/object:Gem::Dependency
29
14
  name: sequel
30
15
  requirement: !ruby/object:Gem::Requirement
31
16
  requirements:
32
17
  - - "~>"
33
18
  - !ruby/object:Gem::Version
34
- version: 5.70.0
19
+ version: 5.96.0
35
20
  type: :runtime
36
21
  prerelease: false
37
22
  version_requirements: !ruby/object:Gem::Requirement
38
23
  requirements:
39
24
  - - "~>"
40
25
  - !ruby/object:Gem::Version
41
- version: 5.70.0
26
+ version: 5.96.0
42
27
  - !ruby/object:Gem::Dependency
43
28
  name: thor
44
29
  requirement: !ruby/object:Gem::Requirement
45
30
  requirements:
46
31
  - - "~>"
47
32
  - !ruby/object:Gem::Version
48
- version: 1.2.1
33
+ version: 1.4.0
49
34
  type: :runtime
50
35
  prerelease: false
51
36
  version_requirements: !ruby/object:Gem::Requirement
52
37
  requirements:
53
38
  - - "~>"
54
39
  - !ruby/object:Gem::Version
55
- version: 1.2.1
40
+ version: 1.4.0
56
41
  - !ruby/object:Gem::Dependency
57
42
  name: mysql2
58
43
  requirement: !ruby/object:Gem::Requirement
59
44
  requirements:
60
45
  - - "~>"
61
46
  - !ruby/object:Gem::Version
62
- version: 0.4.10
47
+ version: 0.5.7
63
48
  type: :development
64
49
  prerelease: false
65
50
  version_requirements: !ruby/object:Gem::Requirement
66
51
  requirements:
67
52
  - - "~>"
68
53
  - !ruby/object:Gem::Version
69
- version: 0.4.10
54
+ version: 0.5.7
70
55
  - !ruby/object:Gem::Dependency
71
56
  name: pg
72
57
  requirement: !ruby/object:Gem::Requirement
73
58
  requirements:
74
59
  - - "~>"
75
60
  - !ruby/object:Gem::Version
76
- version: 0.21.0
61
+ version: 1.6.2
77
62
  type: :development
78
63
  prerelease: false
79
64
  version_requirements: !ruby/object:Gem::Requirement
80
65
  requirements:
81
66
  - - "~>"
82
67
  - !ruby/object:Gem::Version
83
- version: 0.21.0
68
+ version: 1.6.2
84
69
  - !ruby/object:Gem::Dependency
85
70
  name: sqlite3
86
71
  requirement: !ruby/object:Gem::Requirement
87
72
  requirements:
88
73
  - - "~>"
89
74
  - !ruby/object:Gem::Version
90
- version: 1.3.11
75
+ version: 2.7.4
91
76
  type: :development
92
77
  prerelease: false
93
78
  version_requirements: !ruby/object:Gem::Requirement
94
79
  requirements:
95
80
  - - "~>"
96
81
  - !ruby/object:Gem::Version
97
- version: 1.3.11
82
+ version: 2.7.4
98
83
  description: Simple tool to import/export databases inspired by taps but OOB, meaning
99
84
  databases are imported/exported from the filesystem.
100
85
  email: felix.bellanger@faveod.com
@@ -134,7 +119,6 @@ homepage: https://github.com/Keeguon/tapsoob
134
119
  licenses:
135
120
  - MIT
136
121
  metadata: {}
137
- post_install_message:
138
122
  rdoc_options: []
139
123
  require_paths:
140
124
  - lib
@@ -149,8 +133,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
149
133
  - !ruby/object:Gem::Version
150
134
  version: '0'
151
135
  requirements: []
152
- rubygems_version: 3.3.26
153
- signing_key:
136
+ rubygems_version: 3.6.9
154
137
  specification_version: 4
155
138
  summary: Simple tool to import/export databases.
156
139
  test_files: