summaryrefslogtreecommitdiff
path: root/lib/Travel/Status/DE/URA/Stop.pm
blob: bfe3a9ab384b6e8f2d5256dc874fbde798e3136f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
package Travel::Status::DE::URA::Stop;

use strict;
use warnings;
use 5.010;

use parent 'Class::Accessor';

our $VERSION = '1.02';

Travel::Status::DE::URA::Stop->mk_ro_accessors(qw(datetime name));

sub new {
	my ( $obj, %conf ) = @_;

	my $ref = \%conf;

	return bless( $ref, $obj );
}

sub date {
	my ($self) = @_;

	return $self->{datetime}->strftime('%d.%m.%Y');
}

sub time {
	my ($self) = @_;

	return $self->{datetime}->strftime('%H:%M:%S');
}

sub TO_JSON {
	my ($self) = @_;

	return { %{$self} };
}

1;

__END__

=head1 NAME

Travel::Status::DE::URA::Stop - Information about a stop

=head1 SYNOPSIS

    for my $stop ($departure->route_post) {
        printf(
            "%s  %s\n",
            $stop->time, $stop->name
        );
    }

=head1 VERSION

version 1.02

=head1 DESCRIPTION

Travel::Status::DE::URA::Stop describes a single stop of a departure's route.

=head1 METHODS

=head2 ACCESSORS

=over

=item $stop->datetime

DateTime object holding the arrival/departure date and time.

=item $stop->date

Arrival/departure date in dd.mm.YYYY format.

=item $stop->time

Arrival/departure time in HH:MM:SS format.

=item $stop->name

Stop name.

=back

=head1 DIAGNOSTICS

None.

=head1 DEPENDENCIES

=over

=item Class::Accessor(3pm)

=back

=head1 BUGS AND LIMITATIONS

Unknown.

=head1 SEE ALSO

Travel::Status::DE::URA(3pm).

=head1 AUTHOR

Copyright (C) 2015-2016 by Daniel Friesel E<lt>derf@finalrewind.orgE<gt>

=head1 LICENSE

This module is licensed under the same terms as Perl itself.