Newer
Older
package Travel::Status::DE::EFA::Result;
no if $] >= 5.018, warnings => 'experimental::smartmatch';
Travel::Status::DE::EFA::Result->mk_ro_accessors(
qw(countdown date delay destination is_cancelled info key line lineref
platform platform_db platform_name sched_date sched_time time type)
sub new {
my ( $obj, %conf ) = @_;
my $ref = \%conf;
if ( defined $ref->{delay} and $ref->{delay} eq '-9999' ) {
$ref->{is_cancelled} = 1;
}
else {
$ref->{is_cancelled} = 0;
}
sub route_pre {
my ($self) = @_;
return @{ $self->{prev_route} };
}
sub route_post {
my ($self) = @_;
return @{ $self->{next_route} };
}
sub route_interesting {
my ( $self, $max_parts ) = @_;
my @via = $self->route_post;
my ( @via_main, @via_show, $last_stop );
$max_parts //= 3;
for my $stop (@via) {
Birte Kristina Friesel
committed
if (
$stop->{stop_suf} =~ m{ Bf | Hbf | Flughafen | Hauptbahnhof
| Krankenhaus | Klinik | (?: S $ ) }ox
)
{
push( @via_main, $stop );
}
}
$last_stop = pop(@via);
Birte Kristina Friesel
committed
if ( @via_main and $via_main[-1] == $last_stop ) {
pop(@via_main);
}
Birte Kristina Friesel
committed
if ( @via and $via[-1] == $last_stop ) {
pop(@via);
}
Birte Kristina Friesel
committed
if ( @via_main and @via and $via[0] == $via_main[0] ) {
shift(@via_main);
}
if ( @via < $max_parts ) {
@via_show = @via;
}
else {
if ( @via_main >= $max_parts ) {
@via_show = ( $via[0] );
}
else {
@via_show = splice( @via, 0, $max_parts - @via_main );
}
while ( @via_show < $max_parts and @via_main ) {
my $stop = shift(@via_main);
Birte Kristina Friesel
committed
if ( $stop ~~ \@via_show or $stop == $last_stop ) {
next;
}
push( @via_show, $stop );
}
}
return @via_show;
}
sub TO_JSON {
my ($self) = @_;
return { %{$self} };
}
Travel::Status::DE::EFA::Result - Information about a single
departure received by Travel::Status::DE::EFA
for my $departure ($status->results) {
printf(
"At %s: %s to %s from platform %d\n",
$departure->time, $departure->line, $departure->destination,
$departure->platform
);
}
Travel::Status::DE::EFA::Result describes a single departure as obtained by
Travel::Status::DE::EFA. It contains information about the time, platform,
"Actual" in the description means that the delay (if available) is already
included in the calculation, "Scheduled" means it isn't.
=item $departure->countdown
Actual time in minutes from now until the tram/bus/train will depart.
If delay information is available, it is already included.
=item $departure->date
Actual departure date (DD.MM.YYYY).
=item $departure->delay
Expected delay from scheduled departure time in minutes. A delay of 0
indicates departure on time. undef when no realtime information is available.
=item $departure->info
Additional information related to the departure (string). If departures for
an address were requested, this is the stop name, otherwise it may be recent
news related to the line's schedule. If no information is available, returns
an empty string.
=item $departure->is_cancelled
1 if the departure got cancelled, 0 otherwise.
Unknown. Unlike the name may suggest, this is not a unique key / UUID for a
departure: On the same day, different lines departing at the same station
may have the same key. It might, however, be unique when combined with the
B<line> information.
=item $departure->line
The name/number of the line.
Travel::Status::DE::EFA::Line(3pm) object describing the departing line in
Departure platform number (may not be a number).
true if the platform number is operated by DB ("Gleis x"), false ("Bstg. x")
otherwise.
Unfortunately, there is no distinction between tram and bus platforms yet,
which also may have the same numbers.
=item $departure->route_interesting
List of up to three "interesting" stations served by this departure. Is a
subset of B<route_post>. Each station is a hash reference, see ROUTE STATIONS
for details.
=item $departure->route_pre
List of stations the train passed (or will have passed) befoe this stop.
Each station is a hash reference, see ROUTE STATIONS for details.
=item $departure->route_post
List of stations the train will pass after this stop.
Each station is a hash reference, see ROUTE STATIONS for details.
Scheduled departure date (DD.MM.YYYY).
Scheduled departure time (HH:MM).
Type of the departure. Note that efa.vrr.de sometimes puts bogus data in this
field. See L</DEPARTURE TYPES>.
=head2 INTERNAL
=over
=item $departure = Travel::Status::DE::EFA::Result->new(I<%data>)
Returns a new Travel::Status::DE::EFA::Result object. You should not need to
=item $departure->TO_JSON
Allows the object data to be serialized to JSON.
=head1 DEPARTURE TYPES
The following are known so far:
=over
=item * Abellio-Zug
=item * Eurocity
=item * Intercity-Express
=item * NE (NachtExpress / night bus)
=item * Niederflurbus
=item * R-Bahn (RE / RegionalExpress)
=item * S-Bahn
=item * SB (Schnellbus)
=item * U-Bahn
=back
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
=head1 ROUTE STATIONS
The B<route> accessors return hashrefs, each of which corresponds to a single
station. Note that the route is solely based on the schedule, delays or
changed platforms are not taken into account.
For a station I<$stop>,
the following keys are available:
=over
=item $stop->{arr_date}
arrival date (DD.MM.YYYY). undef if this is the first scheduled stop.
=item $stop->{arr_time}
arrival time (HH:MM). undef if this is the first scheduled stop.
=item $stop->{dep_date}
departure date (DD.MM.YYYY). undef if this is the final scehduled stop.
=item $stop->{dep_time}
departure time (HH:MM). undef if this is the final scehduled stop.
=item $stop->{stop}
stop name with city prefix ("I<City> I<Stop>", for instance
"Essen RE<uuml>ttenscheider Stern").
=item $stop->{stop_suf}
stop name without city prefix, for instance "RE<uuml>ttenscheider Stern".
=item $stop->{platform}
Platform name/number if available, empty string otherwise.
=back
=head1 DIAGNOSTICS
None.
=head1 DEPENDENCIES
=over
=item Class::Accessor(3pm)
=back
=head1 BUGS AND LIMITATIONS
C<< $result->type >> may contain bogus data. This comes from the efa.vrr.de
interface.
Travel::Status::DE::EFA(3pm).
Copyright (C) 2011-2014 by Daniel Friesel E<lt>derf@finalrewind.orgE<gt>
=head1 LICENSE
This module is licensed under the same terms as Perl itself.