aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjoe <joe@FreeBSD.org>2001-10-24 06:04:42 +0800
committerjoe <joe@FreeBSD.org>2001-10-24 06:04:42 +0800
commita58c2bee44ca657c4ac7e0ed471bdeedad35fc6f (patch)
tree425c5fc2f123cc23cb878064307eeb2d504b3686
parentb3b15d6144b8d77a13ad8547fc42a37c920746a7 (diff)
downloadfreebsd-ports-gnome-a58c2bee44ca657c4ac7e0ed471bdeedad35fc6f.tar.gz
freebsd-ports-gnome-a58c2bee44ca657c4ac7e0ed471bdeedad35fc6f.tar.zst
freebsd-ports-gnome-a58c2bee44ca657c4ac7e0ed471bdeedad35fc6f.zip
Add an example of how to add links to cvsweb.cgi in the email at
commit time.
-rwxr-xr-xCVSROOT/cfg.pm80
1 files changed, 61 insertions, 19 deletions
diff --git a/CVSROOT/cfg.pm b/CVSROOT/cfg.pm
index 19de3de083c7..68b23ba426c3 100755
--- a/CVSROOT/cfg.pm
+++ b/CVSROOT/cfg.pm
@@ -121,26 +121,68 @@ $MAIL_BRANCH_HDR = "X-CVS-Branch";
# element per email line, with no trailing line feeds. This function
# shouldn't add them. If $DEBUG is switched on the log_accum.pl
# script will show the before and after on stdout at commit time.
+#
+# The example below shows a way of inserting links to cvsweb.
$MAIL_TRANSFORM = "";
-###$MAIL_TRANSFORM = sub {
-### my @input = @_;
-### my @output = ();
-###
-### while (1) {
-### my $line = shift @input;
-### last if $line =~ /^$/;
-###
-### push @output, $line;
-### }
-###
-### push @output, "";
-###
-### foreach my $line (@input) {
-### push @output, "Q: $line";
-### }
-###
-### return @output;
-###};
+#$MAIL_TRANSFORM = sub {
+# add_cvsweb_entry("http://www.example.org/cgi-bin/cvsweb.cgi", @_);
+#};
+
+
+
+# A function for post-processing a log message
+# and outputing it with URLs to a cvsweb.cgi in.
+sub add_cvsweb_entry {
+ my $url_to_cvsweb = shift;
+ my @input = @_;
+ my @output = ();
+
+ # Skip down to the revision summary.
+ while (1) {
+ my $line = shift @input;
+ last unless defined($line);
+ last if $line =~ /^\s*Revision\s*Changes\s*Path\s*$/;
+
+ push @output, $line;
+ }
+
+ # Add the url links
+ foreach (@input) {
+ # Skip any trailing blank lines.
+ unless ($_) {
+ push @output, $_;
+ next;
+ }
+
+ my ($rev, $add, $sub, $file, $status) = split;
+
+ $rev =~ /(?:(.*)\.)?([^\.]+)\.([^\.]+)$/;
+ my ($base, $r1, $r2) = ($1, $2, $3);
+ my $prevrev = "";
+ if ($r2 == 1) {
+ $prevrev = $base;
+ } else {
+ $prevrev = "$base." if $base;
+ $prevrev .= "$r1." . ($r2 - 1);
+ }
+
+ my $baseurl = "$url_to_cvsweb/$file";
+ my $extra;
+ if (defined($status)) {
+ $rev = $prevrev if $status =~ /dead/;
+ $extra = "?rev=$rev&content-type=text/plain";
+ } else {
+ $extra = ".diff?r1=$prevrev&r2=$rev";
+ }
+ push @output, $_;
+ push @output, "$baseurl$extra";
+ }
+
+ return @output;
+};
+
+
+