eitil 1.1.33 → 1.1.37

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 36321fc1d4a6ef1bc8427a54f987b7c659ca6c2d129a4b4ffa32d65292c6e55b
4
- data.tar.gz: 1096c2f9c22382044a248d118680d2882df5886b1d8a58a374bd840d01070fd8
3
+ metadata.gz: b1ab2c62c13503c0afc55aea6663a381a4d7ad81a363e9131a2d185ead576997
4
+ data.tar.gz: 44faf8bb9335b81c978ba1a8c6a6cd105d4980a2c982874ce69fa203acce4ac5
5
5
  SHA512:
6
- metadata.gz: 33b6da41a3963ef05207d6bfb6937f3ec28cbaa9a842d3cc7b22a4c3bcafe1b0abdaddb0d291fb121bc033b58b35ce455c101eb086a11ce7266c9a6e058f1e9f
7
- data.tar.gz: 6e7438d46132b2efa040221a02129ba516945a1f2256f7235ad910847ac0c724841f82a41e7dfb2b40753d28bee54c6cc9b44040640131784cd9ac3431f36aec
6
+ metadata.gz: fc48bffc1b39584a556e0a742095b56fbd29e22559280c873b7654572ae48c59eb5382bb3d2eddcee184b5f65c9033271c98383cfe04625a633550e8db964a27
7
+ data.tar.gz: a2f8cd2ca05de73290728093d068e91dda6113e77de2f358e916b1c3425fdf2d1184ccccf55ab2aa6737f8c2751fb644cf850b8919c57d7ce3c07fde35940e87
data/eitil_core/README.md CHANGED
@@ -181,6 +181,21 @@ require "eitil_core/array"
181
181
 
182
182
  ```
183
183
 
184
+ ```ruby
185
+ # require "eitil_core/array/map_strings"
186
+
187
+ map_strings(&block)
188
+ # transforms all strings in infinite recursion by yielding the given block, also works for strings contained in hashes.
189
+ # call as: ["hey", ["hi", {a: "ho"}]].map_strings! { |str| str.upcase }
190
+ # => ["HEY", ["HI", {a: "HO"}]]
191
+ ```
192
+ ```ruby
193
+ # require "eitil_core/array/map_strings"
194
+
195
+ map_strings!(&block)
196
+ # bang variant of .map_strings, which recursively modifies all objects it is called on.
197
+ ```
198
+
184
199
  ```ruby
185
200
  # require "eitil_core/array/slice_hashes"
186
201
 
@@ -355,6 +370,20 @@ auto_dig(_hash = self, _key)
355
370
  # => 3
