1Hash::Merge(3) User Contributed Perl Documentation Hash::Merge(3)
2
3
4
6 Hash::Merge - Merges arbitrarily deep hashes into a single hash
7
9 my %a = (
10 'foo' => 1,
11 'bar' => [qw( a b e )],
12 'querty' => { 'bob' => 'alice' },
13 );
14 my %b = (
15 'foo' => 2,
16 'bar' => [qw(c d)],
17 'querty' => { 'ted' => 'margeret' },
18 );
19
20 my %c = %{ merge( \%a, \%b ) };
21
22 Hash::Merge::set_behavior('RIGHT_PRECEDENT');
23
24 # This is the same as above
25
26 Hash::Merge::add_behavior_spec(
27 { 'SCALAR' => {
28 'SCALAR' => sub { $_[1] },
29 'ARRAY' => sub { [ $_[0], @{ $_[1] } ] },
30 'HASH' => sub { $_[1] },
31 },
32 'ARRAY' => {
33 'SCALAR' => sub { $_[1] },
34 'ARRAY' => sub { [ @{ $_[0] }, @{ $_[1] } ] },
35 'HASH' => sub { $_[1] },
36 },
37 'HASH' => {
38 'SCALAR' => sub { $_[1] },
39 'ARRAY' => sub { [ values %{ $_[0] }, @{ $_[1] } ] },
40 'HASH' => sub { Hash::Merge::_merge_hashes( $_[0], $_[1] ) },
41 },
42 },
43 'My Behavior',
44 );
45
46 # Also there is OO interface.
47
48 my $merger = Hash::Merge->new('LEFT_PRECEDENT');
49 my %c = %{ $merger->merge( \%a, \%b ) };
50
51 # All behavioral changes (e.g. $merge->set_behavior(...)), called on an object remain specific to that object
52 # The legacy "Global Setting" behavior is respected only when new called as a non-OO function.
53
54 # re-use globally specified behavior
55 my $merger = Hash::Merge->new();
56 $merger->add_behavior_spec(Hash::Merge::get_behavior_spec("My Behavior"), "My Behavior");
57 my %c = %{ $merger->merge( \%a, \%b ) };
58
59 # re-use externally specified behavior
60 use Hash::Merge::Extra ();
61 my $merger = Hash::Merge->new();
62 $merger->add_behavior_spec(Hash::Merge::Extra::L_REPLACE, "L_REPLACE");
63 my %c = %{ $merger->merge( \%a, \%b ) };
64
66 Hash::Merge merges two arbitrarily deep hashes into a single hash.
67 That is, at any level, it will add non-conflicting key-value pairs from
68 one hash to the other, and follows a set of specific rules when there
69 are key value conflicts (as outlined below). The hash is followed
70 recursively, so that deeply nested hashes that are at the same level
71 will be merged when the parent hashes are merged. Please note that
72 self-referencing hashes, or recursive references, are not handled well
73 by this method.
74
75 Values in hashes are considered to be either ARRAY references, HASH
76 references, or otherwise are treated as SCALARs. By default, the data
77 passed to the merge function will be cloned using the Clone module;
78 however, if necessary, this behavior can be changed to use as many of
79 the original values as possible. (See "set_clone_behavior").
80
81 Because there are a number of possible ways that one may want to merge
82 values when keys are conflicting, Hash::Merge provides several preset
83 methods for your convenience, as well as a way to define you own.
84 These are (currently):
85
86 Left Precedence
87 This is the default behavior.
88
89 The values buried in the left hash will never be lost; any values
90 that can be added from the right hash will be attempted.
91
92 my $merge = Hash::Merge->new();
93 my $merge = Hash::Merge->new('LEFT_PRECEDENT');
94 $merge->set_behavior('LEFT_PRECEDENT');
95 Hash::Merge::set_behavior('LEFT_PRECEDENT');
96
97 Right Precedence
98 Same as Left Precedence, but with the right hash values never being
99 lost
100
101 my $merge = Hash::Merge->new('RIGHT_PRECEDENT');
102 $merge->set_behavior('RIGHT_PRECEDENT');
103 Hash::Merge::set_behavior('RIGHT_PRECEDENT');
104
105 Storage Precedence
106 If conflicting keys have two different storage mediums, the
107 'bigger' medium will win; arrays are preferred over scalars, hashes
108 over either. The other medium will try to be fitted in the other,
109 but if this isn't possible, the data is dropped.
110
111 my $merge = Hash::Merge->new('STORAGE_PRECEDENT');
112 $merge->set_behavior('STORAGE_PRECEDENT');
113 Hash::Merge::set_behavior('STORAGE_PRECEDENT');
114
115 Retainment Precedence
116 No data will be lost; scalars will be joined with arrays, and
117 scalars and arrays will be 'hashified' to fit them into a hash.
118
119 my $merge = Hash::Merge->new('RETAINMENT_PRECEDENT');
120 $merge->set_behavior('RETAINMENT_PRECEDENT');
121 Hash::Merge::set_behavior('RETAINMENT_PRECEDENT');
122
123 Specific descriptions of how these work are detailed below.
124
125 merge ( <hashref>, <hashref> )
126 Merges two hashes given the rules specified. Returns a reference
127 to the new hash.
128
129 _hashify( <scalar>|<arrayref> ) -- INTERNAL FUNCTION
130 Returns a reference to a hash created from the scalar or array
131 reference, where, for the scalar value, or each item in the array,
132 there is a key and it's value equal to that specific value.
133 Example, if you pass scalar '3', the hash will be { 3 => 3 }.
134
135 _merge_hashes( <hashref>, <hashref> ) -- INTERNAL FUNCTION
136 Actually does the key-by-key evaluation of two hashes and returns
137 the new merged hash. Note that this recursively calls "merge".
138
139 set_clone_behavior( <scalar> )
140 Sets how the data cloning is handled by Hash::Merge. If this is
141 true, then data will be cloned; if false, then original data will
142 be used whenever possible. By default, cloning is on (set to
143 true).
144
145 get_clone_behavior( )
146 Returns the current behavior for data cloning.
147
148 set_behavior( <scalar> )
149 Specify which built-in behavior for merging that is desired. The
150 scalar must be one of those given below.
151
152 get_behavior( )
153 Returns the behavior that is currently in use by Hash::Merge.
154
155 specify_behavior( <hashref>, [<name>] ) [deprecated]
156 Alias for "add_behavior_spec".
157
158 add_behavior_spec( <hashref>, [<name>] )
159 Add a custom merge behavior spec for Hash::Merge. This must be a
160 hashref defined with (at least) 3 keys, SCALAR, ARRAY, and HASH;
161 each of those keys must have another hashref with (at least) the
162 same 3 keys defined. Furthermore, the values in those hashes must
163 be coderefs. These will be called with two arguments, the left and
164 right values for the merge. Your coderef should return either a
165 scalar or an array or hash reference as per your planned behavior.
166 If necessary, use the functions _hashify and _merge_hashes as
167 helper functions for these. For example, if you want to add the
168 left SCALAR to the right ARRAY, you can have your behavior
169 specification include:
170
171 %spec = ( ...SCALAR => { ARRAY => sub { [ $_[0], @$_[1] ] }, ... } } );
172
173 Note that you can import _hashify and _merge_hashes into your
174 program's namespace with the 'custom' tag.
175
176 get_behavior_spec( [<name>] )
177 Return a previously defined merge behavior spec. If name ism't
178 specified, the same default as add_behavior_spec is applied.
179
180 If no such name is known referring to an behavior spec, nothing is
181 returned.
182
184 Here is the specifics on how the current internal behaviors are called,
185 and what each does. Assume that the left value is given as $a, and the
186 right as $b (these are either scalars or appropriate references)
187
188 LEFT TYPE RIGHT TYPE LEFT_PRECEDENT RIGHT_PRECEDENT
189 SCALAR SCALAR $a $b
190 SCALAR ARRAY $a ( $a, @$b )
191 SCALAR HASH $a %$b
192 ARRAY SCALAR ( @$a, $b ) $b
193 ARRAY ARRAY ( @$a, @$b ) ( @$a, @$b )
194 ARRAY HASH ( @$a, values %$b ) %$b
195 HASH SCALAR %$a $b
196 HASH ARRAY %$a ( values %$a, @$b )
197 HASH HASH merge( %$a, %$b ) merge( %$a, %$b )
198
199 LEFT TYPE RIGHT TYPE STORAGE_PRECEDENT RETAINMENT_PRECEDENT
200 SCALAR SCALAR $a ( $a ,$b )
201 SCALAR ARRAY ( $a, @$b ) ( $a, @$b )
202 SCALAR HASH %$b merge( hashify( $a ), %$b )
203 ARRAY SCALAR ( @$a, $b ) ( @$a, $b )
204 ARRAY ARRAY ( @$a, @$b ) ( @$a, @$b )
205 ARRAY HASH %$b merge( hashify( @$a ), %$b )
206 HASH SCALAR %$a merge( %$a, hashify( $b ) )
207 HASH ARRAY %$a merge( %$a, hashify( @$b ) )
208 HASH HASH merge( %$a, %$b ) merge( %$a, %$b )
209
210 (*) note that merge calls _merge_hashes, hashify calls _hashify.
211
213 Michael K. Neylon <mneylon-pm@masemware.com>, Daniel Muey
214 <dmuey@cpan.org>, Jens Rehsack <rehsack@cpan.org>, Stefan Hermes
215 <hermes@cpan.org>
216
218 Copyright (c) 2001,2002 Michael K. Neylon. All rights reserved.
219 Copyright (c) 2013-2020 Jens Rehsack. All rights reserved. Copyright
220 (c) 2017-2020 Stefan Hermes. All rights reserved.
221
222 This library is free software. You can redistribute it and/or modify
223 it under the same terms as Perl itself.
224
225
226
227perl v5.34.0 2022-01-21 Hash::Merge(3)