X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fxdcc%2Fdata%2FBot.java;h=0f096718cae033e74d432203f75373f11204812b;hb=ce7a48c4eda76cad0be79a58a31bff08b99a14d3;hp=211dde7e78130da750d645ba6cea55369474f0e5;hpb=a1ad62aece998bef7d62cab8fa31a839d1d16ef8;p=xudocci.git diff --git a/src/main/java/net/pterodactylus/xdcc/data/Bot.java b/src/main/java/net/pterodactylus/xdcc/data/Bot.java index 211dde7..0f09671 100644 --- a/src/main/java/net/pterodactylus/xdcc/data/Bot.java +++ b/src/main/java/net/pterodactylus/xdcc/data/Bot.java @@ -39,6 +39,7 @@ public class Bot implements Iterable { /** The packs this bot carries. */ private final Map packs = Maps.newHashMap(); + private final Map packsByName = Maps.newHashMap(); /** The current name of the bot. */ private String name; @@ -81,7 +82,9 @@ public class Bot implements Iterable { * @return The packs this bot carries */ public Collection packs() { - return packs.values(); + synchronized (packs) { + return packs.values(); + } } // @@ -111,7 +114,14 @@ public class Bot implements Iterable { * The pack to add */ public void addPack(Pack pack) { - packs.put(pack.id(), pack); + synchronized (this) { + if (packsByName.containsKey(pack.name())) { + Pack oldPack = packsByName.remove(pack.name()); + packs.remove(oldPack.id()); + } + packs.put(pack.id(), pack); + packsByName.put(pack.name(), pack); + } } // @@ -120,7 +130,7 @@ public class Bot implements Iterable { @Override public Iterator iterator() { - return packs.values().iterator(); + return packs().iterator(); } //