use Data::Dump qw(dump);
use Getopt::Long;
use lib 'lib';
-use RFID::Biblio::Readers;
-use RFID::Biblio::RFID501;
+use Biblio::RFID::Reader;
+use Biblio::RFID::RFID501;
my $loop = 0;
-my $only;
+my $reader;
+my $debug = 0;
GetOptions(
- 'loop!' => \$loop,
- 'only=s', => \$only,
+ 'loop!' => \$loop,
+ 'reader=s', => \$reader,
+ 'debug+' => \$debug,
) || die $!;
-my @rfid = RFID::Biblio::Readers->available( $only );
+my $rfid = Biblio::RFID::Reader->new( $reader );
+$Biblio::RFID::debug = $debug;
+
+sub tag {
+ my $tag = shift;
+ return $tag
+ , " AFI: "
+ , uc unpack('H2', $rfid->afi($tag))
+ , " "
+ , dump( Biblio::RFID::RFID501->to_hash( $rfid->blocks($tag) ) )
+ , $/
+ ;
+}
do {
- foreach my $rfid ( @rfid ) {
- my $visible = $rfid->scan;
- foreach my $tag ( keys %$visible ) {
- warn "XXX $tag";
- print ref($rfid),"\t$tag\t", dump( RFID::Biblio::RFID501->to_hash( join('', @{ $visible->{$tag} }) ) ), $/;
- }
- }
+ my @visible = $rfid->tags(
+ enter => sub {
+ my $tag = shift;
+ print localtime()." enter ", tag($tag);
+
+ },
+ leave => sub {
+ my $tag = shift;
+ print localtime()." leave ", tag($tag);
+ },
+ );
+
+ warn localtime()." visible: ",join(' ',@visible),"\n";
+
+ sleep 1;
} while $loop;