- my $state = "call";
- while (my $result = $t->getline) {
-# print "$state: $result";
- if ($state eq 'call' && $result =~ /$l/i) {
- $state = 'getaddr';
- push @out, uc $l;
- } elsif ($state eq 'getaddr' || $state eq 'inaddr') {
- if ($result =~ /^\s+([\w\s.,;:-]+)(?:<br>)?$/) {
- my $line = $1;
- unless ($line =~ /^\s+$/) {
- push @out, $line;
- $state = 'inaddr' unless $state eq 'inaddr';
- }
- } else {
- $state = 'runout' if $state eq 'inaddr';
- }
+ my $state = "blank";
+ while (my $result = eval { $t->getline(Timeout => 30) } || $@) {
+ dbg($result) if isdbg('qrz') && $result;
+ if ($@) {
+ push @out, $self->msg('e18', 'QRZ.com');
+ last;
+ }
+ if ($state eq 'blank' && $result =~ /^<Callsign>/i) {
+ $state = 'go';
+ } elsif ($state eq 'go') {
+ next if $result =~ m|<user>|;
+ next if $result =~ m|<u_views>|;
+ next if $result =~ m|<locref>|;
+ next if $result =~ m|<ccode>|;
+ next if $result =~ m|<dxcc>|;
+ last if $result =~ m|</Callsign>|;
+ my ($tag, $data) = $result =~ m|^\s*<(\w+)>(.*)</|;
+ push @out, sprintf "%10s: $data", $tag;