X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;ds=inline;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fsone%2Fdata%2FPost.java;h=20bf5182ada06fcc02d1c097738539abf9bba903;hb=532076508aac8e03e0ef9914e90c7a0558b66bbe;hp=6523e9b8cfcf848b062aa32d9b7ff185bdd47246;hpb=6f019de1d4d9742981d851ac3c9097cca8bff58e;p=Sone.git
diff --git a/src/main/java/net/pterodactylus/sone/data/Post.java b/src/main/java/net/pterodactylus/sone/data/Post.java
index 6523e9b..20bf518 100644
--- a/src/main/java/net/pterodactylus/sone/data/Post.java
+++ b/src/main/java/net/pterodactylus/sone/data/Post.java
@@ -17,8 +17,11 @@
package net.pterodactylus.sone.data;
+import java.util.Collections;
import java.util.Comparator;
+import java.util.List;
+import com.google.common.base.Function;
import com.google.common.base.Optional;
import com.google.common.base.Predicate;
@@ -28,7 +31,7 @@ import com.google.common.base.Predicate;
*
* @author David âBombeâ Roden
*/
-public interface Post {
+public interface Post extends Identified {
/** Comparator for posts, sorts descending by time. */
public static final Comparator TIME_COMPARATOR = new Comparator() {
@@ -45,11 +48,18 @@ public interface Post {
@Override
public boolean apply(Post post) {
- return post.getTime() <= System.currentTimeMillis();
+ return (post == null) ? false : post.getTime() <= System.currentTimeMillis();
}
};
+ public static final Function> TO_REPLIES = new Function>() {
+ @Override
+ public List apply(Post post) {
+ return (post == null) ? Collections.emptyList() : post.getReplies();
+ }
+ };
+
//
// ACCESSORS
//
@@ -77,10 +87,7 @@ public interface Post {
public Optional getRecipientId();
/**
- * Returns the recipient of this post, if any. As this method can return
- * {@link Optional#absent()} if the post has a recipient which has not yet
- * been loaded, it is recommended to use {@link #hasRecipient()} to check
- * for the presence of a recipient.
+ * Returns the recipient of this post, if any.
*
* @return The recipient of this post, or {@link Optional#absent()} if there
* is no recipient
@@ -117,4 +124,6 @@ public interface Post {
*/
public Post setKnown(boolean known);
+ List getReplies();
+
}