concurrent_pipeline 0.1.0 → 1.0.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.
@@ -1,67 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require "securerandom"
4
- require "yaml"
5
-
6
- require_relative "db"
7
-
8
- module ConcurrentPipeline
9
- module Stores
10
- module Yaml
11
- class History
12
- class Version
13
- attr_reader :index, :registry, :changesets
14
- def initialize(index:, changesets:, registry:)
15
- @index = index
16
- @changesets = changesets[0..index]
17
- @registry = registry
18
- end
19
-
20
- def store
21
- @store ||= (
22
- Db
23
- .new(data: {}, registry: registry)
24
- .tap { _1.apply(changesets) }
25
- .reader
26
- )
27
- end
28
-
29
- def diff
30
- changesets.last.as_json
31
- end
32
- end
33
-
34
- attr_reader :path, :registry
35
- def initialize(registry:, path:)
36
- @registry = registry
37
- @path = path
38
- end
39
-
40
- def versions
41
- @versions ||= (
42
- changesets
43
- .count
44
- .times
45
- .map { |i|
46
- Version.new(
47
- index: i,
48
- changesets: changesets,
49
- registry: registry
50
- )
51
- }
52
- )
53
- end
54
-
55
- private
56
-
57
- def changesets
58
- @changesets ||= (
59
- YAML
60
- .load_stream(File.read(path))
61
- .map { |v| Changeset.from_json(json: v, registry: registry) }
62
- )
63
- end
64
- end
65
- end
66
- end
67
- end
@@ -1,40 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require "securerandom"
4
- require "yaml"
5
-
6
- require_relative "yaml/db"
7
- require_relative "yaml/history"
8
-
9
- module ConcurrentPipeline
10
- module Stores
11
- module Yaml
12
- def self.build_writer(data:, dir:, registry:)
13
- data_path = File.join(dir, "data.yml")
14
- versions_path = File.join(dir, "versions.yml")
15
-
16
- after_apply = ->(changesets) do
17
- File.write(data_path, data.to_yaml)
18
- File.open(versions_path, "a") do |f|
19
- changesets
20
- .map { _1.as_json.to_yaml }
21
- .join("\n")
22
- .then { f.puts(_1)}
23
- end
24
- end
25
-
26
- db = Db.new(data: data, registry: registry, after_apply: after_apply)
27
-
28
- changeset = db.changeset
29
- changeset.deltas << Changeset::InitialDelta.new(data: data)
30
- db.apply(changeset)
31
- db
32
- end
33
-
34
- def self.history(dir:, registry:)
35
- path = File.join(dir, "versions.yml")
36
- History.new(registry: registry, path: path)
37
- end
38
- end
39
- end
40
- end