--- web/cgi-bin/cvslog.cgi 2001/05/25 16:40:08 1.4 +++ web/cgi-bin/cvslog.cgi 2004/03/21 23:59:32 1.30 @@ -1,50 +1,189 @@ -#!/usr/bin/perl +#!/usr/bin/perl -w -print "Content-type: text/html\n\n"; +# TODO: remove tables, and use CSS instead -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 *"; +use CGI; +$query=new CGI; +my($period)=$query->param('period'); +$period = "today" unless defined $period; +my($modulelist)=$query->param('module'); +my $moduleext=""; $moduleext=":$modulelist" if defined $modulelist; -my(@lines) = `$cmd 2>&1`; +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$moduleext commits in the past $days day(s)"; + $days--; + $firstdate = ">" . `/bin/date -v-${days}d +%Y/%m/%d`; +} +elsif($period eq "date") { + my($date)=$query->param('date'); + $date = `/bin/date +%Y/%m/%d` unless defined $date; + $heading = "i-scream CVS$moduleext commits on $date"; + $firstdate = "$date 00:00<$date 23:59" +} +elsif($period eq "since") { + my($date)=$query->param('date'); + $date = `/bin/date +%Y/%m/%d` unless defined $date; + $heading = "i-scream CVS$moduleext commits since $date"; + $firstdate = ">$date"; +} +elsif($period eq "thisweek") { + $firstdate = ">last Sunday"; + $heading = "i-scream CVS$moduleext commits this week"; +} +else { + # default to "today only" + $firstdate = ">" . `/bin/date +%Y/%m/%d`; + $heading = "Today's i-scream CVS$moduleext commits"; +} +my($cvsroot) = "/cvs/i-scream"; + +$modulelist = `ls $cvsroot` unless defined $modulelist; +$modulelist =~ s/[\r\n]/ /gm; + +my($cvs2clpath) = "/usr/local/bin/cvs2cl"; +my($cvs2clargs) = "--stdout --no-wrap --no-common-dir -r -t -w -S -U $cvsroot/CVSROOT/users -l \"-d'$firstdate'\" -g \"-d$cvsroot\" -g \"-Q\""; +my($updatecmd) = "/home/iscream/bin/fullcvsupdate.sh $modulelist"; +my($logcmd) = "cd /tmp/i-scream/cvstmp && $cvs2clpath $cvs2clargs"; + +my ($menu) = "../nwww/menu.inc" ; +my ($header) = "../nwww/header.inc"; +my ($footer) = "../nwww/footer.inc"; +my ($style) = "../nwww/style.inc"; + +print "Content-type: text/html\n\n"; + print <<"END"; - + - The i-scream Project Daily Commit Log - - - + i-scream CVS Commit Logs +END + +&print_html($style); + +print <<"END"; - + - +
-

Today's i-scream CVS commits

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

i-scream CVS Commit Logs

+ +

$heading

END -foreach my $line (@lines) { - print HTML_encode($line); +print `$updatecmd >/dev/null 2>&1`; + +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+([^\s]+)\s+<([^\s]+)>$/) { + print "\n\n"; + print HTML_encode($1); + print "\n"; + print " committed by "; + print HTML_encode("$2"); + print "\n\n" + } + elsif ($line =~ /^([0-9]{4}-[0-9]{2}-[0-9]{2}.*?)\s+([^\s]+)$/) { + print "\n\n"; + print HTML_encode($1); + print "\n"; + print " committed by "; + print HTML_encode("$2"); + print "\n\n" + } + elsif($line =~ /([^\s]+) (\([^,^\)]+(,[^\)]+)?\))([,:])/) { + my ($file, $rev, $tags, $ext) = ($1, $2, $3, $4); + print ""; + print ""; + print HTML_encode($file); + print " "; + if($rev =~ /\(([^\s]+)\.(\d+)(.*)\)/) { + my $start = $1; + my $end = $2; + my $other = $3; + my $newrev = "$start.$end"; + my $oldrev; + if($end != 1) { + my $oldminver = $end-1; + $oldrev = "$start.$oldminver"; + } + elsif($start =~ /^((\d+\.)+)(\d+)$/) { + $oldrev = $1; + # take trailing . off old revision + chop $oldrev; + } + if(defined $oldrev) { + my $diff = ".diff?r1=$oldrev&r2=$newrev"; + print "("; + print HTML_encode("$start.$end"); + print ""; + print HTML_encode("$other)"); + } + else { + print HTML_encode($rev); + } + } + else { + print HTML_encode($rev); + } + print HTML_encode($ext); + print "
\n" + } + else { + chomp $line; + print ""; + print HTML_encode($line); + print "
\n" + } + } + } + print "

\n\n"; } +print "

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