1 package DBM::Deep::Hash;
8 our $VERSION = q(0.99_03);
13 eval { local $SIG{'__DIE__'}; tied( %{$_[0]} ) } || $_[0]
16 #XXX Need to add a check here for @_ % 2
17 sub _repr { shift;return { @_ } }
24 local $SIG{'__DIE__'};
25 foreach my $key (keys %$struct) {
26 $self->put($key, $struct->{$key});
29 $self->_throw_error("Cannot import: type mismatch");
37 # Tied hash constructor method, called by Perl's tie() function.
40 my $args = $class->_get_args( @_ );
42 $args->{type} = $class->TYPE_HASH;
44 return $class->_init($args);
48 my $self = shift->_get_self;
49 my $key = ($self->_fileobj->{filter_store_key})
50 ? $self->_fileobj->{filter_store_key}->($_[0])
53 return $self->SUPER::FETCH( $key, $_[0] );
57 my $self = shift->_get_self;
58 my $key = ($self->_fileobj->{filter_store_key})
59 ? $self->_fileobj->{filter_store_key}->($_[0])
63 return $self->SUPER::STORE( $key, $value, $_[0] );
67 my $self = shift->_get_self;
68 my $key = ($self->_fileobj->{filter_store_key})
69 ? $self->_fileobj->{filter_store_key}->($_[0])
72 return $self->SUPER::EXISTS( $key );
76 my $self = shift->_get_self;
77 my $key = ($self->_fileobj->{filter_store_key})
78 ? $self->_fileobj->{filter_store_key}->($_[0])
81 return $self->SUPER::DELETE( $key, $_[0] );
86 # Locate and return first key (in no particular order)
88 my $self = shift->_get_self;
91 # Request shared lock for reading
93 $self->lock( $self->LOCK_SH );
95 my $result = $self->_engine->get_next_key($self);
99 return ($result && $self->_fileobj->{filter_fetch_key})
100 ? $self->_fileobj->{filter_fetch_key}->($result)
106 # Return next key (in no particular order), given previous one
108 my $self = shift->_get_self;
110 my $prev_key = ($self->_fileobj->{filter_store_key})
111 ? $self->_fileobj->{filter_store_key}->($_[0])
114 my $prev_md5 = $self->_engine->apply_digest($prev_key);
117 # Request shared lock for reading
119 $self->lock( $self->LOCK_SH );
121 my $result = $self->_engine->get_next_key( $self, $prev_md5 );
125 return ($result && $self->_fileobj->{filter_fetch_key})
126 ? $self->_fileobj->{filter_fetch_key}->($result)
131 # Public method aliases
133 sub first_key { (shift)->FIRSTKEY(@_) }
134 sub next_key { (shift)->NEXTKEY(@_) }
140 my $key = $self->first_key();
142 my $value = $self->get($key);
143 $self->_copy_value( \$db_temp->{$key}, $value );
144 $key = $self->next_key($key);