Andrew's git
/
gitweb.git
/ diff
summary
|
log
|
commit
| diff |
tree
commit
grep
author
committer
pickaxe
?
re
contrib: contacts: add ability to parse from committish
author
Eric Sunshine
<sunshine@sunshineco.com>
Sun, 21 Jul 2013 10:52:39 +0000
(06:52 -0400)
committer
Junio C Hamano
<gitster@pobox.com>
Sun, 21 Jul 2013 22:13:16 +0000
(15:13 -0700)
For example:
% git contacts R1..R2
Committishes and patch files can be mentioned in the same invocation:
% git contacts R1..R2 extra/*.patch
Signed-off-by: Eric Sunshine <sunshine@sunshineco.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
contrib/contacts/git-contacts
patch
|
blob
|
history
raw
|
patch
|
inline
| side by side (parent:
4d06402
)
diff --git
a/contrib/contacts/git-contacts
b/contrib/contacts/git-contacts
index 3e6cce810679cbc0d4d1316babd5da42d7197f5d..1686ff340ad0dbc7eff53411107858a08f4024b9 100755
(executable)
--- a/
contrib/contacts/git-contacts
+++ b/
contrib/contacts/git-contacts
@@
-3,7
+3,7
@@
# List people who might be interested in a patch. Useful as the argument to
# git-send-email --cc-cmd option, and in other situations.
#
# List people who might be interested in a patch. Useful as the argument to
# git-send-email --cc-cmd option, and in other situations.
#
-# Usage: git contacts <file> ...
+# Usage: git contacts <file
| rev-list option
> ...
use strict;
use warnings;
use strict;
use warnings;
@@
-77,8
+77,8
@@
sub get_blame {
}
sub scan_patches {
}
sub scan_patches {
- my ($commits, $f) = @_;
- my
($id, $source)
;
+ my ($commits, $
id, $
f) = @_;
+ my
$source
;
while (<$f>) {
if (/^From ([0-9a-f]{40}) Mon Sep 17 00:00:00 2001$/) {
$id = $1;
while (<$f>) {
if (/^From ([0-9a-f]{40}) Mon Sep 17 00:00:00 2001$/) {
$id = $1;
@@
-98,18
+98,44
@@
sub scan_patches {
sub scan_patch_file {
my ($commits, $file) = @_;
open my $f, '<', $file or die "read failure: $file: $!\n";
sub scan_patch_file {
my ($commits, $file) = @_;
open my $f, '<', $file or die "read failure: $file: $!\n";
- scan_patches($commits, $f);
+ scan_patches($commits, undef, $f);
+ close $f;
+}
+
+sub scan_rev_args {
+ my ($commits, $args) = @_;
+ open my $f, '-|', qw(git rev-list --reverse), @$args or die;
+ while (<$f>) {
+ chomp;
+ my $id = $_;
+ $seen{$id} = 1;
+ open my $g, '-|', qw(git show -C --oneline), $id or die;
+ scan_patches($commits, $id, $g);
+ close $g;
+ }
close $f;
}
if (!@ARGV) {
close $f;
}
if (!@ARGV) {
- die "No input patch files\n";
+ die "No input
revisions or
patch files\n";
}
}
-my
%commits
;
+my
(@files, @rev_args)
;
for (@ARGV) {
for (@ARGV) {
+ if (-e) {
+ push @files, $_;
+ } else {
+ push @rev_args, $_;
+ }
+}
+
+my %commits;
+for (@files) {
scan_patch_file(\%commits, $_);
}
scan_patch_file(\%commits, $_);
}
+if (@rev_args) {
+ scan_rev_args(\%commits, \@rev_args)
+}
import_commits(\%commits);
my $contacts = {};
import_commits(\%commits);
my $contacts = {};