356
371
  ```
357
372
 
373
+ ```ruby
374
+ # require "eitil_core/hash/transform_string_values"
375
+
376
+ transform_string_values(&block)
377
+ # transforms all strings in infinite recursion by yielding the given block, also works for strings contained in arrays.
378
+ # call as: {a: "hey", b: {c: "hi", d: ["ho"]}}.transform_string_values! { |str| str.upcase }
379
+ # => {a: "HEY", b: {c: "HI", d: ["HO"]}}
380
+ ```
381
+ ```ruby
382
+ # require "eitil_core/hash/transform_string_values"
383
+
384
+ transform_string_values!(&block)
385
+ # bang variant of .transform_string_values, which recursively modifies all objects it is called on.
386
+ ```
358
387
 
359
388
  ## Lookups
360
389
 
@@ -0,0 +1,33 @@
1
+
2
+ # require "eitil_core/array/map_strings"
3
+
4
+ require "eitil_core/hash/transform_string_values"
5
+
6
+ class Array
7
+
8
+ def map_strings!(&block)
9
+ map! do |item|
10
+
11
+ if item.class == String
12
+ yield item
13
+
14
+ elsif item.class == Hash
15
+ item.transform_string_values!(&block)
16
+
17
+ elsif item.class == Array
18
+ item.map_strings!(&block)
19
+
20
+ else
21
+ item
22
+
23
+ end
24
+ end
25
+
26
+ self
27
+ end
28
+
29
+ def map_strings(&block)
30
+ deep_dup.map_strings!(&block)
31
+ end
32
+
33
+ end
@@ -1,2 +1,3 @@
1
1
 
2
- require "eitil_core/array/slice_hashes"
2
+ require "eitil_core/array/slice_hashes"
3
+ require "eitil_core/array/map_strings"
@@ -0,0 +1,33 @@
1
+
2
+ # require "eitil_core/hash/transform_string_values"
3
+
4
+ require "eitil_core/array/map_strings"
5
+
6
+ class Hash
7
+
8
+ def transform_string_values!(&block)
9
+ transform_values! do |value|
10
+
11
+ if value.class == String
12
+ yield value
13
+
14
+ elsif value.class == Hash
15
+ value.transform_string_values!(&block)
16
+
17
+ elsif value.class == Array
18
+ value.map_strings!(&block)
19
+
20
+ else
21
+ value
22
+
23
+ end
24
+ end
25
+
26
+ self
27
+ end
28
+
29
+ def transform_string_values(&block)
30
+ deep_dup.transform_string_values!(&block)
31
+ end
32
+
33
+ end
@@ -1,2 +1,3 @@
1
1
 
2
2
  require "eitil_core/hash/auto_dig"
3
+ require "eitil_core/hash/transform_string_values"
@@ -17,7 +17,7 @@ module EitilIntegrate::RubyXL
17
17
  end
18
18
 
19
19
  def try_float_conversion
20
- @hash.transform_values! { |array| array.map { |item| item.is_num? ? item.to_f : item } }
20
+ @hash.transform_values! { |array| array.map { |item| item.is_num? ? to_float(item) : item } }
21
21
  end
22
22
 
23
23
  def drop_nil_values
@@ -37,6 +37,12 @@ module EitilIntegrate::RubyXL
37
37
  value_is_a_int || value_is_a_float || value_is_a_time_string
38
38
  end
39
39
 
40
+ def to_float(object)
41
+ # Implemented a new to_float method, which replaces .to_f, because "7.5".to_f
42
+ # would correctly return 7.5, but "7,5" would incorrectly return 7.0.
43
+ object.is_a?(String) ? object.gsub(',','.').to_f : object.to_f
44
+ end
45
+
40
46
  def value_is_a_int
41
47
  @value.is_a? Integer
42
48
  end
@@ -31,9 +31,13 @@ module EitilIntegrate::RubyXL
31
31
 
32
32
  # returns the exporter_infos, without the datatypes – for taxonomy purpuses, the field
33
33
  # names are often sufficient
34
- def exporter_taxonomy
35
- exporter_infos.transform_values do |settings|
36
- settings.transform_values { |info| info.first.is_a?(Hash) ? info.first.keys : info }
34
+ def exporter_taxonomy
35
+ parameter_fields = exporter_infos.transform_values { |v| v.select { |k,v| k == :required || k == :optional } }
36
+
37
+ parameter_fields.transform_values do |setting_collection|
38
+ setting_collection.transform_values do |setting|
39
+ setting.map { |key| key.is_a?(Hash) ? key.keys : key }.flatten
40
+ end
37
41
  end
38
42
  end
39
43
 
@@ -16,7 +16,7 @@ module EitilStore
16
16
  UUID = /\A(\h{32}|\h{8}-\h{4}-\h{4}-\h{4}-\h{12})\z/
17
17
 
18
18
  # IsNum comes from the Rubinius source code and identifies both integers and floats correctly.
19
- IsNum = /^\s*[+-]?((\d+_?)*\d+(\.(\d+_?)*\d+)?|\.(\d+_?)*\d+)(\s*|([eE][+-]?(\d+_?)*\d+)\s*)$/
19
+ IsNum = /^\s*[+-]?((\d+_?)*\d+([.,](\d+_?)*\d+)?|\.(\d+_?)*\d+)(\s*|([eE][+-]?(\d+_?)*\d+)\s*)$/
20
20
 
21
21
  # Validates Credit Card numbers, Checks if it contains 16 numbers in groups of 4 separated by -, space or nothing
22
22
  CreditCard = /\A(\d{4}-){3}\d{4}\z|\A(\d{4}\s){3}\d{4}\z|\A\d{16}\z/
data/lib/eitil/version.rb CHANGED
@@ -1,5 +1,5 @@
1
1
  module Eitil
2
2
 
3
- VERSION = '1.1.33'
3
+ VERSION = '1.1.37'
4
4
 
5
5
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: eitil
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.1.33
4
+ version: 1.1.37
5
5
  platform: ruby
6
6
  authors:
7
7
  - Jurriaan Schrofer
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2021-08-19 00:00:00.000000000 Z
11
+ date: 2021-09-03 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rails
@@ -103,6 +103,7 @@ files:
103
103
  - eitil_core/lib/eitil_core/argument_helpers/args_to_ivars.rb
104
104
  - eitil_core/lib/eitil_core/argument_helpers/args_to_ivars_bang.rb
105
105
  - eitil_core/lib/eitil_core/array.rb
106
+ - eitil_core/lib/eitil_core/array/map_strings.rb
106
107
  - eitil_core/lib/eitil_core/array/slice_hashes.rb
107
108
  - eitil_core/lib/eitil_core/concerns.rb
108
109
  - eitil_core/lib/eitil_core/concerns/include_concerns_of.rb
@@ -119,6 +120,7 @@ files:
119
120
  - eitil_core/lib/eitil_core/formatters/sql.rb
120
121
  - eitil_core/lib/eitil_core/hash.rb
121
122
  - eitil_core/lib/eitil_core/hash/auto_dig.rb
123
+ - eitil_core/lib/eitil_core/hash/transform_string_values.rb
122
124
  - eitil_core/lib/eitil_core/lookups.rb
123
125
  - eitil_core/lib/eitil_core/lookups/all_methods.rb
124
126
  - eitil_core/lib/eitil_core/lookups/gem_path.rb