summaryrefslogtreecommitdiff
path: root/ext/Hash-Util
diff options
context:
space:
mode:
authorYves Orton <demerphq@gmail.com>2013-05-07 11:22:44 +0200
committerYves Orton <demerphq@gmail.com>2013-05-07 12:05:32 +0200
commit4950784de8a40c6d83ebf86e563b1de2e1c32c18 (patch)
treee7a0b16271991cd10264a55bcbaee12854126e9e /ext/Hash-Util
parent42b49dd2b85336d203323f188bd9b68595ae105e (diff)
downloadperl-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.pm22
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.