X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FGitalist.pm;h=64329fa747a0f3f3b5baf83db75aa799b5910bab;hb=a6db50831af08084d918bf42c5bfda096c0a373f;hp=e877fa71f6dc92a0180b44b70f029df2a5bd2f46;hpb=61b56ed67fa1788aed0d0acf11e251308b9943f4;p=catagits%2FGitalist.git diff --git a/lib/Gitalist.pm b/lib/Gitalist.pm index e877fa7..64329fa 100644 --- a/lib/Gitalist.pm +++ b/lib/Gitalist.pm @@ -11,8 +11,6 @@ use Catalyst qw/ Static::Simple StackTrace/; -use Class::C3::Adopt::NEXT -no_warn; - our $VERSION = '0.01'; # Bring in the libified gitweb.cgi. @@ -21,54 +19,113 @@ use gitweb; __PACKAGE__->config( name => 'Gitalist', default_view => 'Default', + default_model => 'GitRepos', + # Set to 1 to make your fcgi die the request after you push :) + exit_at_end_of_request_if_updated => 0, ); +{ + my $version; + my $get_version = sub { + my $gitdir = shift->path_to('.git'); + my $version = qx{cat "$gitdir/`cut -d' ' -f2 .git/HEAD`"}; + chomp $version; + return $version; + }; + + after setup_finalize => sub { + my $c = shift; + $version = $c->$get_version + if $c->config->{exit_at_end_of_request_if_updated}; + }; + after handle_request => sub { + my $c = shift; + if ($version) { + my $new = $c->$get_version; + exit 0 unless $new eq $version; + } + }; +} + + # Start the application __PACKAGE__->setup(); -sub uri_for { - my $p = ref $_[-1] eq 'HASH' - ? $_[-1] - : push(@_, {}) && $_[-1]; - $p->{p} = $_[0]->model('Git')->project; - - (my $uri = $_[0]->NEXT::uri_for(@_[1 .. $#_])) - # Ampersand! What is this, the 90s? - =~ s/&/;/g; - return $uri; -} +around uri_for => sub { + my ($orig, $c) = (shift, shift); + my $project_name = $c->stash->{'Project'} && $c->stash->{'Project'}->name; + my $hash = ref($_[-1]) eq 'HASH' ? pop @_ : {}; + my $params = Catalyst::Utils::merge_hashes( + { p => $hash->{p} || $project_name }, + $hash, + ); + delete $params->{p} unless defined $params->{p} && length $params->{p}; + (my $uri = $c->$orig(@_, $params)) + =~ tr[&][;]; + return $uri; +}; =head1 NAME -Gitalist - Catalyst based application +Gitalist - Transitional project to convert gitweb.cgi to a Catalyst app =head1 SYNOPSIS script/gitalist_server.pl + +=head1 INSTALL + +As Gitalist follows the usual Perl module format the usual approach +for installation should work e.g + + perl Makefile.PL + make + make test + make install + +If you're running a git checkout of Gitalist then you'll additionally +need the author modules. I. + =head1 DESCRIPTION -[enter your description here] +Gitalist is a web frontend for git repositories based on gitweb.cgi +and backed by Catalyst. It doesn't yet have the full functionality of +gitweb.cgi but it does have a few small additions at this stage. + +=head2 History + +This project started off as an attempt to port gitweb.cgi to a +Catalyst app in a piecemeal fashion. As it turns out, thanks largely +to Florian Ragwitz's earlier effort, it was easier to use gitweb.cgi +as a template for building a new Catalyst application. =head1 SEE ALSO -L, L +L + +L + +L =head1 AUTHORS AND COPYRIGHT Catalyst application: - (C) 2009 Venda Ltd and Dan Brook + (C) 2009 Venda Ltd and Dan Brook + (C) 2009, Tom Doran + (C) 2009, Zac Stevens Original gitweb.cgi from which this was derived: (C) 2005-2006, Kay Sievers (C) 2005, Christian Gierke -=head1 LICENSE + Model based on http://github.com/rafl/gitweb + (C) 2008, Florian Ragwitz -FIXME - Is this going to be GPLv2 as per gitweb? If so this is broken.. +=head1 LICENSE -This library is free software. You can redistribute it and/or modify -it under the same terms as Perl itself. +Licensed under GNU GPL v2 =cut