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
mot platform platform_db platform_name sched_date sched_time time type)
my @mot_mapping = qw{
zug s-bahn u-bahn stadtbahn tram stadtbus regionalbus
schnellbus seilbahn schiff ast sonstige
};
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 mot_name {
my ($self) = @_;
return $mot_mapping[ $self->{mot} ] // 'sonstige';
}
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->name_suf =~ m{ Bf | Hbf | Flughafen | Hauptbahnhof
Birte Kristina Friesel
committed
| 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);
# FIXME cannot smartmatch $stop since it became an object
# 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
=item $departure->mot
Returns the "mode of transport" number. This is usually an integer between 0
and 11.
=item $departure->mot_name
Returns the "mode of transport", for instance "zug", "s-bahn", "tram" or
"sonstige".
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 may alsn have the same numbers.
=item $departure->route_interesting
List of up to three "interesting" stations served by this departure. Is a
Birte Kristina Friesel
committed
subset of B<route_post>. Each station is a Travel::Status::DE::EFA::Stop(3pm)
object.
=item $departure->route_pre
List of stations the train passed (or will have passed) befoe this stop.
Birte Kristina Friesel
committed
Each station is a Travel::Status::DE::EFA::Stop(3pm) object.
=item $departure->route_post
List of stations the train will pass after this stop.
Birte Kristina Friesel
committed
Each station is a Travel::Status::DE::EFA::Stop(3pm) object.
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
=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-2015 by Daniel Friesel E<lt>derf@finalrewind.orgE<gt>
=head1 LICENSE
This module is licensed under the same terms as Perl itself.