X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fsone%2Ftemplate%2FReplyGroupFilter.java;h=c093e6fe01969fc665954909d38e9997470433f7;hb=981d31bd43cae0ebd74a2e4bb053a4b77c0be094;hp=25672845a3e30b2c88e7516992a9e97750437aeb;hpb=90d19c992a93d1a54ecf46704acf16361c888465;p=Sone.git
diff --git a/src/main/java/net/pterodactylus/sone/template/ReplyGroupFilter.java b/src/main/java/net/pterodactylus/sone/template/ReplyGroupFilter.java
index 2567284..c093e6f 100644
--- a/src/main/java/net/pterodactylus/sone/template/ReplyGroupFilter.java
+++ b/src/main/java/net/pterodactylus/sone/template/ReplyGroupFilter.java
@@ -1,5 +1,5 @@
/*
- * Sone - ReplyGroupFilter.java - Copyright © 2010 David Roden
+ * Sone - ReplyGroupFilter.java - Copyright © 2010â2019 David Roden
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
@@ -21,10 +21,11 @@ import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
+import java.util.Map.Entry;
import java.util.Set;
import net.pterodactylus.sone.data.Post;
-import net.pterodactylus.sone.data.Reply;
+import net.pterodactylus.sone.data.PostReply;
import net.pterodactylus.sone.data.Sone;
import net.pterodactylus.util.template.Filter;
import net.pterodactylus.util.template.TemplateContext;
@@ -33,8 +34,6 @@ import net.pterodactylus.util.template.TemplateContext;
* {@link Filter} implementation that groups replies by the post the are in
* reply to, returning a map with the post as key and the list of replies as
* values.
- *
- * @author David âBombeâ Roden
*/
public class ReplyGroupFilter implements Filter {
@@ -42,35 +41,36 @@ public class ReplyGroupFilter implements Filter {
* {@inheritDoc}
*/
@Override
- public Object format(TemplateContext templateContext, Object data, Map parameters) {
+ public Object format(TemplateContext templateContext, Object data, Map parameters) {
@SuppressWarnings("unchecked")
- List allReplies = (List) data;
- Map> postSones = new HashMap>();
- Map> postReplies = new HashMap>();
- for (Reply reply : allReplies) {
- Post post = reply.getPost();
+ List allReplies = (List) data;
+ Map> postSones = new HashMap<>();
+ Map> postReplies = new HashMap<>();
+ for (PostReply reply : allReplies) {
+ /*
+ * All replies from a new-reply notification have posts,
+ * ListNotificationFilters takes care of that.
+ */
+ Post post = reply.getPost().get();
Set sones = postSones.get(post);
if (sones == null) {
- sones = new HashSet();
+ sones = new HashSet<>();
postSones.put(post, sones);
}
sones.add(reply.getSone());
- Set replies = postReplies.get(post);
+ Set replies = postReplies.get(post);
if (replies == null) {
- replies = new HashSet();
+ replies = new HashSet<>();
postReplies.put(post, replies);
}
replies.add(reply);
}
- Map>> result = new HashMap>>();
- for (Post post : postSones.keySet()) {
- if (result.containsKey(post)) {
- continue;
- }
- Map> postResult = new HashMap>();
- postResult.put("sones", postSones.get(post));
- postResult.put("replies", postReplies.get(post));
- result.put(post, postResult);
+ Map>> result = new HashMap<>();
+ for (Entry> postEntry : postSones.entrySet()) {
+ Map> postResult = new HashMap<>();
+ postResult.put("sones", postEntry.getValue());
+ postResult.put("replies", postReplies.get(postEntry.getKey()));
+ result.put(postEntry.getKey(), postResult);
}
return result;
}