X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=lib%2FCatalyst.pm;h=b7bb450d67408523b6e23799bfd2b3d63e7eb540;hp=c5294bddfd6593b3286a95c25fde00794a6ea74d;hb=00e6a2b71197b3b79b6d62a1c8154b7ca6702d2f;hpb=9ce5ab638a3850ea9b2449dc1ed20693f5478973 diff --git a/lib/Catalyst.pm b/lib/Catalyst.pm index c5294bd..b7bb450 100644 --- a/lib/Catalyst.pm +++ b/lib/Catalyst.pm @@ -45,6 +45,8 @@ __PACKAGE__->mk_classdata($_) our $VERSION = '5.49_01'; +sub version { return $Catalyst::VERSION } + sub import { my ( $class, @arguments ) = @_; @@ -389,27 +391,33 @@ sub setup { $class->log->_flush() if $class->log->can('_flush'); } -=item $c->uri_for($path) +=item $c->uri_for($path,[@args]) Merges path with $c->request->base for absolute uri's and with $c->request->match for relative uri's, then returns a normalized -L object. +L object. If any args are passed, they are added at the end +of the path. =cut sub uri_for { - my ( $c, $path ) = @_; + my ( $c, $path, @args ) = @_; my $base = $c->request->base->clone; my $basepath = $base->path; $basepath =~ s/\/$//; $basepath .= '/'; my $match = $c->request->match; + + # massage match, empty if absolute path $match =~ s/^\///; $match .= '/' if $match; $match = '' if $path =~ /^\//; $path =~ s/^\///; - return URI->new_abs( URI->new_abs( $path, "$basepath$match" ), $base ) - ->canonical; + + # join args with '/', or a blank string + my $args = ( scalar @args ? '/' . join( '/', @args ) : '' ); + return URI->new_abs( URI->new_abs( "$path$args", "$basepath$match" ), + $base )->canonical; } =item $c->error @@ -426,13 +434,20 @@ Add a new error. $c->error('Something bad happened'); +Clean errors. + + $c->error(0); + =cut sub error { my $c = shift; - my $error = ref $_[0] eq 'ARRAY' ? $_[0] : [@_]; - push @{ $c->{error} }, @$error; - return $c->{error}; + if ( $_[0] ) { + my $error = ref $_[0] eq 'ARRAY' ? $_[0] : [@_]; + push @{ $c->{error} }, @$error; + } + elsif ( defined $_[0] ) { $c->{error} = undef } + return $c->{error} || []; } =item $c->engine @@ -750,14 +765,15 @@ sub execute { } $c->{depth}++; eval { - if ( $c->debug ) { + if ( $c->debug ) + { my ( $elapsed, @state ) = $c->benchmark( $code, $class, $c, @{ $c->req->args } ); push @{ $c->{stats} }, [ $action, sprintf( '%fs', $elapsed ) ]; $c->state(@state); } else { - $c->state( &$code( $class, $c, @{ $c->req->args } ) || 0 ) + $c->state( &$code( $class, $c, @{ $c->req->args } ) || 0 ); } }; $c->{depth}--;