diff options
author | 2004-05-13 06:57:31 +0000 | |
---|---|---|
committer | 2004-05-13 06:57:31 +0000 | |
commit | b1317e9fa0f343c92577ce729eb5abee0878b59a (patch) | |
tree | 40c2dfa6d4bd5613376bc73d087e257d4473de05 /globals.pl | |
parent | Bug 226477: Fix undefined method call in Bugzilla::User->in_group (diff) | |
download | bugzilla-b1317e9fa0f343c92577ce729eb5abee0878b59a.tar.gz bugzilla-b1317e9fa0f343c92577ce729eb5abee0878b59a.tar.bz2 bugzilla-b1317e9fa0f343c92577ce729eb5abee0878b59a.zip |
Bug 226411: make DiffStrings handle fields with duplicate values
patch by jouni
r=joel,myk
a=justdave
Diffstat (limited to 'globals.pl')
-rw-r--r-- | globals.pl | 26 |
1 files changed, 13 insertions, 13 deletions
diff --git a/globals.pl b/globals.pl index 055584f7e..7439940c3 100644 --- a/globals.pl +++ b/globals.pl @@ -1404,20 +1404,20 @@ sub DiffStrings { my @old = split(" ", $oldstr); my @new = split(" ", $newstr); - my (@remove, @add) = (); - - # Find values that were removed - foreach my $value (@old) { - push (@remove, $value) if !grep($_ eq $value, @new); - } - - # Find values that were added - foreach my $value (@new) { - push (@add, $value) if !grep($_ eq $value, @old); + # For each pair of (old, new) entries: + # If they're equal, set them to empty. When done, @old contains entries + # that were removed; @new contains ones that got added. + + foreach my $oldv (@old) { + foreach my $newv (@new) { + next if ($newv eq ''); + if ($oldv eq $newv) { + $newv = $oldv = ''; + } + } } - - my $removed = join (", ", @remove); - my $added = join (", ", @add); + my $removed = join (", ", grep { $_ ne '' } @old); + my $added = join (", ", grep { $_ ne '' } @new); return ($removed, $added); } |