From: Chen Gang <gang.chen@asianux.com>
To: Joe Perches <joe@perches.com>
Cc: Chen Gang F T <chen.gang.flying.transformer@gmail.com>,
Andrew Morton <akpm@linux-foundation.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH -next] get_maintainer: Improve "Author:" rolestats
Date: Tue, 05 Nov 2013 10:37:13 +0800 [thread overview]
Message-ID: <527859D9.30109@asianux.com> (raw)
In-Reply-To: <52785676.8030801@asianux.com>
On 11/05/2013 10:22 AM, Chen Gang wrote:
> On 11/05/2013 05:54 AM, Joe Perches wrote:
>> Add this to "try this"...
>>
>> Chen Gang's defect is because his git repository branch
>> had a commit he authored but where did not add his signature.
>>
Hmm... in fact, when I make a patch, I really let "git log" contents a
commit I author but where do not add my signature.
But after I let it pure next-20131101 ("git reset HEAD^; git stash"), it
still cause this issue.
>
> Hmm... for pure next-20131101 tree in my git directory and the demo
> patches in attachment, it will cause this issue.
>
> And excuse me, I am not quite familiar with git, could you provide more
> details (e.g. where the special difference of the demo patches or the
> pure next-20131101 tree in my git directory)? thanks.
>
>> Also, there's a defect in function vcs_find_signers.
>> It should only return the commit count and array references.
>>
>> If there are no signers in the commit history interval specified,
>> then the "authors" array is added to the "signers" array and
>> returned as a single array.
>>
>> Use references instead.
>>
>> Make sure that references are defined in the places
>> that vcs_find_signers is called.
>>
>
> After apply the patch below, it can work well.
>
> Tested-by Chen Gang <gang.chen@asianux.com>
>
>
>
>> Signed-off-by: Joe Perches <joe@perches.com>
>> ---
>> scripts/get_maintainer.pl | 21 +++++++++++----------
>> 1 file changed, 11 insertions(+), 10 deletions(-)
>>
>> diff --git a/scripts/get_maintainer.pl b/scripts/get_maintainer.pl
>> index ee9adb8..9c3986f 100755
>> --- a/scripts/get_maintainer.pl
>> +++ b/scripts/get_maintainer.pl
>> @@ -128,7 +128,7 @@ my %VCS_cmds_git = (
>> "blame_commit_pattern" => "^([0-9a-f]+) ",
>> "author_pattern" => "^GitAuthor: (.*)",
>> "subject_pattern" => "^GitSubject: (.*)",
>> - "stat_pattern" => "(\\d+)\\t(\\d+)\\t\$file",
>> + "stat_pattern" => "^(\\d+)\\t(\\d+)\\t\$file\$",
>> );
>>
>> my %VCS_cmds_hg = (
>> @@ -156,7 +156,7 @@ my %VCS_cmds_hg = (
>> "blame_commit_pattern" => "^([ 0-9a-f]+):",
>> "author_pattern" => "^HgAuthor: (.*)",
>> "subject_pattern" => "^HgSubject: (.*)",
>> - "stat_pattern" => "(\\d+)\t(\\d+)\t\$file",
>> + "stat_pattern" => "^(\\d+)\t(\\d+)\t\$file\$",
>> );
>>
>> my $conf = which_conf(".get_maintainer.conf");
>> @@ -1297,7 +1297,7 @@ sub vcs_find_signers {
>>
>> # print("stats: <@stats>\n");
>>
>> - return (0, @signatures, @authors) if !@signatures;
>> + return (0, \@signatures, \@authors, \@stats) if !@signatures;
>>
>> save_commits_by_author(@lines) if ($interactive);
>> save_commits_by_signer(@lines) if ($interactive);
>> @@ -1880,9 +1880,10 @@ sub vcs_file_signoffs {
>> $cmd =~ s/(\$\w+)/$1/eeg; # interpolate $cmd
>>
>> ($commits, $signers_ref, $authors_ref, $stats_ref) = vcs_find_signers($cmd, $file);
>> - @signers = @{$signers_ref};
>> - @authors = @{$authors_ref};
>> - @stats = @{$stats_ref};
>> +
>> + @signers = @{$signers_ref} if defined $signers_ref;
>> + @authors = @{$authors_ref} if defined $authors_ref;
>> + @stats = @{$stats_ref} if defined $stats_ref;
>>
>> # print("commits: <$commits>\nsigners:<@signers>\nauthors: <@authors>\nstats: <@stats>\n");
>>
>> @@ -1965,8 +1966,8 @@ sub vcs_file_blame {
>> $cmd =~ s/(\$\w+)/$1/eeg; #substitute variables in $cmd
>>
>> ($commit_count, $commit_signers_ref, $commit_authors_ref, $stats_ref) = vcs_find_signers($cmd, $file);
>> - @commit_authors = @{$commit_authors_ref};
>> - @commit_signers = @{$commit_signers_ref};
>> + @commit_authors = @{$commit_authors_ref} if defined $commit_authors_ref;
>> + @commit_signers = @{$commit_signers_ref} if defined $commit_signers_ref;
>>
>> push(@signers, @commit_signers);
>> } else {
>> @@ -1983,8 +1984,8 @@ sub vcs_file_blame {
>> $cmd =~ s/(\$\w+)/$1/eeg; #substitute variables in $cmd
>>
>> ($commit_count, $commit_signers_ref, $commit_authors_ref, $stats_ref) = vcs_find_signers($cmd, $file);
>> - @commit_authors = @{$commit_authors_ref};
>> - @commit_signers = @{$commit_signers_ref};
>> + @commit_authors = @{$commit_authors_ref} if defined $commit_authors_ref;
>> + @commit_signers = @{$commit_signers_ref} if defined $commit_signers_ref;
>>
>> push(@signers, @commit_signers);
>> }
>>
>>
>>
>>
>
>
--
Chen Gang
next prev parent reply other threads:[~2013-11-05 2:38 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-11-01 11:20 [Suggestion] about latest commit for "scripts/get_maintainers.pl" Chen Gang
2013-11-01 18:32 ` Joe Perches
2013-11-02 14:07 ` Chen Gang F T
2013-11-04 21:54 ` [PATCH -next] get_maintainer: Improve "Author:" rolestats Joe Perches
2013-11-05 2:22 ` Chen Gang
2013-11-05 2:37 ` Chen Gang [this message]
2013-11-05 5:23 ` Joe Perches
2013-11-05 5:42 ` Chen Gang
2013-11-05 5:45 ` Chen Gang
2013-11-05 5:54 ` Joe Perches
2013-11-05 6:04 ` Chen Gang
2013-11-05 6:16 ` Joe Perches
2013-11-05 6:36 ` Chen Gang
2013-11-05 5:50 ` Joe Perches
2013-11-05 6:01 ` Chen Gang
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=527859D9.30109@asianux.com \
--to=gang.chen@asianux.com \
--cc=akpm@linux-foundation.org \
--cc=chen.gang.flying.transformer@gmail.com \
--cc=joe@perches.com \
--cc=linux-kernel@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.