X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fsone%2Fdatabase%2Fmemory%2FMemoryDatabase.java;h=bace9d9fbe592535f8d6aecc6ba991917fc75a4c;hp=8d60e0f4b548f4f0c579ad7aca52cda000d76911;hb=9d9b901b7173a9b8221a8b830ece31bc5ee36578;hpb=4d62892729cbce31c4fb2171ad2c2174db1d44b4 diff --git a/src/main/java/net/pterodactylus/sone/database/memory/MemoryDatabase.java b/src/main/java/net/pterodactylus/sone/database/memory/MemoryDatabase.java index 8d60e0f..bace9d9 100644 --- a/src/main/java/net/pterodactylus/sone/database/memory/MemoryDatabase.java +++ b/src/main/java/net/pterodactylus/sone/database/memory/MemoryDatabase.java @@ -57,7 +57,6 @@ import com.google.common.base.Optional; import com.google.common.collect.ArrayListMultimap; import com.google.common.collect.HashMultimap; import com.google.common.collect.ListMultimap; -import com.google.common.collect.Maps; import com.google.common.collect.SetMultimap; import com.google.common.collect.SortedSetMultimap; import com.google.common.collect.TreeMultimap; @@ -79,8 +78,8 @@ public class MemoryDatabase extends AbstractService implements Database { /** The configuration. */ private final Configuration configuration; - private final Map identities = Maps.newHashMap(); private final Map sones = new HashMap(); + private final MemoryIdentityDatabase memoryIdentityDatabase; private final MemoryPostDatabase memoryPostDatabase; /** All post replies by their ID. */ @@ -125,6 +124,7 @@ public class MemoryDatabase extends AbstractService implements Database { public MemoryDatabase(Configuration configuration) { this.configuration = configuration; memoryPostDatabase = new MemoryPostDatabase(this, lock, configuration); + memoryIdentityDatabase = new MemoryIdentityDatabase(lock); } // @@ -150,22 +150,12 @@ public class MemoryDatabase extends AbstractService implements Database { @Override public Optional getIdentity(String identityId) { - lock.readLock().lock(); - try { - return fromNullable(identities.get(identityId)); - } finally { - lock.readLock().unlock(); - } + return memoryIdentityDatabase.getIdentity(identityId); } @Override public void storeIdentity(Identity identitiy) { - lock.writeLock().lock(); - try { - identities.put(identitiy.getId(), identitiy); - } finally { - lock.writeLock().unlock(); - } + memoryIdentityDatabase.storeIdentity(identitiy); } @Override