Skip to content
Snippets Groups Projects
Commit 3557cfb0 authored by Birte Kristina Friesel's avatar Birte Kristina Friesel
Browse files

Improve(?) error handling

parent 5dc6d078
No related branches found
No related tags found
No related merge requests found
...@@ -97,8 +97,8 @@ $efa = WWW::Efa->new( ...@@ -97,8 +97,8 @@ $efa = WWW::Efa->new(
max_interchanges => $opt->{'max-change'}, max_interchanges => $opt->{'max-change'},
); );
if (my $err = $efa->setup_error()) { if ($efa->error()) {
die $err->as_string(); die $efa->error()->as_string();
} }
if ($opt->{'test-parse'}) { if ($opt->{'test-parse'}) {
...@@ -111,11 +111,7 @@ else { ...@@ -111,11 +111,7 @@ else {
); );
} }
my $err = $efa->parse(); $efa->parse or die $efa->error()->as_string();
if ($err and $err->isa('WWW::Efa::Error')) {
die $err->as_string();
}
my @connections = $efa->connections(); my @connections = $efa->connections();
......
...@@ -477,6 +477,9 @@ If true: Prefer connections allowing to take a bike along ...@@ -477,6 +477,9 @@ If true: Prefer connections allowing to take a bike along
=back =back
When encountering invalid hash keys, a WWW::Efa::Error object is stored to be
retrieved by $efa->error();
=cut =cut
sub new { sub new {
...@@ -495,15 +498,15 @@ sub new { ...@@ -495,15 +498,15 @@ sub new {
return bless($ref, $obj); return bless($ref, $obj);
} }
=head2 $efa->setup_error() =head2 $efa->error()
In case WWW::Efa->new() encountered an error (usually invalid options), this In case a WWW::Efa operation encountered an error, this returns a
returns a B<WWW::Efa::Error::Setup> object describing the exact error. B<WWW::Efa::Error> object related to the exact error. Otherwise, returns
Otherwise, returns nothing. undef.
=cut =cut
sub setup_error { sub error {
my ($self) = @_; my ($self) = @_;
if ($self->{'error'}) { if ($self->{'error'}) {
...@@ -543,7 +546,8 @@ sub submit { ...@@ -543,7 +546,8 @@ sub submit {
=head2 $efa->parse() =head2 $efa->parse()
Parse the B<efa.vrr.de> reply. Parse the B<efa.vrr.de> reply.
Returns undef on success and a WWW::Efa::Error object upon failure. returns a true value on success. Upon failure, returns undef and sets
$efa->error() to a WWW::Efa::Error object.
=cut =cut
...@@ -568,17 +572,16 @@ sub parse { ...@@ -568,17 +572,16 @@ sub parse {
if ($err = $self->check_ambiguous()) { if ($err = $self->check_ambiguous()) {
$self->{'error'} = $err; $self->{'error'} = $err;
return $err;
} }
elsif ($err = $self->check_no_connections()) { elsif ($err = $self->check_no_connections()) {
$self->{'error'} = $err; $self->{'error'} = $err;
return $err;
} }
elsif ($self->{'error'}) {
return $self->{'error'}; if ($self->{'error'}) {
return;
} }
return $self->{'error'}; return 1;
} }
sub check_ambiguous { sub check_ambiguous {
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment