⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 filter.t

📁 linux 下的源代码分析阅读器 red hat公司新版
💻 T
字号:
#!./perl -w# ID: %I%, %G%   use strict ;use lib 't' ;use BerkeleyDB; use util ;print "1..52\n";my $Dfile = "dbhash.tmp";unlink $Dfile;umask(0) ;{   # DBM Filter tests   use strict ;   my (%h, $db) ;   my ($fetch_key, $store_key, $fetch_value, $store_value) = ("") x 4 ;   unlink $Dfile;   sub checkOutput   {       my($fk, $sk, $fv, $sv) = @_ ;       return           $fetch_key eq $fk && $store_key eq $sk && 	   $fetch_value eq $fv && $store_value eq $sv &&	   $_ eq 'original' ;   }       ok 1, $db = tie %h, 'BerkeleyDB::Hash',     		-Filename   => $Dfile, 	        -Flags      => DB_CREATE;    $db->filter_fetch_key   (sub { $fetch_key = $_ }) ;   $db->filter_store_key   (sub { $store_key = $_ }) ;   $db->filter_fetch_value (sub { $fetch_value = $_}) ;   $db->filter_store_value (sub { $store_value = $_ }) ;   $_ = "original" ;   $h{"fred"} = "joe" ;   #                   fk   sk     fv   sv   ok 2, checkOutput( "", "fred", "", "joe") ;   ($fetch_key, $store_key, $fetch_value, $store_value) = ("") x 4 ;   ok 3, $h{"fred"} eq "joe";   #                   fk    sk     fv    sv   ok 4, checkOutput( "", "fred", "joe", "") ;   ($fetch_key, $store_key, $fetch_value, $store_value) = ("") x 4 ;   ok 5, $db->FIRSTKEY() eq "fred" ;   #                    fk     sk  fv  sv   ok 6, checkOutput( "fred", "", "", "") ;   # replace the filters, but remember the previous set   my ($old_fk) = $db->filter_fetch_key      			(sub { $_ = uc $_ ; $fetch_key = $_ }) ;   my ($old_sk) = $db->filter_store_key      			(sub { $_ = lc $_ ; $store_key = $_ }) ;   my ($old_fv) = $db->filter_fetch_value    			(sub { $_ = "[$_]"; $fetch_value = $_ }) ;   my ($old_sv) = $db->filter_store_value    			(sub { s/o/x/g; $store_value = $_ }) ;      ($fetch_key, $store_key, $fetch_value, $store_value) = ("") x 4 ;   $h{"Fred"} = "Joe" ;   #                   fk   sk     fv    sv   ok 7, checkOutput( "", "fred", "", "Jxe") ;   ($fetch_key, $store_key, $fetch_value, $store_value) = ("") x 4 ;   ok 8, $h{"Fred"} eq "[Jxe]";   print "$h{'Fred'}\n";   #                   fk   sk     fv    sv   ok 9, checkOutput( "", "fred", "[Jxe]", "") ;   ($fetch_key, $store_key, $fetch_value, $store_value) = ("") x 4 ;   ok 10, $db->FIRSTKEY() eq "FRED" ;   #                   fk   sk     fv    sv   ok 11, checkOutput( "FRED", "", "", "") ;   # put the original filters back   $db->filter_fetch_key   ($old_fk);   $db->filter_store_key   ($old_sk);   $db->filter_fetch_value ($old_fv);   $db->filter_store_value ($old_sv);   ($fetch_key, $store_key, $fetch_value, $store_value) = ("") x 4 ;   $h{"fred"} = "joe" ;   ok 12, checkOutput( "", "fred", "", "joe") ;   ($fetch_key, $store_key, $fetch_value, $store_value) = ("") x 4 ;   ok 13, $h{"fred"} eq "joe";   ok 14, checkOutput( "", "fred", "joe", "") ;   ($fetch_key, $store_key, $fetch_value, $store_value) = ("") x 4 ;   ok 15, $db->FIRSTKEY() eq "fred" ;   ok 16, checkOutput( "fred", "", "", "") ;   # delete the filters   $db->filter_fetch_key   (undef);   $db->filter_store_key   (undef);   $db->filter_fetch_value (undef);   $db->filter_store_value (undef);   ($fetch_key, $store_key, $fetch_value, $store_value) = ("") x 4 ;   $h{"fred"} = "joe" ;   ok 17, checkOutput( "", "", "", "") ;   ($fetch_key, $store_key, $fetch_value, $store_value) = ("") x 4 ;   ok 18, $h{"fred"} eq "joe";   ok 19, checkOutput( "", "", "", "") ;   ($fetch_key, $store_key, $fetch_value, $store_value) = ("") x 4 ;   ok 20, $db->FIRSTKEY() eq "fred" ;   ok 21, checkOutput( "", "", "", "") ;   undef $db ;   untie %h;   unlink $Dfile;}{        # DBM Filter with a closure    use strict ;    my (%h, $db) ;    unlink $Dfile;    ok 22, $db = tie %h, 'BerkeleyDB::Hash',     		-Filename   => $Dfile, 	        -Flags      => DB_CREATE;     my %result = () ;    sub Closure    {        my ($name) = @_ ;	my $count = 0 ;	my @kept = () ;	return sub { ++$count ; 		     push @kept, $_ ; 		     $result{$name} = "$name - $count: [@kept]" ;		   }    }    $db->filter_store_key(Closure("store key"))  ;    $db->filter_store_value(Closure("store value")) ;    $db->filter_fetch_key(Closure("fetch key")) ;    $db->filter_fetch_value(Closure("fetch value")) ;    $_ = "original" ;    $h{"fred"} = "joe" ;    ok 23, $result{"store key"} eq "store key - 1: [fred]" ;    ok 24, $result{"store value"} eq "store value - 1: [joe]" ;    ok 25, ! defined $result{"fetch key"}  ;    ok 26, ! defined $result{"fetch value"}  ;    ok 27, $_ eq "original"  ;    ok 28, $db->FIRSTKEY() eq "fred"  ;    ok 29, $result{"store key"} eq "store key - 1: [fred]" ;    ok 30, $result{"store value"} eq "store value - 1: [joe]" ;    ok 31, $result{"fetch key"} eq "fetch key - 1: [fred]" ;    ok 32, ! defined $result{"fetch value"}  ;    ok 33, $_ eq "original"  ;    $h{"jim"}  = "john" ;    ok 34, $result{"store key"} eq "store key - 2: [fred jim]" ;    ok 35, $result{"store value"} eq "store value - 2: [joe john]" ;    ok 36, $result{"fetch key"} eq "fetch key - 1: [fred]" ;    ok 37, ! defined $result{"fetch value"}  ;    ok 38, $_ eq "original"  ;    ok 39, $h{"fred"} eq "joe" ;    ok 40, $result{"store key"} eq "store key - 3: [fred jim fred]" ;    ok 41, $result{"store value"} eq "store value - 2: [joe john]" ;    ok 42, $result{"fetch key"} eq "fetch key - 1: [fred]" ;    ok 43, $result{"fetch value"} eq "fetch value - 1: [joe]" ;    ok 44, $_ eq "original" ;    undef $db ;    untie %h;    unlink $Dfile;}		{   # DBM Filter recursion detection   use strict ;   my (%h, $db) ;   unlink $Dfile;    ok 45, $db = tie %h, 'BerkeleyDB::Hash',     		-Filename   => $Dfile, 	        -Flags      => DB_CREATE;    $db->filter_store_key (sub { $_ = $h{$_} }) ;   eval '$h{1} = 1234' ;   ok 46, $@ =~ /^recursion detected in filter_store_key at/ ;      undef $db ;   untie %h;   unlink $Dfile;}{   # Check that DBM Filter can cope with read-only $_   #use warnings ;   use strict ;   my (%h, $db) ;   unlink $Dfile;   ok 47, $db = tie %h, 'BerkeleyDB::Hash',     		-Filename   => $Dfile, 	        -Flags      => DB_CREATE;    $db->filter_fetch_key   (sub { }) ;   $db->filter_store_key   (sub { }) ;   $db->filter_fetch_value (sub { }) ;   $db->filter_store_value (sub { }) ;   $_ = "original" ;   $h{"fred"} = "joe" ;   ok(48, $h{"fred"} eq "joe");   eval { grep { $h{$_} } (1, 2, 3) };   ok (49, ! $@);   # delete the filters   $db->filter_fetch_key   (undef);   $db->filter_store_key   (undef);   $db->filter_fetch_value (undef);   $db->filter_store_value (undef);   $h{"fred"} = "joe" ;   ok(50, $h{"fred"} eq "joe");   ok(51, $db->FIRSTKEY() eq "fred") ;      eval { grep { $h{$_} } (1, 2, 3) };   ok (52, ! $@);   undef $db ;   untie %h;   unlink $Dfile;}if(0){    # Filter without tie    use strict ;    my (%h, $db) ;    unlink $Dfile;    ok 53, $db = tie %h, 'BerkeleyDB::Hash',     		-Filename   => $Dfile, 	        -Flags      => DB_CREATE;     my %result = () ;    sub INC { return ++ $_[0] }    sub DEC { return -- $_[0] }    #$db->filter_fetch_key   (sub { warn "FFK $_\n"; $_ = INC($_); warn "XX\n" }) ;    #$db->filter_store_key   (sub { warn "FSK $_\n"; $_ = DEC($_); warn "XX\n" }) ;    #$db->filter_fetch_value (sub { warn "FFV $_\n"; $_ = INC($_); warn "XX\n"}) ;    #$db->filter_store_value (sub { warn "FSV $_\n"; $_ = DEC($_); warn "XX\n" }) ;    $db->filter_fetch_key   (sub { warn "FFK $_\n"; $_ = pack("i", $_); warn "XX\n" }) ;    $db->filter_store_key   (sub { warn "FSK $_\n"; $_ = unpack("i", $_); warn "XX\n" }) ;    $db->filter_fetch_value (sub { warn "FFV $_\n"; $_ = pack("i", $_); warn "XX\n"}) ;    #$db->filter_store_value (sub { warn "FSV $_\n"; $_ = unpack("i", $_); warn "XX\n" }) ;    #$db->filter_fetch_key   (sub { ++ $_ }) ;    #$db->filter_store_key   (sub { -- $_ }) ;    #$db->filter_fetch_value (sub { ++ $_ }) ;    #$db->filter_store_value (sub { -- $_ }) ;    my ($k, $v) = (0,0);    ok 54, ! $db->db_put(3,5);    exit;    ok 55, ! $db->db_get(3, $v);    ok 56, $v == 5 ;    $h{4} = 7 ;    ok 57, $h{4} == 7;    $k = 10;    $v = 30;    $h{$k} = $v ;    ok 58, $k == 10;    ok 59, $v == 30;    ok 60, $h{$k} == 30;    $k = 3;    ok 61, ! $db->db_get($k, $v, DB_GET_BOTH);    ok 62, $k == 3 ;    ok 63, $v == 5 ;    my $cursor = $db->db_cursor();    my %tmp = ();    while ($cursor->c_get($k, $v, DB_NEXT) == 0)    {	$tmp{$k} = $v;    }    ok 64, keys %tmp == 3 ;    ok 65, $tmp{3} == 5;    undef $cursor ;    undef $db ;    untie %h;    unlink $Dfile;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -