use Moose::Autobox;
use namespace::autoclean;
+use Gitalist::Git::Types qw/SHA1/;
+
requires 'base';
with qw/
# FIXME - Should not be here!
$c->stash->{Commit} = $c->stash->{Repository}->get_object_or_head($sha1part)
or $c->detach('/error404', "Couldn't find a object for '$sha1part' in XXXX!");
+ $c->stash->{data} = $c->stash->{Commit};
}
sub diff : Chained('find') CaptureArgs(0) {}
-sub diff_fancy : Chained('diff') PathPart('') Args() {
- my($self, $c, $comparison, @rest) = @_;
+sub _set_diff_args {
+ my($self, $c, @rest) = @_;
+
# FIXME - This ain't pretty
- $c->stash->{parent} = $comparison
- if $comparison;
- $c->stash->{filename} = $rest[0]
+ $c->stash(parent => shift @rest)
+ if @rest == 2
+ # Check that the single arg is unlikely to be a path.
+ or @rest && to_SHA1($rest[0]) && $c->stash->{Repository}->get_object_or_head($rest[0]);
+ $c->stash(filename => $rest[-1])
if @rest;
}
-sub diff_plain : Chained('diff') PathPart('plain') Args(0) {
- my($self, $c) = @_;
- $c->stash->{no_wrapper} = 1;
+sub diff_fancy : Chained('diff') PathPart('') Args() {
+ my($self, $c, @rest) = @_;
+
+ $self->_set_diff_args($c, @rest);
+ }
+
+sub diff_plain : Chained('diff') PathPart('plain') Args() {
+ my($self, $c, $comparison, @rest) = @_;
+
+ $self->_set_diff_args($c, @rest);
+
+ $c->stash(no_wrapper => 1);
+ $c->response->content_type('text/plain; charset=utf-8');
}
sub commit : Chained('find') PathPart('commit') Args(0) {}
+sub file_commit_info : Chained('find') Does('FilenameArgs') Args() {}
+
sub tree : Chained('find') Does('FilenameArgs') Args() {}
sub find_blob : Action {