Added recursive -r flag to prove example
[catagits/Catalyst-Runtime.git] / lib / Catalyst / Response.pm
index a433f02..e0d1a3b 100644 (file)
@@ -3,7 +3,7 @@ package Catalyst::Response;
 use strict;
 use base 'Class::Accessor::Fast';
 
-__PACKAGE__->mk_accessors(qw/cookies body headers redirect status/);
+__PACKAGE__->mk_accessors(qw/cookies body headers location status/);
 
 *output = \&body;
 
@@ -20,8 +20,6 @@ Catalyst::Response - Catalyst Response Class
 
     $resp = $c->response;
     $resp->body;
-    $resp->body_length;
-    $resp->body_ref;
     $resp->content_encoding;
     $resp->content_length;
     $resp->content_type;
@@ -49,34 +47,6 @@ to response data.
 
 Contains the final output.
 
-=item $resp->body_length
-
-Returns the length of body in bytes.
-
-    print $c->response->body_length
-
-=cut
-
-sub body_length {
-    my $self = shift;
-    
-    use bytes;
-    
-    return 0 unless $self->body;
-    return length($self->body);
-}
-
-=item $resp->body_ref
-
-Returns a reference to body.
-
-=cut
-
-sub body_ref {
-    my $self = shift;    
-    return \$self->{body};
-}
-
 =item $resp->content_encoding
 
 Shortcut to $resp->headers->content_encoding
@@ -109,11 +79,28 @@ Returns a L<HTTP::Headers> object containing the headers.
 
 Shortcut to $resp->body
 
-=item $resp->redirect($url)
+=item $resp->redirect( $url, $status )
 
 Contains a location to redirect to.
 
-    $c->response->redirect('http://slashdot.org');
+    $c->response->redirect( 'http://slashdot.org' );
+    $c->response->redirect( 'http://slashdot.org', 307 );
+
+=cut
+
+sub redirect {
+    my $self = shift;
+    
+    if ( @_ ) {
+        my $location = shift;
+        my $status   = shift || 302;
+
+        $self->location($location);
+        $self->status($status);
+    }
+
+    return $self->location;
+}
 
 =item status