diff options
author | tudalova <tudalova@138bc75d-0d04-0410-961f-82ee72b054a4> | 2014-01-21 10:07:22 +0000 |
---|---|---|
committer | tudalova <tudalova@138bc75d-0d04-0410-961f-82ee72b054a4> | 2014-01-21 10:07:22 +0000 |
commit | 463d1e8d5a181acc852fb942ff578a7e5bfd5b09 (patch) | |
tree | 5551103da3593309499ffe570d2af7a2a4b07832 /contrib/mklog | |
parent | 4b16f8e375ec96f97aa50b735a338a915c25d3a8 (diff) | |
download | gcc-463d1e8d5a181acc852fb942ff578a7e5bfd5b09.tar.gz |
* mklog: Avoid adding falsely changed functions to ChangeLog.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@206875 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'contrib/mklog')
-rwxr-xr-x | contrib/mklog | 46 |
1 files changed, 42 insertions, 4 deletions
diff --git a/contrib/mklog b/contrib/mklog index fb0514f2ddd..16ce1914db6 100755 --- a/contrib/mklog +++ b/contrib/mklog @@ -80,6 +80,20 @@ sub remove_suffixes ($) { return $filename; } +# Check if line can be a function declaration: +# First pattern cut extra symbols added by diff +# second pattern checks that line is not a comment or brace +sub is_function { + my ($function, $is_context_diff) = (@_); + if ($is_context_diff) { + $function =~ s/^..//; + } else { + $function =~ s/^.//; + } + return $function + && ($function !~ /^[\s{}]/); +} + # For every file in the .diff print all the function names in ChangeLog # format. %cl_entries = (); @@ -87,7 +101,10 @@ $change_msg = undef; $look_for_funs = 0; $clname = get_clname(''); open (DFILE, $diff) or die "Could not open file $diff for reading"; -while (<DFILE>) { +chomp (my @diff_lines = <DFILE>); +close (DFILE); +$line_idx = 0; +foreach (@diff_lines) { # Stop processing functions if we found a new file # Remember both left and right names because one may be /dev/null. if (/^[+*][+*][+*] +(\S+)/) { @@ -150,6 +167,17 @@ while (<DFILE>) { $look_for_funs = 0; } + # Mark if we met doubtfully changed function. + $doubtfunc = 0; + $is_context_diff = 0; + if ($diff_lines[$line_idx] =~ /^@@ .* @@ ([a-zA-Z0-9_].*)/) { + $doubtfunc = 1; + } + elsif ($diff_lines[$line_idx] =~ /^\*\*\*\*\*\** ([a-zA-Z0-9_].*)/) { + $doubtfunc = 1; + $is_context_diff = 1; + } + # If we find a new function, print it in brackets. Special case if # this is the first function in a file. # @@ -187,7 +215,18 @@ while (<DFILE>) { 1 while ($fn =~ s/<[^<>]*>//); $fn =~ s/[ \t]*$//; } - if ($fn && $seen_names{$fn} == 0) { + # Check is function really modified + $no_real_change = 0; + if ($doubtfunc) { + $idx = $line_idx; + # Check all lines till the first change + # for the presence of really changed function + do { + ++$idx; + $no_real_change = is_function ($diff_lines[$idx], $is_context_diff); + } while (!$no_real_change && ($diff_lines[$idx] !~ /^[\+\-\!]/)) + } + if ($fn && !$seen_names{$fn} && !$no_real_change) { # If this is the first function in the file, we display it next # to the filename, so we need an extra space before the opening # brace. @@ -201,10 +240,9 @@ while (<DFILE>) { $seen_names{$fn} = 1; } } + $line_idx++; } -close (DFILE); - # If we have not seen any function names (ie, $change_msg is empty), we just # write out a ':'. This happens when there is only one file with no # functions. |