AnyEvent-GPSD

 view release on metacpan or  search on metacpan

GPSD.pm  view on Meta::CPAN

162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
      &$event;
   }
}
 
sub retry {
   my ($self) = @_;
 
   delete $self->{fh};
   delete $self->{command};
 
   Scalar::Util::weaken $self;
   $self->{retry_w} = AnyEvent->timer (after => 1, cb => sub {
      delete $self->{retry_w};
      $self->connect;
   });
}
 
# make sure we send "no fix" updates when we lose connectivity
sub interval_timer {
   my ($self) = @_;
 
   $self->{interval_w} = AnyEvent->timer (after => $self->{interval}, cb => sub {
      if (AnyEvent->now - $self->{fix}{time} > $self->{interval} * 1.9) {
         $self->{fix}{mode} = 1;
         $self->event (fix => $self->{fix});
      }
 
      $self->interval_timer;
   });
 
   Scalar::Util::weaken $self;
}
 
sub connect {
   my ($self) = @_;
 
   return if $self->{fh};
 
   AnyEvent::Socket::tcp_connect $self->{host} || "localhost", $self->{port} || 2947, sub {
      my ($fh) = @_;

GPSD.pm  view on Meta::CPAN

238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
         $self->send ("y");
         $self->send ("c");
 
         $self->event ("connect");
         $self->log ("connect");
      } else {
         $self->event ("error");
      }
   };
 
   Scalar::Util::weaken $self;
}
 
sub drain_wbuf {
   my ($self) = @_;
 
   $self->{fh}->push_write (join "", @{ $self->{command}[0] });
}
 
sub send {
   my ($self, $command, $args) = @_;

GPSD.pm  view on Meta::CPAN

469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
require JSON;
 
open my $fh, "<:perlio", $path
   or Carp::croak "$path: $!";
 
$self->{stretch}  = $option{stretch} || 1;
$self->{compress} = $option{compress};
 
$self->{imterval} /= $self->{stretch};
 
Scalar::Util::weaken $self;
 
$self->{replay_cb} = sub {
   my $line = <$fh>;
 
   if (2 > length $line) {
      $self->replay_log;
   } else {
      my ($time, $type, @data) = @{ JSON::decode_json ($line) };
 
      $time *= $self->{stretch};



( run in 0.317 second using v1.01-cache-2.11-cpan-a9ef4e587e4 )