--- web/cgi-bin/cvslog.cgi 2001/05/25 16:40:08 1.4 +++ web/cgi-bin/cvslog.cgi 2001/06/05 16:19:00 1.5 @@ -1,16 +1,39 @@ -#!/usr/bin/perl +#!/usr/bin/perl -w -print "Content-type: text/html\n\n"; +use CGI; +$query=new CGI; +my($period)=$query->param('period'); +$period = "today" unless defined $period; -my($today) = `date \"+%Y/%m/%d\"`; -my($cvs) = "/home/cut/tdb1/bin/cvs"; -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 && $cvs -d $cvsroot -Q update -d && $cvs2clpath $cvs2clargs *"; +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"; +} -my(@lines) = `$cmd 2>&1`; +print "Content-type: text/html\n\n"; +my($cvs) = "/usr/bin/cvs"; +my($cvs2clpath) = "/home/sites/www.i-scream.org.uk/bin/cvs2cl.pl"; +my($cvsroot) = "/cvs/i-scream"; +#my($cvs2clargs) = "--stdout -r -b -t -w -U $cvsroot/CVSROOT/users -l \"-d'\>$today'\" -g \"-d$cvsroot\" -g \"-Q\""; +my($cvs2clargs) = "--stdout -r -b -t -w -U $cvsroot/CVSROOT/users -l \"-d'\>$firstdate'\" -g \"-d$cvsroot\" -g \"-Q\""; +my($updatecmd) = "cd /home/sites/www.i-scream.org.uk/cvsscripttemp && $cvs -d $cvsroot -Q update -d"; +my($logcmd) = "cd /home/sites/www.i-scream.org.uk/cvsscripttemp && $cvs2clpath $cvs2clargs"; + print <<"END"; @@ -18,31 +41,42 @@ print <<"END"; The i-scream Project Daily Commit Log - - - - + -

Today's i-scream CVS commits

+

$heading

-Browse i-scream CVS repository - -
 END
 
-foreach my $line (@lines) {
-    print HTML_encode($line);
+print `$updatecmd`;
+
+my $modulelist = `ls $cvsroot`;
+my(@modules) = split (/\s+/, $modulelist);
+
+foreach my $module (@modules) {
+
+    print "

$module module

\n"; + print ""; + print "Browse i-scream "$module" cvs module\n"; + print "
\n";
+
+    my(@lines) = `$logcmd $module 2>&1`;
+    if(@lines == 0) {
+        print "There have been no commits in this module during this period.";
+    }
+    else {
+        foreach my $line (@lines) {
+            print HTML_encode($line);
+        }
+    }
+
+    print "

\n\n"; } print <<"END"; -
@@ -64,4 +98,3 @@ sub HTML_encode ($){ $encoded =~ s/>/>/g; return $encoded; } -