diff options
author | Yves Orton <demerphq@gmail.com> | 2013-05-07 11:22:44 +0200 |
---|---|---|
committer | Yves Orton <demerphq@gmail.com> | 2013-05-07 12:05:32 +0200 |
commit | 4950784de8a40c6d83ebf86e563b1de2e1c32c18 (patch) | |
tree | e7a0b16271991cd10264a55bcbaee12854126e9e /ext/Hash-Util | |
parent | 42b49dd2b85336d203323f188bd9b68595ae105e (diff) | |
download | perl-4950784de8a40c6d83ebf86e563b1de2e1c32c18.tar.gz |
document Hash::Util::hash_traversal_mask()
It still needs tests. But I figured it would be easier to test
by someone else if I documented it. (Ill try to get tests done for it
soon).
Diffstat (limited to 'ext/Hash-Util')
-rw-r--r-- | ext/Hash-Util/lib/Hash/Util.pm | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/ext/Hash-Util/lib/Hash/Util.pm b/ext/Hash-Util/lib/Hash/Util.pm index 336a28ec7e..ed47098056 100644 --- a/ext/Hash-Util/lib/Hash/Util.pm +++ b/ext/Hash-Util/lib/Hash/Util.pm @@ -31,6 +31,8 @@ our @EXPORT_OK = qw( hash_seed hash_value hv_store bucket_stats bucket_info bucket_array lock_hash_recurse unlock_hash_recurse + + hash_traversal_mask ); our $VERSION = '0.16'; require XSLoader; @@ -76,6 +78,8 @@ Hash::Util - A selection of general-utility hash subroutines hash_seed hash_value hv_store bucket_stats bucket_info bucket_array lock_hash_recurse unlock_hash_recurse + + hash_traversal_mask ); %hash = (foo => 42, bar => 23); @@ -105,6 +109,10 @@ Hash::Util - A selection of general-utility hash subroutines my $int_hash_value = hash_value( 'string' ); + my $mask= hash_traversal_mask(%hash); + + hash_traversal_mask(%hash,1234); + =head1 DESCRIPTION C<Hash::Util> and C<Hash::Util::FieldHash> contain special functions @@ -597,6 +605,20 @@ sub bucket_stats { Stores an alias to a variable in a hash instead of copying the value. +=item B<hash_traversal_mask> + +As of Perl 5.18 every hash its own hash traversal order, and this order +changes every time a new element is inserted in the hash. This functionality +is provided by maintaining an unsigned integer mask (U32) which is xor'ed +with the actual bucket id during a traverse of the hash buckets using keys(), +values() or each(). + +You can use this subroutine to get and set the traversal mask for a specific +hash. Setting the mask ensures that a given hash will produce the same key +order. B<Note> that this does B<not> guarantee that *two* hashes will produce +the same key order for the same hash seed and traversal mask, items that +collide into one bucket may have different orders regardless of this setting. + =back =head2 Operating on references to hashes. |