X-Git-Url: http://git.i-scream.org/?a=blobdiff_plain;f=cgi-bin%2Fcvslog.cgi;h=f967c4fc314b38448ec4a0caf3bc284682bdc728;hb=414e7c5504cad8b09d704fe5ac08e67b00f82f5d;hp=e822a31b944bfceb346f3d5170bc0b447cc9c71f;hpb=32c55a04768e468b83f9e6dfdd21d84a7d234b9f;p=www.i-scream.org.git diff --git a/cgi-bin/cvslog.cgi b/cgi-bin/cvslog.cgi index e822a31..f967c4f 100755 --- a/cgi-bin/cvslog.cgi +++ b/cgi-bin/cvslog.cgi @@ -1,14 +1,44 @@ -#!/usr/bin/perl +#!/usr/bin/perl -w + +use CGI; +$query=new CGI; +my($period)=$query->param('period'); +$period = "today" unless defined $period; + +my($firstdate); +if($period eq "days") { + my($days)=$query->param('days'); + $days = 1 unless defined $days; + if ($days < 1) {$days = 1}; + $heading = "i-scream CVS commits in the past $days day(s)"; + $days--; + $firstdate = `date --date \"$days days ago\" \"+%Y/%m/%d\"`; +} +elsif($period eq "thisweek") { + $firstdate = "last Sunday"; + $heading = "i-scream CVS commits this week"; +} +else { + # default to "today only" + $firstdate = `/bin/date \"+%Y/%m/%d\"`; + $heading = "Today's i-scream CVS commits"; +} -print "Content-type: text/html\n\n"; +my($cvsroot) = "/cvs/i-scream"; -my($today) = `date \"+%Y/%m/%d\"`; -my($cvs2clpath) = "/home/cut/tdb1/bin/cvs2cl"; -my($cvsroot) = "/usr/local/proj/co600_10/cvs"; -my($cvs2clargs) = "--stdout -r -b -t -w -U $cvsroot/CVSROOT/users -l \"-d'\>$today'\" -g \"-d$cvsroot\" -g \"-Q\""; -my($cmd) = "cd /home/cut/tdb1/cvsscripttemp && $cvs2clpath $cvs2clargs *"; +my($modulelist)=$query->param('module'); +$modulelist = `ls $cvsroot` unless defined $modulelist; -my(@lines) = `$cmd`; +my($cvs2clpath) = "/home/sites/www.i-scream.org.uk/bin/cvs2cl.pl"; +my($cvs2clargs) = "--stdout -r -b -t -w -U $cvsroot/CVSROOT/users -l \"-d'\>$firstdate'\" -g \"-d$cvsroot\" -g \"-Q\""; +my($updatecmd) = "/home/sites/www.i-scream.org.uk/bin/fullcvsupdate.sh $modulelist"; +my($logcmd) = "cd /home/sites/www.i-scream.org.uk/cvsscripttemp && $cvs2clpath $cvs2clargs"; + +my ($left) = "../left.inc" ; +my ($title) = "../title.inc"; +my ($bottom) = "../bottom.inc"; + +print "Content-type: text/html\n\n"; print <<"END"; @@ -16,32 +46,74 @@ print <<"END"; - The i-scream Project Logfile Tailer - - - + The i-scream Project Commit Log - + + + + + + + +
+END - +&print_html($left); -

Today's i-scream CVS commits

+print <<"END"; +
+END -Browse i-scream CVS repository +&print_html($title); -
+print <<"END";
+

$heading

END -foreach my $line (@lines) { - print HTML_encode($line); +print `$updatecmd`; + +my(@modules) = split (/\s+/, $modulelist); + +foreach my $module (@modules) { + + print "\n\n"; + print "\n\n"; + print "\n"; + + print "
\n$module module\n
\n"; + + my(@lines) = `$logcmd $module 2>&1`; + if(@lines == 0) { + print "There have been no commits in this module during this period.\n"; + } + else { + foreach my $line (@lines) { + + if ($line =~ /^([0-9]{4}-[0-9]{2}-[0-9]{2}.*?)([^\s]+)$/) { + print "\n"; + print HTML_encode($1); + print ""; + print HTML_encode("by $2"); + print "\n" + } + else { + chop $line; + print ""; + print HTML_encode($line); + print "
\n" + } + } + } + print "

\n\n"; } +&print_html($bottom); + print <<"END"; -

+ +
+ @@ -64,3 +136,8 @@ sub HTML_encode ($){ return $encoded; } +# Print a file without escaping HTML: - +sub print_html ($) { + my ($filename) = @_; + print `cat $filename 2>&1`; +}