From: Marcus Ramberg Date: Tue, 25 Oct 2005 13:17:22 +0000 (+0000) Subject: add support for args to uri_for. X-Git-Tag: 5.7099_04~1109 X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=commitdiff_plain;h=189e2a51125327af68b68b3d3ab1c394d605c596;hp=ae9556190adec21134aa2ad4f52bc961bd3e28c8 add support for args to uri_for. --- diff --git a/lib/Catalyst.pm b/lib/Catalyst.pm index c5294bd..3df8da8 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,26 +391,30 @@ 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 ) + # 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; }