From bbbf2a168ecf09392cb18143ff3a5d60522522e9 Mon Sep 17 00:00:00 2001 From: Damian Minkov Date: Mon, 16 Dec 2013 13:01:22 +0200 Subject: Adds checks to avoid problem contacts where to providers of same type have group with same name. --- .../java/sip/communicator/impl/protocol/icq/ContactGroupIcqImpl.java | 3 +++ .../java/sip/communicator/impl/protocol/msn/ContactGroupMsnImpl.java | 3 +++ .../java/sip/communicator/impl/protocol/sip/ContactGroupSipImpl.java | 3 +++ .../sip/communicator/impl/protocol/yahoo/ContactGroupYahooImpl.java | 3 +++ 4 files changed, 12 insertions(+) (limited to 'src/net/java/sip/communicator/impl') diff --git a/src/net/java/sip/communicator/impl/protocol/icq/ContactGroupIcqImpl.java b/src/net/java/sip/communicator/impl/protocol/icq/ContactGroupIcqImpl.java index 5e5049e..2bb8f13 100644 --- a/src/net/java/sip/communicator/impl/protocol/icq/ContactGroupIcqImpl.java +++ b/src/net/java/sip/communicator/impl/protocol/icq/ContactGroupIcqImpl.java @@ -303,6 +303,9 @@ public class ContactGroupIcqImpl if(!((ContactGroup)obj).getGroupName().equals(getGroupName())) return false; + if(getProtocolProvider() != ((ContactGroup)obj).getProtocolProvider()) + return false; + //since ICQ does not support having two groups with the same name // at this point we could bravely state that the groups are the same // and not bother to compare buddies. (gotta check that though) diff --git a/src/net/java/sip/communicator/impl/protocol/msn/ContactGroupMsnImpl.java b/src/net/java/sip/communicator/impl/protocol/msn/ContactGroupMsnImpl.java index 7b1c831..64085a6 100644 --- a/src/net/java/sip/communicator/impl/protocol/msn/ContactGroupMsnImpl.java +++ b/src/net/java/sip/communicator/impl/protocol/msn/ContactGroupMsnImpl.java @@ -267,6 +267,9 @@ public class ContactGroupMsnImpl if(!((ContactGroup)obj).getGroupName().equals(getGroupName())) return false; + if(getProtocolProvider() != ((ContactGroup)obj).getProtocolProvider()) + return false; + //since Msn does not support having two groups with the same name // at this point we could bravely state that the groups are the same // and not bother to compare buddies. (gotta check that though) diff --git a/src/net/java/sip/communicator/impl/protocol/sip/ContactGroupSipImpl.java b/src/net/java/sip/communicator/impl/protocol/sip/ContactGroupSipImpl.java index ae1d184..f40f6b3 100644 --- a/src/net/java/sip/communicator/impl/protocol/sip/ContactGroupSipImpl.java +++ b/src/net/java/sip/communicator/impl/protocol/sip/ContactGroupSipImpl.java @@ -592,6 +592,9 @@ public class ContactGroupSipImpl || sipGroup.countSubgroups() != countSubgroups()) return false; + if(getProtocolProvider() != ((ContactGroup)obj).getProtocolProvider()) + return false; + //traverse child contacts Iterator theirContacts = sipGroup.contacts(); diff --git a/src/net/java/sip/communicator/impl/protocol/yahoo/ContactGroupYahooImpl.java b/src/net/java/sip/communicator/impl/protocol/yahoo/ContactGroupYahooImpl.java index 1682bd5..762694a 100644 --- a/src/net/java/sip/communicator/impl/protocol/yahoo/ContactGroupYahooImpl.java +++ b/src/net/java/sip/communicator/impl/protocol/yahoo/ContactGroupYahooImpl.java @@ -268,6 +268,9 @@ public class ContactGroupYahooImpl if(!((ContactGroup)obj).getGroupName().equals(getGroupName())) return false; + if(getProtocolProvider() != ((ContactGroup)obj).getProtocolProvider()) + return false; + //since Yahoo does not support having two groups with the same name // at this point we could bravely state that the groups are the same // and not bother to compare buddies. (gotta check that though) -- cgit v1.1