| Jifty documentation | Contained in the Jifty distribution. |
Jifty::View - Base class for view modules
This is the base class for Jifty::View::Declare and Jifty::View::Mason::Handler, which are the two view plugins shipped with Jifty. Other view plugins can be built by extending this class.
Doesn't send headers if this is a subrequest (according to the current Jifty::Request).
The default output method. Sets the content-type to text/html;
charset=utf-8 unless a content type has already been set, and then
sends a header if need be.
Jifty is Copyright 2005-2010 Best Practical Solutions, LLC. Jifty is distributed under the same terms as Perl itself.
| Jifty documentation | Contained in the Jifty distribution. |
package Jifty::View; use strict; use warnings; use base qw/Jifty::Object/; use Encode ();
sub auto_send_headers { return not Jifty->web->request->is_subrequest; }
sub out_method { my $r = Jifty->web->response; # Send a header $r->content_type || $r->content_type('text/html; charset=utf-8'); # Set up a default # We now install a new, faster out_method that doesn't have to # keep checking whether headers have been sent. my $content = sub { Jifty->web->response->{body} .= $_ for map { Encode::is_utf8($_) ? Encode::encode('utf8', $_) : $_ } @_; }; Jifty->handler->buffer->out_method( $content ); $content->(@_); }
1;