diff options
author | Daniel Friesel <derf@finalrewind.org> | 2015-06-23 22:12:48 +0200 |
---|---|---|
committer | Daniel Friesel <derf@finalrewind.org> | 2015-06-23 22:12:48 +0200 |
commit | 1e048ee2f717e92b7ed89b1f0acd63b4953be83f (patch) | |
tree | 2629429827bd575b2e6a40647bdfc918cf68b734 | |
parent | 5106c6d18051685627e6775f48e61946ab192896 (diff) |
add new ::Stop class for stop data
-rw-r--r-- | Changelog | 2 | ||||
-rwxr-xr-x | bin/efa-m | 16 | ||||
-rw-r--r-- | lib/Travel/Status/DE/EFA.pm | 9 | ||||
-rw-r--r-- | lib/Travel/Status/DE/EFA/Stop.pm | 122 |
4 files changed, 136 insertions, 13 deletions
@@ -6,8 +6,8 @@ git HEAD * EFA->new: Add full_routes config option * EFA: Add identified_data accessor * Result: Add route_pre, route_post and route_interesting accessors - * efa-m: Add -f / --full-route option * efa-m: Add -v / --via option + * Add Travel::Routing::DE::EFA::Stop module Travel::Status::DE::VRR 1.09 - Thu Apr 30 2015 @@ -106,23 +106,23 @@ sub format_route { say "BUG"; next; } - if ( not defined $stop->{arr_time} ) { + if ( not defined $stop->arr_time ) { $output .= sprintf( " %5s %40s %s\n", - $stop->{dep_time}, $stop->{stop}, $stop->{platform}, ); + $stop->dep_time, $stop->name, $stop->platform, ); } - elsif ( not defined $stop->{dep_time} ) { + elsif ( not defined $stop->dep_time ) { $output .= sprintf( "%5s %40s %s\n", - $stop->{arr_time}, $stop->{stop}, $stop->{platform}, ); + $stop->arr_time, $stop->name, $stop->platform, ); } - elsif ( $stop->{arr_time} eq $stop->{dep_time} ) { + elsif ( $stop->arr_time eq $stop->dep_time ) { $output .= sprintf( " %5s %40s %s\n", - $stop->{dep_time}, $stop->{stop}, $stop->{platform}, ); + $stop->dep_time, $stop->name, $stop->platform, ); } else { $output .= sprintf( "%5s → %5s %40s %s\n", - $stop->{arr_time}, $stop->{dep_time}, - $stop->{stop}, $stop->{platform}, + $stop->arr_time, $stop->dep_time, + $stop->name, $stop->platform, ); } } diff --git a/lib/Travel/Status/DE/EFA.pm b/lib/Travel/Status/DE/EFA.pm index 3ac28ce..ecf2b79 100644 --- a/lib/Travel/Status/DE/EFA.pm +++ b/lib/Travel/Status/DE/EFA.pm @@ -12,6 +12,7 @@ use Carp qw(confess cluck); use Encode qw(encode decode); use Travel::Status::DE::EFA::Line; use Travel::Status::DE::EFA::Result; +use Travel::Status::DE::EFA::Stop; use LWP::UserAgent; use XML::LibXML; @@ -334,15 +335,15 @@ sub parse_route { # cases. push( @ret, - { + Travel::Status::DE::EFA::Stop->new( arr_date => sprintf_date( $dates[0] ), arr_time => sprintf_time( $times[0] ), dep_date => sprintf_date( $dates[-1] ), dep_time => sprintf_time( $times[-1] ), - stop => decode( 'UTF-8', $e->getAttribute('name') ), - stop_suf => decode( 'UTF-8', $e->getAttribute('nameWO') ), + name => decode( 'UTF-8', $e->getAttribute('name') ), + name_suf => decode( 'UTF-8', $e->getAttribute('nameWO') ), platform => $e->getAttribute('platformName'), - } + ) ); } diff --git a/lib/Travel/Status/DE/EFA/Stop.pm b/lib/Travel/Status/DE/EFA/Stop.pm new file mode 100644 index 0000000..a4b3b61 --- /dev/null +++ b/lib/Travel/Status/DE/EFA/Stop.pm @@ -0,0 +1,122 @@ +package Travel::Status::DE::EFA::Stop; + +use strict; +use warnings; +use 5.010; + +no if $] >= 5.018, warnings => 'experimental::smartmatch'; + +use parent 'Class::Accessor'; + +our $VERSION = '1.09'; + +Travel::Status::DE::EFA::Stop->mk_ro_accessors( + qw(arr_date arr_time dep_date dep_time name name_suf platform)); + +sub new { + my ( $obj, %conf ) = @_; + + my $ref = \%conf; + + return bless( $ref, $obj ); +} + +sub TO_JSON { + my ($self) = @_; + + return { %{$self} }; +} + +1; + +__END__ + +=head1 NAME + +Travel::Status::DE::EFA::Stop - Information about a stop (station) contained +in a Travel::Status::DE::EFA::Result's route + +=head1 SYNOPSIS + + for my $stop ($departure->route_post) { + printf( + "%s -> %s : %40s %s\n", + $stop->arr_time // q{ }, $stop->dep_time // q{ }, + $stop->name, $stop->platform + ); + } + +=head1 VERSION + +version 1.09 + +=head1 DESCRIPTION + +Travel::Status::DE::EFA::stop describes a TODO. + +=head1 METHODS + +=head2 ACCESSORS + +TODO + +=over + +=item $stop->arr_date + +=item $stop->arr_time + +=item $stop->dep_date + +=item $stop->dep_time + +=item $stop->name + +=item $stop->name_suf + +=item $stop->platform + +=back + +=head2 INTERNAL + +=over + +=item $stop = Travel::Status::DE::EFA::Stop->new(I<%data>) + +Returns a new Travel::Status::DE::EFA::Stop object. You should not need to +call this. + +=item $stop->TO_JSON + +Allows the object data to be serialized to JSON. + +=back + +=head1 DIAGNOSTICS + +None. + +=head1 DEPENDENCIES + +=over + +=item Class::Accessor(3pm) + +=back + +=head1 BUGS AND LIMITATIONS + +None known. + +=head1 SEE ALSO + +Travel::Status::DE::EFA(3pm). + +=head1 AUTHOR + +Copyright (C) 2015 by Daniel Friesel E<lt>derf@finalrewind.orgE<gt> + +=head1 LICENSE + +This module is licensed under the same terms as Perl itself. |