From: David ‘Bombe’ Roden Date: Sat, 19 Oct 2013 23:44:19 +0000 (+0200) Subject: Use a multimap to store the posts for a Sone. X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=commitdiff_plain;h=918190a7948e8c45398059dec7c446c8662450ae Use a multimap to store the posts for a Sone. --- 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 d7cef49..a19290e 100644 --- a/src/main/java/net/pterodactylus/sone/database/memory/MemoryDatabase.java +++ b/src/main/java/net/pterodactylus/sone/database/memory/MemoryDatabase.java @@ -55,8 +55,10 @@ import net.pterodactylus.util.config.ConfigurationException; import com.google.common.base.Function; 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.Multimap; import com.google.common.collect.SortedSetMultimap; import com.google.common.collect.TreeMultimap; import com.google.common.util.concurrent.AbstractService; @@ -82,7 +84,7 @@ public class MemoryDatabase extends AbstractService implements Database { private final Map allPosts = new HashMap(); /** All posts by their Sones. */ - private final Map> sonePosts = new HashMap>(); + private final Multimap sonePosts = HashMultimap.create(); /** All posts by their recipient. */ private final Map> recipientPosts = new HashMap>(); @@ -227,7 +229,12 @@ public class MemoryDatabase extends AbstractService implements Database { @Override public Collection getPosts(String soneId) { - return new HashSet(getPostsFrom(soneId)); + lock.readLock().lock(); + try { + return new HashSet(sonePosts.get(soneId)); + } finally { + lock.readLock().unlock(); + } } @Override @@ -251,7 +258,7 @@ public class MemoryDatabase extends AbstractService implements Database { lock.writeLock().lock(); try { allPosts.put(post.getId(), post); - getPostsFrom(post.getSone().getId()).add(post); + sonePosts.put(post.getSone().getId(), post); if (post.getRecipientId().isPresent()) { getPostsTo(post.getRecipientId().get()).add(post); } @@ -266,7 +273,7 @@ public class MemoryDatabase extends AbstractService implements Database { lock.writeLock().lock(); try { allPosts.remove(post.getId()); - getPostsFrom(post.getSone().getId()).remove(post); + sonePosts.remove(post.getSone().getId(), post); if (post.getRecipientId().isPresent()) { getPostsTo(post.getRecipientId().get()).remove(post); } @@ -289,7 +296,7 @@ public class MemoryDatabase extends AbstractService implements Database { lock.writeLock().lock(); try { /* remove all posts by the Sone. */ - getPostsFrom(sone.getId()).clear(); + sonePosts.removeAll(sone.getId()); for (Post post : posts) { allPosts.remove(post.getId()); if (post.getRecipientId().isPresent()) { @@ -298,7 +305,7 @@ public class MemoryDatabase extends AbstractService implements Database { } /* add new posts. */ - getPostsFrom(sone.getId()).addAll(posts); + sonePosts.putAll(sone.getId(), posts); for (Post post : posts) { allPosts.put(post.getId(), post); if (post.getRecipientId().isPresent()) { @@ -316,7 +323,7 @@ public class MemoryDatabase extends AbstractService implements Database { lock.writeLock().lock(); try { /* remove all posts by the Sone. */ - getPostsFrom(sone.getId()).clear(); + sonePosts.removeAll(sone.getId()); for (Post post : sone.getPosts()) { allPosts.remove(post.getId()); if (post.getRecipientId().isPresent()) { @@ -675,37 +682,6 @@ public class MemoryDatabase extends AbstractService implements Database { // /** - * Gets all posts for the given Sone, creating a new collection if there is - * none yet. - * - * @param soneId - * The ID of the Sone to get the posts for - * @return All posts - */ - private Collection getPostsFrom(String soneId) { - Collection posts = null; - lock.readLock().lock(); - try { - posts = sonePosts.get(soneId); - } finally { - lock.readLock().unlock(); - } - if (posts != null) { - return posts; - } - - posts = new HashSet(); - lock.writeLock().lock(); - try { - sonePosts.put(soneId, posts); - } finally { - lock.writeLock().unlock(); - } - - return posts; - } - - /** * Gets all posts that are directed the given Sone, creating a new collection * if there is none yet. *