sleep a second between scans
[Biblio-RFID.git] / scripts / scan.pl
index f4ec02a..10df6b4 100755 (executable)
@@ -22,15 +22,32 @@ GetOptions(
 my $rfid = RFID::Biblio::Reader->new( $reader );
 $RFID::Biblio::debug = $debug;
 
+sub tag {
+       my $tag = shift;
+       return $tag
+               , " AFI: "
+               , uc unpack('H2', $rfid->afi($tag))
+               , " "
+               , dump( RFID::Biblio::RFID501->to_hash( $rfid->blocks($tag) ) )
+               , $/
+               ;
+}
+
 do {
-       my @visible = $rfid->tags;
-       foreach my $tag ( @visible ) {
-               print $tag
-                       , " AFI: "
-                       , uc unpack('H2', $rfid->afi($tag))
-                       , " "
-                       , dump( RFID::Biblio::RFID501->to_hash( $rfid->blocks($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;