our @EXPORT_OK = qw(lock_keys unlock_keys lock_value unlock_value
lock_hash unlock_hash
);
-our $VERSION = 0.04;
+our $VERSION = 0.05;
=head1 NAME
=head1 SYNOPSIS
- use Hash::Util qw(lock_keys unlock_keys
+ use Hash::Util qw(lock_keys unlock_keys
lock_value unlock_value
lock_hash unlock_hash);
Restricts the given %hash's set of keys to @keys. If @keys is not
given it restricts it to its current keyset. No more keys can be
-added. delete() and exists() will still work, but it does not effect
-the set of allowed keys.
+added. delete() and exists() will still work, but will not alter
+the set of allowed keys. B<Note>: the current implementation prevents
+the hash from being bless()ed while it is in a locked state. Any attempt
+to do so will raise an exception. Of course you can still bless()
+the hash before you call lock_keys() so this shouldn't be a problem.
- unlock_keys(%hash;)
+ unlock_keys(%hash);
Removes the restriction on the %hash's keyset.
Internals::SvREADONLY %$hash, 1;
}
- return undef;
+ return;
}
sub unlock_keys (\%) {
my($hash) = shift;
Internals::SvREADONLY %$hash, 0;
- return undef;
+ return;
}
=item lock_value
=item unlock_value
- lock_key (%hash, $key);
- unlock_key(%hash, $key);
+ lock_value (%hash, $key);
+ unlock_value(%hash, $key);
Locks and unlocks an individual key of a hash. The value of a locked
key cannot be changed.
=back
+=head1 CAVEATS
+
+Note that the trapping of the restricted operations is not atomic:
+for example
+
+ eval { %hash = (illegal_key => 1) }
+
+leaves the C<%hash> empty rather than with its original contents.
+
=head1 AUTHOR
Michael G Schwern <schwern@pobox.com> on top of code by Nick