better_pluck 1.0.1 → 1.0.2
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 +4 -4
- data/lib/better_pluck/struct_pluck.rb +5 -2
- data/lib/better_pluck/version.rb +1 -1
- metadata +1 -1
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 31e8abd7675b9da9ed7df5402f4d350e0506c59b4a2deb0d3d81165f3c5a82a1
|
|
4
|
+
data.tar.gz: eabaf0a669cb4031cdf93c1e3ac41ca8eaca113518a93b717fed97513372892f
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: fc5cd17a8699dcdf487f95901ad3745e2f413d81384ecbc2e74d8310d915b6cbb78499f73e9732634ab8aff8cb562fb0ac037207ce534e19f72fe03a5b71a066
|
|
7
|
+
data.tar.gz: 5a520708ff9560e61faf2c809361e417df680129969b029d20395a8a39983f415894ba0a71ef467fff9dd0347fbd2a925f5be48e9a78a9e8b0da0977b9668cc8
|
|
@@ -153,10 +153,13 @@ module BetterPluck::StructPluck
|
|
|
153
153
|
# 1st list: database fields and associations
|
|
154
154
|
# 2nd list: virtual methods (copied from ActiveRecord)
|
|
155
155
|
db_and_assoc = metadata[:all_fields] - metadata[:methods].keys
|
|
156
|
+
metadata[:fields] = db_and_assoc
|
|
156
157
|
cache_key = [metadata[:klass_name], db_and_assoc, metadata[:methods].keys]
|
|
157
158
|
|
|
158
159
|
STRUCT_CLASSES.compute_if_absent(cache_key) do
|
|
159
|
-
|
|
160
|
+
puts metadata[:all_fields]
|
|
161
|
+
puts db_and_assoc
|
|
162
|
+
struct_klass = Struct.new(*metadata[:fields])
|
|
160
163
|
metadata[:methods].each do |name, source|
|
|
161
164
|
struct_klass.class_eval(source)
|
|
162
165
|
end
|
|
@@ -166,7 +169,7 @@ module BetterPluck::StructPluck
|
|
|
166
169
|
end
|
|
167
170
|
|
|
168
171
|
def _struct_pluck_instantiate(struct_klass, metadata, row_data)
|
|
169
|
-
args = metadata[:
|
|
172
|
+
args = metadata[:fields].map do |field|
|
|
170
173
|
if metadata[:db_columns].include?(field)
|
|
171
174
|
row_data.shift
|
|
172
175
|
elsif (sub_metadata = metadata[:associations][field])
|
data/lib/better_pluck/version.rb
CHANGED