X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;f=lib%2FApache%2FMVC%2FView%2FTT.pm;fp=lib%2FApache%2FMVC%2FView%2FTT.pm;h=0000000000000000000000000000000000000000;hb=b078065f0c417a20dd7115bff96e1a5903634172;hp=babd0f457a9260735ccd438eb88c5b2ce2c00837;hpb=40aac6aaddbad039ee003a46421b22e35b03bbeb;p=maypole.git diff --git a/lib/Apache/MVC/View/TT.pm b/lib/Apache/MVC/View/TT.pm deleted file mode 100644 index babd0f4..0000000 --- a/lib/Apache/MVC/View/TT.pm +++ /dev/null @@ -1,82 +0,0 @@ -package Apache::MVC::View::TT; -use Apache::Constants; -use Lingua::EN::Inflect; -use Template; -use File::Spec; -use UNIVERSAL::moniker; -use strict; - - -sub new { bless {}, shift } # Not worth having - -sub _tt { - my ($self, $r) = @_; - my $root = $r->{ar}->document_root . "/". $r->{ar}->location; - warn "Root was $root"; - Template->new({ INCLUDE_PATH => [ - $root, - ($r->model_class && File::Spec->catdir($root, $r->model_class->moniker)), - File::Spec->catdir($root, "custom"), - File::Spec->catdir($root, "factory") - ]}); -} - -sub _args { - my ($self, $r) = @_; - my $class = $r->model_class; - my %args = ( - request => $r, - objects => $r->objects, - base => $r->config->{uri_base}, - config => $r->config - # ... - ) ; - if ($class) { - $args{classmetadata} = { - name => $class, - columns => [ $class->columns ], - colnames => { $class->column_names }, - related_accessors => [ $class->related($r) ], - moniker => $class->moniker, - plural => $class->plural_moniker, - cgi => { $class->to_cgi }, - description => $class->description - }; - - # User-friendliness facility for custom template writers. - if (@{$r->objects || []} > 1) { - $args{$r->model_class->plural_moniker} = $r->objects; - } else { - ($args{$r->model_class->moniker}) = @{$r->objects}; - } - } - - # Overrides - %args = (%args, %{$r->{template_args}||{}}); - %args; -} - -sub process { - my ($self, $r) = @_; - my $template = $self->_tt($r); - my $output; - $template->process($r->template, { $self->_args($r) }, \$output) - || return $self->error($r, $template->error); - - $r->{ar}->content_type("text/html"); - $r->{ar}->headers_out->set("Content-Length" => length $output); - $r->{ar}->send_http_header; - $r->{ar}->print($output); - return 200; -} - -sub error { - my ($self, $r, $error) = @_; - warn $error; - if ($error =~ /not found$/) { return DECLINED } - $r->{ar}->send_http_header("text/plain"); - $r->{ar}->print($error); - exit; -} - -1;