14 |
|
if ($days < 1) {$days = 1}; |
15 |
|
$heading = "i-scream CVS$moduleext commits in the past $days day(s)"; |
16 |
|
$days--; |
17 |
< |
$firstdate = ">" . `date --date \"$days days ago\" \"+%Y/%m/%d\"`; |
17 |
> |
$firstdate = ">" . `/bin/date -v-${days}d +%Y/%m/%d`; |
18 |
|
} |
19 |
|
elsif($period eq "date") { |
20 |
|
my($date)=$query->param('date'); |
21 |
< |
$date = `/bin/date \"+%Y/%m/%d\"` unless defined $date; |
21 |
> |
$date = `/bin/date +%Y/%m/%d` unless defined $date; |
22 |
|
$heading = "i-scream CVS$moduleext commits on $date"; |
23 |
|
$firstdate = "$date 00:00<$date 23:59" |
24 |
|
} |
25 |
+ |
elsif($period eq "since") { |
26 |
+ |
my($date)=$query->param('date'); |
27 |
+ |
$date = `/bin/date +%Y/%m/%d` unless defined $date; |
28 |
+ |
$heading = "i-scream CVS$moduleext commits since $date"; |
29 |
+ |
$firstdate = ">$date"; |
30 |
+ |
} |
31 |
|
elsif($period eq "thisweek") { |
32 |
|
$firstdate = ">last Sunday"; |
33 |
|
$heading = "i-scream CVS$moduleext commits this week"; |
34 |
|
} |
35 |
|
else { |
36 |
|
# default to "today only" |
37 |
< |
$firstdate = ">" . `/bin/date \"+%Y/%m/%d\"`; |
37 |
> |
$firstdate = ">" . `/bin/date +%Y/%m/%d`; |
38 |
|
$heading = "Today's i-scream CVS$moduleext commits"; |
39 |
|
} |
40 |
|
|
41 |
|
my($cvsroot) = "/cvs/i-scream"; |
42 |
|
|
43 |
|
$modulelist = `ls $cvsroot` unless defined $modulelist; |
44 |
+ |
$modulelist =~ s/[\r\n]/ /gm; |
45 |
|
|
46 |
< |
my($cvs2clpath) = "/home/sites/www.i-scream.org.uk/bin/cvs2cl2.pl"; |
47 |
< |
my($cvs2clargs) = "--stdout --no-wrap -r -b -t -w -S -U $cvsroot/CVSROOT/users -l \"-d'$firstdate'\" -g \"-d$cvsroot\" -g \"-Q\""; |
48 |
< |
my($updatecmd) = "/home/sites/www.i-scream.org.uk/bin/fullcvsupdate.sh $modulelist"; |
49 |
< |
my($logcmd) = "cd /home/sites/www.i-scream.org.uk/cvsscripttemp && $cvs2clpath $cvs2clargs"; |
46 |
> |
my($cvs2clpath) = "/usr/local/bin/cvs2cl"; |
47 |
> |
my($cvs2clargs) = "--stdout --no-wrap --no-common-dir -r -t -w -S -U $cvsroot/CVSROOT/users -l \"-d'$firstdate'\" -g \"-d$cvsroot\" -g \"-Q\""; |
48 |
> |
my($updatecmd) = "/home/iscream/bin/fullcvsupdate.sh $modulelist"; |
49 |
> |
my($logcmd) = "cd /tmp/i-scream/cvstmp && $cvs2clpath $cvs2clargs"; |
50 |
|
|
51 |
< |
my ($left) = "../left.inc" ; |
52 |
< |
my ($title) = "../title.inc"; |
53 |
< |
my ($bottom) = "../bottom.inc"; |
51 |
> |
my ($left) = "../htdocs/left.inc" ; |
52 |
> |
my ($title) = "../htdocs/title.inc"; |
53 |
> |
my ($bottom) = "../htdocs/bottom.inc"; |
54 |
|
|
55 |
|
print "Content-type: text/html\n\n"; |
56 |
|
|
83 |
|
<h2>$heading</h2> |
84 |
|
END |
85 |
|
|
86 |
< |
print `$updatecmd`; |
86 |
> |
print `$updatecmd >/dev/null 2>&1`; |
87 |
|
|
88 |
|
my(@modules) = split (/\s+/, $modulelist); |
89 |
|
|
90 |
|
foreach my $module (@modules) { |
91 |
|
|
92 |
|
print "<table border=\"0\" bgcolor=\"#000066\" cellpadding=\"5\" width=\"100%\">\n\n"; |
93 |
< |
print "<tr><td>\n<font size=\"4\"><b><a href=\"/cgi-bin/cvs/viewcvs.cgi/$module\" style=\"color: white\">$module module</a></b></font>\n</td></tr>\n\n"; |
93 |
> |
print "<tr><td>\n<font size=\"4\"><b><a href=\"http://cvs.i-scream.org/$module\" style=\"color: white\">$module module</a></b></font>\n</td></tr>\n\n"; |
94 |
|
print "<tr><td bgcolor=\"white\">\n"; |
95 |
|
|
96 |
|
my(@lines) = `$logcmd $module 2>&1`; |
104 |
|
print "\n<font color=\"blue\">\n<b>"; |
105 |
|
print HTML_encode($1); |
106 |
|
print "</b>\n<i>"; |
107 |
< |
print " commited by <a href=\"mailto:$3\" style=\"text-decoration: none;\">"; |
107 |
> |
print " committed by <a href=\"mailto:$3\" style=\"text-decoration: none;\">"; |
108 |
|
print HTML_encode("$2"); |
109 |
|
print "</a></i>\n</font>\n" |
110 |
|
} |
111 |
< |
elsif($line =~ /(\S+) (\(\S+\))([,:])/) { |
112 |
< |
#chop $line; |
111 |
> |
elsif ($line =~ /^([0-9]{4}-[0-9]{2}-[0-9]{2}.*?)\s+([^\s]+)$/) { |
112 |
> |
print "\n<font color=\"blue\">\n<b>"; |
113 |
> |
print HTML_encode($1); |
114 |
> |
print "</b>\n<i>"; |
115 |
> |
print " committed by "; |
116 |
> |
print HTML_encode("$2"); |
117 |
> |
print "</i>\n</font>\n" |
118 |
> |
} |
119 |
> |
elsif($line =~ /(\S+) (\(\S+\))([,:])/ || $line =~ /(\S+) (\(\S+,\s+\S+\))([,:])/) { |
120 |
|
my ($file, $rest, $ext) = ($1, $2, $3); |
121 |
|
print "<code>"; |
122 |
< |
print "<a href=\"/cgi-bin/cvs/viewcvs.cgi/$file\" style=\"text-decoration: none;\">"; |
122 |
> |
print "<a href=\"http://cvs.i-scream.org/$file\" style=\"text-decoration: none;\">"; |
123 |
|
print HTML_encode($file); |
124 |
|
print "</a> "; |
125 |
< |
if($rest =~ /\((\S).(\S+)\)/) { |
126 |
< |
my $newrev = "$1.$2"; |
127 |
< |
my $oldminver = $2-1; |
128 |
< |
my $oldrev = "$1.$oldminver"; |
129 |
< |
if(!($1==1 && $2==1)) { |
125 |
> |
if($rest =~ /\((\S+)\.(\d+)(.*)\)/) { |
126 |
> |
my $start = $1; |
127 |
> |
my $end = $2; |
128 |
> |
my $other = $3; |
129 |
> |
my $newrev = "$start.$end"; |
130 |
> |
my $oldrev; |
131 |
> |
if($end != 1) { |
132 |
> |
my $oldminver = $end-1; |
133 |
> |
$oldrev = "$start.$oldminver"; |
134 |
> |
} |
135 |
> |
elsif($start =~ /^((\d+\.)+)(\d+)$/) { |
136 |
> |
$oldrev = $1; |
137 |
> |
# take trailing . off old revision |
138 |
> |
chop $oldrev; |
139 |
> |
} |
140 |
> |
if(defined $oldrev) { |
141 |
|
my $diff = ".diff?r1=$oldrev&r2=$newrev"; |
142 |
< |
print "<a href=\"/cgi-bin/cvs/viewcvs.cgi/$file$diff\" style=\"text-decoration: none;\">"; |
143 |
< |
print HTML_encode($rest); |
142 |
> |
print "(<a href=\"http://cvs.i-scream.org/$file$diff\" style=\"text-decoration: none;\">"; |
143 |
> |
print HTML_encode("$start.$end"); |
144 |
|
print "</a>"; |
145 |
+ |
print HTML_encode("$other)"); |
146 |
|
} |
147 |
|
else { |
148 |
|
print HTML_encode($rest); |