X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBM%2FDeep%2FHash.pm;h=73f3d9f1828be2904bfa352c7ca51c73917dc32a;hb=460b106703a60d35609f3673ceb5fa39173fdef2;hp=ac6b7cdb52c50175eea86f2d1bf64b15983b740d;hpb=f75b719ee773050f0487a93f8bbae70dd92f861b;p=dbsrgits%2FDBM-Deep.git diff --git a/lib/DBM/Deep/Hash.pm b/lib/DBM/Deep/Hash.pm index ac6b7cd..73f3d9f 100644 --- a/lib/DBM/Deep/Hash.pm +++ b/lib/DBM/Deep/Hash.pm @@ -1,6 +1,9 @@ package DBM::Deep::Hash; +use 5.6.0; + use strict; +use warnings; use base 'DBM::Deep'; @@ -8,6 +11,24 @@ sub _get_self { eval { local $SIG{'__DIE__'}; tied( %{$_[0]} ) } || $_[0] } +sub _repr { shift;return { @_ } } + +sub _import { + my $self = shift; + my ($struct) = @_; + + eval { + local $SIG{'__DIE__'}; + foreach my $key (keys %$struct) { + $self->put($key, $struct->{$key}); + } + }; if ($@) { + $self->_throw_error("Cannot import: type mismatch"); + } + + return 1; +} + sub TIEHASH { ## # Tied hash constructor method, called by Perl's tie() function. @@ -22,8 +43,8 @@ sub TIEHASH { sub FETCH { my $self = shift->_get_self; - my $key = ($self->_root->{filter_store_key}) - ? $self->_root->{filter_store_key}->($_[0]) + my $key = ($self->_fileobj->{filter_store_key}) + ? $self->_fileobj->{filter_store_key}->($_[0]) : $_[0]; return $self->SUPER::FETCH( $key ); @@ -31,8 +52,8 @@ sub FETCH { sub STORE { my $self = shift->_get_self; - my $key = ($self->_root->{filter_store_key}) - ? $self->_root->{filter_store_key}->($_[0]) + my $key = ($self->_fileobj->{filter_store_key}) + ? $self->_fileobj->{filter_store_key}->($_[0]) : $_[0]; my $value = $_[1]; @@ -41,8 +62,8 @@ sub STORE { sub EXISTS { my $self = shift->_get_self; - my $key = ($self->_root->{filter_store_key}) - ? $self->_root->{filter_store_key}->($_[0]) + my $key = ($self->_fileobj->{filter_store_key}) + ? $self->_fileobj->{filter_store_key}->($_[0]) : $_[0]; return $self->SUPER::EXISTS( $key ); @@ -50,8 +71,8 @@ sub EXISTS { sub DELETE { my $self = shift->_get_self; - my $key = ($self->_root->{filter_store_key}) - ? $self->_root->{filter_store_key}->($_[0]) + my $key = ($self->_fileobj->{filter_store_key}) + ? $self->_fileobj->{filter_store_key}->($_[0]) : $_[0]; return $self->SUPER::DELETE( $key ); @@ -61,7 +82,7 @@ sub FIRSTKEY { ## # Locate and return first key (in no particular order) ## - my $self = $_[0]->_get_self; + my $self = shift->_get_self; ## # Request shared lock for reading @@ -72,8 +93,8 @@ sub FIRSTKEY { $self->unlock(); - return ($result && $self->_root->{filter_fetch_key}) - ? $self->_root->{filter_fetch_key}->($result) + return ($result && $self->_fileobj->{filter_fetch_key}) + ? $self->_fileobj->{filter_fetch_key}->($result) : $result; } @@ -81,11 +102,11 @@ sub NEXTKEY { ## # Return next key (in no particular order), given previous one ## - my $self = $_[0]->_get_self; + my $self = shift->_get_self; - my $prev_key = ($self->_root->{filter_store_key}) - ? $self->_root->{filter_store_key}->($_[1]) - : $_[1]; + my $prev_key = ($self->_fileobj->{filter_store_key}) + ? $self->_fileobj->{filter_store_key}->($_[0]) + : $_[0]; my $prev_md5 = $self->{engine}{digest}->($prev_key); @@ -98,16 +119,30 @@ sub NEXTKEY { $self->unlock(); - return ($result && $self->_root->{filter_fetch_key}) - ? $self->_root->{filter_fetch_key}->($result) + return ($result && $self->_fileobj->{filter_fetch_key}) + ? $self->_fileobj->{filter_fetch_key}->($result) : $result; } ## # Public method aliases ## -sub first_key { (CORE::shift)->FIRSTKEY(@_) } -sub next_key { (CORE::shift)->NEXTKEY(@_) } +sub first_key { (shift)->FIRSTKEY(@_) } +sub next_key { (shift)->NEXTKEY(@_) } + +sub _copy_node { + my $self = shift; + my ($db_temp) = @_; + + my $key = $self->first_key(); + while ($key) { + my $value = $self->get($key); + $self->_copy_value( \$db_temp->{$key}, $value ); + $key = $self->next_key($key); + } + + return 1; +} 1; __END__