=================================================================== RCS file: /cvs/palm/Palm-Keyring/examples/example3.pl,v retrieving revision 1.6 retrieving revision 1.12 diff -u -r1.6 -r1.12 --- palm/Palm-Keyring/examples/example3.pl 2007/09/12 04:59:37 1.6 +++ palm/Palm-Keyring/examples/example3.pl 2009/12/16 22:54:55 1.12 @@ -1,5 +1,5 @@ #!/usr/bin/perl -# $RedRiver: example3.pl,v 1.5 2007/08/10 04:13:31 andrew Exp $ +# $RedRiver: example3.pl,v 1.11 2008/09/17 14:49:50 andrew Exp $ ######################################################################## # palmkeyring.pl *** a command line client for Keyring databases. # @@ -17,8 +17,6 @@ Getopt::Long::Configure('bundling'); use Term::ReadLine; -use YAML; - use Palm::PDB; use Palm::Keyring; @@ -26,6 +24,7 @@ my $PDBFile; my $Categories; my $Names; +my $Accounts; my $Action_List; my $Action_Show; @@ -33,6 +32,7 @@ "file|f=s" => \$PDBFile, "categories|c:s@" => \$Categories, "name|n=s@" => \$Names, + "account|a=s@" => \$Accounts, "list|l" => \$Action_List, "show|s" => \$Action_Show, ); @@ -44,6 +44,7 @@ if ($Action_List) { show_list(); } elsif ($Action_Show) { + push @{ $Names }, @ARGV; show_items($Names); } elsif (defined $Categories) { show_categories(); @@ -93,11 +94,8 @@ sub show_items { get_password() || die "Couldn't decrypt file!"; - foreach (0..$#{ $pdb->{'records'} }) { - next if $_ == 0; - my $r = $pdb->{'records'}->[$_]; - + my $r = $pdb->{'records'}->[$_]; my $category = $pdb->{'appinfo'}->{'categories'}->[ $r->{'category'} ]->{'name'}; @@ -110,7 +108,13 @@ } next if ( @{ $Categories } || @{ $Names } ) && not $matched; - my $a = $pdb->Decrypt($r); + my $a = $pdb->Decrypt($r); + + $matched = 0; + foreach my $account (@{ $Accounts }) { + $matched++ if uc($a->{1}->{data}) eq uc($account); + } + next if ( @{ $Accounts } ) && not $matched; # XXX Fix up formatting print $a->{0}->{data} . "\n\t" .