X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fxdcc%2Fdata%2FBot.java;h=3ca34f3cc350460ec982ab99bda878aae438f258;hb=d49f842f12ca9cd27b4d649c53b4edeeaf58133a;hp=96d91b654ef57b38a08d44cc4384f6f6da484856;hpb=db7e9612fa189cee9f4b9086e00d87c4d6c58bbf;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 96d91b6..3ca34f3 100644 --- a/src/main/java/net/pterodactylus/xdcc/data/Bot.java +++ b/src/main/java/net/pterodactylus/xdcc/data/Bot.java @@ -35,23 +35,18 @@ public class Bot implements Iterable { /** The network this bot is on. */ private final Network network; + private final String channel; /** 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; - /** - * Creates a new bot. - * - * @param network - * The network the bot is on - * @param name - * The name of the bot - */ - public Bot(Network network, String name) { + public Bot(Network network, String channel, String name) { this.network = checkNotNull(network, "network must not be null"); + this.channel = checkNotNull(channel, "channel must not be null"); this.name = checkNotNull(name, "name must not be null"); } @@ -68,6 +63,10 @@ public class Bot implements Iterable { return network; } + public String channel() { + return channel; + } + /** * Returns the current name of this bot. * @@ -113,7 +112,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); + } } //