diff options
-rw-r--r-- | README.patches | 7 | ||||
-rwxr-xr-x | v4l/scripts/hg-pull-req.pl | 125 |
2 files changed, 132 insertions, 0 deletions
diff --git a/README.patches b/README.patches index 9b81a75be..fda292912 100644 --- a/README.patches +++ b/README.patches @@ -86,6 +86,13 @@ sends a request the developers' mailing list and to the subsystem maintainer. The patches are analyzed and, if they look ok, merged into the master repository. +A script called hg-pull-req.pl is included that will generate this +request, providing a list of patches that will be pulled, links to each +patch, and a diffstat of the all patches. It will work best if Hg has +been configured with the correct username (also used by the commit +message generator) and push path. The script is designed to be easy to +modify to produce text for a given contributor's style. + It is good practice that each developer will have at least one tree called 'v4l-dvb', which keeps their patches, and periodically update this tree with the master tree's patches. diff --git a/v4l/scripts/hg-pull-req.pl b/v4l/scripts/hg-pull-req.pl new file mode 100755 index 000000000..66de967eb --- /dev/null +++ b/v4l/scripts/hg-pull-req.pl @@ -0,0 +1,125 @@ +#!/usr/bin/perl + +# Copyright (C) 2006 Trent Piepho <xyzzy@speakeasy.org> +# Automatic pull request generator + +# Generates a pull request for all changesets in current Hg repository, that +# do not appear in a remote repository. +# +# There are _three_ repositories involved in this operation. +# +# The first is the remote repository that you want your changes to be pulled +# into. The default is the master repository at +# http://linuxtv.org/hg/v4l-dvb, but you can specify something else if you +# want. This repository is called the "to repo". +# +# The next two repositories should be copies of each other. The first is your +# local repository. You must run this script from some directory in that +# repository. The second repository is a remote copy on some public server, +# e.g. linuxtv.org. This is called the "from repo". The default for the from +# repo is the "default-push" path from the Hg configuration, which is where hg +# will push to if you don't specify a path to "hg push". The script will do +# some checks to make sure these two repositories are copies of each other. +# +# The repository used to the changesets are comming from is local repository, +# due to Mercurial's limitations. However, links to your local repository +# would be useless in a pull request, because no one else can see your local +# repository. So, the links are change to use the "from repo" instead. This +# is why your local repo and the from repo must be copies of each other. +# Running "hg push" before generating the pull request should be enough. + +$maintainer = 'Mauro'; +$to_repo = 'http://linuxtv.org/hg/v4l-dvb'; +# Default for when a default-push path wasn't defined +$from_repo_base = 'http://linuxtv.org/hg/~username/'; + +# What to open for the pull request +$output_file = '>&STDOUT'; +# Example, to a local file: '>pull_req' +# Example, file on remote host: '|ssh remote.host.com cat \\> pull_req' + +# Text of the pull request. $nstr is e.g. "changeset" or "42 changesets" +$salutation = <<'EOF'; +$maintainer, + +Please pull from $from_repo + +for the following $nstr: + +EOF + +# The closing of the request, name and fname taken from hg username setting +$valediction = <<'EOF'; + +Thanks, +$fname +EOF + +if($#ARGV < 0) { + if(`hg showconfig paths` =~ m/^paths\.default-push=(.*)$/m) { + $from_repo = $1; + $from_repo =~ s/^ssh:/http:/; + } else { + `hg root` =~ m|/([^/]+)\n$|; + my $repo = $1; + $from_repo = $from_repo_base . $repo; + } +} + +$from_repo = $ARGV[0] if($#ARGV >= 0); +$to_repo = $ARGV[1] if($#ARGV >= 1); + +open OUT, $output_file or die "Opening: $!"; + +if (`hg outgoing $from_repo` !~ /^no changes found$/m || + `hg incoming $from_repo` !~ /^no changes found$/m) { + my $cur = `hg root`; chomp $cur; + print "$cur and $from_repo do not match!\n"; + print "Prehaps you forgot to push your changes?\n"; + exit; +} + +open IN, "hg outgoing -M $to_repo |"; +while(<IN>) { + if(/^changeset:\s+\d+:([[:xdigit:]]{12})$/) { + push @changesets, $1; + } elsif(/^summary:\s+(\S.*)$/) { + if ($1 =~ /^merge:/) { + # Skip merge changesets + pop @changesets; + } else { + push @summaries, $1; + } + } +} +close IN; +$#changesets == $#summaries or die "Confused by hg outgoing output"; + +foreach (0 .. $#summaries) { + if($summaries[$_] =~ /^merge:/) { + splice @summaries, $_, 1; + splice @changesets, $_, 1; + } +} + +$n = $#changesets + 1; +$n > 0 or die "Nothing to pull!"; +$nstr = ($n==1)?"changeset":"$n changesets"; + +print OUT eval qq("$salutation"); + +for (0 .. $#summaries) { + printf OUT "%02d/%02d: $summaries[$_]\n", $_+1, $n; + print OUT "$from_repo?cmd=changeset;node=$changesets[$_]\n"; + print OUT "\n"; +} + +print OUT "\n"; + +open IN, 'hg export ' . join(' ', @changesets) . '| diffstat |'; +print OUT while(<IN>); +close IN; + +`hg showconfig ui.username` =~ m/((\S+).*)\s+</; +my $name = $1; my $fname = $2; +print OUT eval qq("$valediction"); |