philiprehberger-data_mapper 0.4.0 → 0.5.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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: e5404a0cdcc13d6351546a1eba5afde88afd31ea3a26fb02884166918aee9cb0
4
- data.tar.gz: 0e7d36ecf87018ebce2eb8bcfe2decaee35c120f79c006a954883cd8cb4d2b20
3
+ metadata.gz: 28a193815c02260ca5a5f0e32cf1bb8e41c80ac915ae230d238ea17cbf98b5e1
4
+ data.tar.gz: 70dc78f072bb23f692d009561bb3865a3bb5b4e7937b51440a8e4999f7af7db3
5
5
  SHA512:
6
- metadata.gz: 61416ea1c4083f22dee9c828f585b19d7d6dbce1b57f3d0e3100d27b72890bdb44be2fd7e216bfaa5b99a8c75ec5a1e19c012be55bb55e2c2f7080845d9fc806
7
- data.tar.gz: 64d3f10c97e693f882ba0e52e0661d2b26e19a32759478f43fcf5013b8124204e546c08bf3eefdd9f713c7d8e9c616e9e54ab7e876a18b981c52f4564dc90b83
6
+ metadata.gz: f391be6c263d16d60b917a1c7ae8a77cf74d4a0e5c9625df29f44efbeb21dff068253a15c7c50a323d70fcb132071dbf0a297e8d46574e0bb149c7a290d30f15
7
+ data.tar.gz: 981703bef28308069940c19bc5b5eea7192b37553de840b23d60b5c2c3969f5657ff919d2d6e286149ce766e3d190477a9870bcb20e09f1a03ea008c9b6db973
data/CHANGELOG.md CHANGED
@@ -7,6 +7,11 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
7
7
 
8
8
  ## [Unreleased]
9
9
 
10
+ ## [0.5.0] - 2026-04-18
11
+
12
+ ### Added
13
+ - `Mapping#map_lazy(enumerable)` — returns a `Lazy` Enumerator that applies `#map` per-element; suitable for streaming large inputs without materialization
14
+
10
15
  ## [0.4.0] - 2026-04-15
11
16
 
12
17
  ### Added
data/README.md CHANGED
@@ -55,6 +55,20 @@ mapping.map_all(input)
55
55
  # => [{ full_name: "Alice", years: 30, role: "member" }, ...]
56
56
  ```
57
57
 
58
+ ### Lazy streaming
59
+
60
+ Use `map_lazy` to pipe huge datasets without materializing an intermediate array. It returns an `Enumerator::Lazy` that applies `#map` per-element, so it composes with `.first`, `.select`, `.reject`, and works on infinite enumerables:
61
+
62
+ ```ruby
63
+ mapping = Philiprehberger::DataMapper.define do
64
+ field :id
65
+ end
66
+
67
+ infinite = (1..).lazy.map { |i| { "id" => i } }
68
+ mapping.map_lazy(infinite).first(3)
69
+ # => [{ id: 1 }, { id: 2 }, { id: 3 }]
70
+ ```
71
+
58
72
  ### Parse CSV
59
73
 
60
74
  ```ruby
@@ -211,6 +225,7 @@ result.errors # => [{ field: :age, value: -1 }, { field: :name, value: "" }]
211
225
  | `Mapping#map(hash)` | Apply mapping to a single hash |
212
226
  | `Mapping#map_with_validation(hash)` | Apply mapping and return a `MappingResult` with errors |
213
227
  | `Mapping#map_all(array)` | Apply mapping to an array of hashes |
228
+ | `Mapping#map_lazy(enumerable)` | Return a `Lazy` Enumerator applying `#map` per-element for streaming |
214
229
  | `Mapping#field_names` | Array of symbol targets for declared fields and computed fields |
215
230
  | `Mapping#reverse(hash)` | Transform output hash back to input schema |
216
231
  | `Mapping#from_csv(string, headers: true)` | Parse CSV and map each row |
@@ -44,6 +44,10 @@ module Philiprehberger
44
44
  array.map { |hash| map(hash) }
45
45
  end
46
46
 
47
+ def map_lazy(enumerable)
48
+ enumerable.lazy.map { |hash| map(hash) }
49
+ end
50
+
47
51
  # Names (targets) of every declared field, including computed fields.
48
52
  #
49
53
  # @return [Array<Symbol>]
@@ -2,6 +2,6 @@
2
2
 
3
3
  module Philiprehberger
4
4
  module DataMapper
5
- VERSION = '0.4.0'
5
+ VERSION = '0.5.0'
6
6
  end
7
7
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: philiprehberger-data_mapper
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.4.0
4
+ version: 0.5.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Philip Rehberger
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2026-04-15 00:00:00.000000000 Z
11
+ date: 2026-04-19 00:00:00.000000000 Z
12
12
  dependencies: []
13
13
  description: A zero-dependency Ruby gem for transforming data between formats with
14
14
  a mapping DSL, field renaming, type conversion, validation, and CSV support.