summaryrefslogtreecommitdiffstats
path: root/globals.pl
diff options
context:
space:
mode:
authorbugreport%peshkin.net <>2004-05-13 08:57:31 +0200
committerbugreport%peshkin.net <>2004-05-13 08:57:31 +0200
commitb1317e9fa0f343c92577ce729eb5abee0878b59a (patch)
tree40c2dfa6d4bd5613376bc73d087e257d4473de05 /globals.pl
parent4f7b9f55e5be5afab62cabf0788f3964c0c4ba42 (diff)
downloadbugzilla-b1317e9fa0f343c92577ce729eb5abee0878b59a.tar.gz
bugzilla-b1317e9fa0f343c92577ce729eb5abee0878b59a.tar.xz
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.pl26
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);
}