Newer
Older
#!/usr/bin/env perl
use strict;
use warnings;
use 5.010;
our $VERSION = '1.05';
use Getopt::Long qw(:config no_ignore_case);
Birte Kristina Friesel
committed
use List::Util qw(first max);
use Travel::Status::DE::HAFAS;
my ( $date, $time );
my $arrivals = 0;
my $ignore_late = 0;
my $types = q{};
my $language;
my ( @excluded_mots, @exclusive_mots );
Birte Kristina Friesel
committed
my @output;
binmode( STDOUT, ':encoding(utf-8)' );
GetOptions(
'd|date=s' => \$date,
'h|help' => sub { show_help(0) },
'l|lang=s' => \$language,
'L|ignore-late' => \$ignore_late,
'm|mot=s' => \$types,
't|time=s' => \$time,
'V|version' => \&show_version,
'devmode' => \$developer_mode,
if ($list_services) {
printf( "%-40s %-14s %s\n\n", 'operator', 'abbr. (-s)', 'url (-u)' );
for my $service ( Travel::Status::DE::HAFAS::get_services() ) {
printf( "%-40s %-14s %s\n", @{$service}{qw(name shortname url)} );
}
exit 0;
}
my $status = Travel::Status::DE::HAFAS->new(
date => $date,
language => $language,
excluded_mots => \@excluded_mots,
exclusive_mots => \@exclusive_mots,
station => shift || show_help(1),
time => $time,
mode => $arrivals ? 'arr' : 'dep',
developer_mode => $developer_mode,
sub show_help {
my ($code) = @_;
print 'Usage: hafas-m [-d <dd.mm.yyyy>] [-m <motlist>] [-t <time>] '
. "<station>\n"
. "See also: man hafas-m\n";
exit $code;
}
sub show_version {
say "hafas-m version ${VERSION}";
sub parse_mot_options {
my $default_yes = 1;
my $help;
for my $type ( split( qr{,}, $types ) ) {
if ( $type eq 'help' or $type eq 'list' or $type eq '?' ) {
my @mots
= @{ Travel::Status::DE::HAFAS::get_service($service)
->{productbits} };
@mots = grep { $_ ne 'x' } @mots;
@mots = uniq @mots;
@mots = sort @mots;
say join( "\n", @mots );
exit 0;
}
elsif ( substr( $type, 0, 1 ) eq q{!} ) {
push( @excluded_mots, substr( $type, 1 ) );
}
else {
push( @exclusive_mots, $type );
}
}
}
sub show_similar_stops {
my @candidates = $status->similar_stops;
if (@candidates) {
say 'You might want to try one of the following stops:';
for my $c (@candidates) {
printf( "%s (%s)\n", $c->{name}, $c->{id} );
}
}
}
Birte Kristina Friesel
committed
sub display_result {
my (@lines) = @_;
my @line_length;
if ( not @lines ) {
die("Nothing to show\n");
}
Birte Kristina Friesel
committed
$line_length[$i] = max map { length( $_->[$i] ) } @lines;
}
for my $line (@lines) {
my $d = $line->[6];
if ( $d->messages ) {
print "\n";
for my $msg ( $d->messages ) {
printf( "# %s\n", $msg );
}
printf(
join( q{ }, ( map { "%-${_}s" } @line_length ) ),
@{$line}[ 0 .. 4 ]
);
if ( $line->[5] ) {
print $line->[5];
Birte Kristina Friesel
committed
}
return;
}
if ( my $err = $status->errstr ) {
say STDERR "Request error: ${err}";
if ( $status->errcode and $status->errcode eq 'H730' ) {
show_similar_stops();
}
exit 2;
}
for my $d ( $status->results() ) {
if ( $ignore_late and $d->delay ) {
Birte Kristina Friesel
committed
push(
@output,
[
$d->is_cancelled
? 'CANCELED'
: ( $d->delay ? sprintf( '%+d', $d->delay ) : q{} ),
( $d->platform // q{} ) . ( $d->is_changed_platform ? ' !' : q{} ),
Birte Kristina Friesel
committed
]
Birte Kristina Friesel
committed
display_result(@output);
hafas-m - Interface to the DeutscheBahn/HAFAS online departure monitor
B<hafas-m> [B<-a>] [B<-d> I<date>] [B<-L>] [B<-m> I<motlist>] [B<-t> I<time>]
I<station>
hafas-m is an interface to HAFAS-based departure monitors, for instance the
one available at L<http://reiseauskunft.bahn.de/bin/bhftafel.exe/dn>.
It requests all departures at I<station> (optionally filtered by date, time,
route and means of transport) and lists them on stdout, similar to the big
departure screens installed at most main stations.
=item B<-a>, B<--arrivals>
Show arrivals instead of departures, including trains ending at the specified
station. Note that this causes the output to display the start instead of
the end station and B<-f> to list all stops between start end
I<station>, not I<station> and end.
=item B<-d>, B<--date> I<dd>.I<mm>.I<yyyy>
Date to list departures for. Default: today.
=item B<-l>, B<--lang> B<d>|B<e>|B<i>|B<n>
Set language used for additional information. Supports B<d>eutsch (default),
B<e>nglish, B<i>talian and dutch (B<n>).
=item B<-L>, B<--ignore-late>
Do not display delayed trains.
By default, B<hafas-m> shows all modes of transport arriving/departing at the
specified station. With I<motlist>, it is possible to either exclude a list of
modes, or exclusively show only a select list of modes.
To exclude modes, set I<motlist> to B<!>I<mot1>,B<!>I<mot2>,...
To show them exclusively, set I<motlist> to I<mot1>,I<mot2>,...
The I<mot> types depend on the used service. Use C<< -m help >> to list them.
=item B<-t>, B<--time> I<hh>:I<mm>
Time to list departures for. Default: now.
=item B<-V>, B<--version>
=over
=item * Class::Accessor(3pm)
=item * LWP::UserAgent(3pm)
=item * XML::LibXML(3pm)
=back
Copyright (C) 2015 by Daniel Friesel E<lt>derf@finalrewind.orgE<gt>
This program is licensed under the same terms as Perl itself.