X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fsone%2Fdata%2FSone.java;h=4f4fd98145de9123cf575c0ba376ce739b5fcc8e;hb=78da2db8d883349c8509a4f4794b844e2e6c6b31;hp=a3e872b76f92960282e8c70310a6a0c40c396f44;hpb=e3a3dccdfcb0f7390f8bf30ec1af0f9d9fb69496;p=Sone.git
diff --git a/src/main/java/net/pterodactylus/sone/data/Sone.java b/src/main/java/net/pterodactylus/sone/data/Sone.java
index a3e872b..4f4fd98 100644
--- a/src/main/java/net/pterodactylus/sone/data/Sone.java
+++ b/src/main/java/net/pterodactylus/sone/data/Sone.java
@@ -17,8 +17,7 @@
package net.pterodactylus.sone.data;
-import static com.google.common.base.Preconditions.checkArgument;
-import static com.google.common.base.Preconditions.checkNotNull;
+import static com.google.common.base.Preconditions.*;
import java.util.ArrayList;
import java.util.Collection;
@@ -37,16 +36,17 @@ import net.pterodactylus.sone.freenet.wot.OwnIdentity;
import net.pterodactylus.sone.template.SoneAccessor;
import net.pterodactylus.util.logging.Logging;
+import freenet.keys.FreenetURI;
+
import com.google.common.base.Predicate;
+import com.google.common.collect.FluentIterable;
import com.google.common.hash.Hasher;
import com.google.common.hash.Hashing;
-import freenet.keys.FreenetURI;
-
/**
* A Sone defines everything about a user: her profile, her status updates, her
* replies, her likes and dislikes, etc.
- *
+ *
* Operations that modify the Sone need to synchronize on the Sone in question.
*
* @author David âBombeâ Roden
@@ -111,9 +111,7 @@ public class Sone implements Fingerprintable, Comparable {
};
- /**
- * Comparator that sorts Sones by last activity (least recent active first).
- */
+ /** Comparator that sorts Sones by last activity (least recent active first). */
public static final Comparator LAST_ACTIVITY_COMPARATOR = new Comparator() {
@Override
@@ -236,10 +234,9 @@ public class Sone implements Fingerprintable, Comparable {
* Creates a new Sone.
*
* @param id
- * The ID of the Sone
+ * The ID of the Sone
* @param local
- * {@code true} if the Sone is a local Sone, {@code false}
- * otherwise
+ * {@code true} if the Sone is a local Sone, {@code false} otherwise
*/
public Sone(String id, boolean local) {
this.id = id;
@@ -273,10 +270,10 @@ public class Sone implements Fingerprintable, Comparable {
* identity has to match this Soneâs {@link #getId()}.
*
* @param identity
- * The identity of this Sone
+ * The identity of this Sone
* @return This Sone (for method chaining)
* @throws IllegalArgumentException
- * if the ID of the identity does not match this Soneâs ID
+ * if the ID of the identity does not match this Soneâs ID
*/
public Sone setIdentity(Identity identity) throws IllegalArgumentException {
if (!identity.getId().equals(id)) {
@@ -298,8 +295,7 @@ public class Sone implements Fingerprintable, Comparable {
/**
* Returns whether this Sone is a local Sone.
*
- * @return {@code true} if this Sone is a local Sone, {@code false}
- * otherwise
+ * @return {@code true} if this Sone is a local Sone, {@code false} otherwise
*/
public boolean isLocal() {
return local;
@@ -318,7 +314,7 @@ public class Sone implements Fingerprintable, Comparable {
* Sets the request URI of this Sone.
*
* @param requestUri
- * The request URI of this Sone
+ * The request URI of this Sone
* @return This Sone (for method chaining)
*/
public Sone setRequestUri(FreenetURI requestUri) {
@@ -346,7 +342,7 @@ public class Sone implements Fingerprintable, Comparable {
* Sets the insert URI of this Sone.
*
* @param insertUri
- * The insert URI of this Sone
+ * The insert URI of this Sone
* @return This Sone (for method chaining)
*/
public Sone setInsertUri(FreenetURI insertUri) {
@@ -372,11 +368,11 @@ public class Sone implements Fingerprintable, Comparable {
/**
* Sets the latest edition of this Sone. If the given latest edition is not
- * greater than the current latest edition, the latest edition of this Sone
- * is not changed.
+ * greater than the current latest edition, the latest edition of this Sone is
+ * not changed.
*
* @param latestEdition
- * The latest edition of this Sone
+ * The latest edition of this Sone
*/
public void setLatestEdition(long latestEdition) {
if (!(latestEdition > this.latestEdition)) {
@@ -399,7 +395,7 @@ public class Sone implements Fingerprintable, Comparable {
* Sets the time of the last inserted update of this Sone.
*
* @param time
- * The time of the update (in milliseconds since Jan 1, 1970 UTC)
+ * The time of the update (in milliseconds since Jan 1, 1970 UTC)
* @return This Sone (for method chaining)
*/
public Sone setTime(long time) {
@@ -420,10 +416,10 @@ public class Sone implements Fingerprintable, Comparable {
* Sets the new status of this Sone.
*
* @param status
- * The new status of this Sone
+ * The new status of this Sone
* @return This Sone
* @throws IllegalArgumentException
- * if {@code status} is {@code null}
+ * if {@code status} is {@code null}
*/
public Sone setStatus(SoneStatus status) {
this.status = checkNotNull(status, "status must not be null");
@@ -431,9 +427,9 @@ public class Sone implements Fingerprintable, Comparable {
}
/**
- * Returns a copy of the profile. If you want to update values in the
- * profile of this Sone, update the values in the returned {@link Profile}
- * and use {@link #setProfile(Profile)} to change the profile in this Sone.
+ * Returns a copy of the profile. If you want to update values in the profile
+ * of this Sone, update the values in the returned {@link Profile} and use
+ * {@link #setProfile(Profile)} to change the profile in this Sone.
*
* @return A copy of the profile
*/
@@ -442,12 +438,12 @@ public class Sone implements Fingerprintable, Comparable {
}
/**
- * Sets the profile of this Sone. A copy of the given profile is stored so
- * that subsequent modifications of the given profile are not reflected in
- * this Sone!
+ * Sets the profile of this Sone. A copy of the given profile is stored so that
+ * subsequent modifications of the given profile are not reflected in this
+ * Sone!
*
* @param profile
- * The profile to set
+ * The profile to set
*/
public void setProfile(Profile profile) {
this.profile = new Profile(profile);
@@ -466,7 +462,7 @@ public class Sone implements Fingerprintable, Comparable {
* Sets the client used by this Sone.
*
* @param client
- * The client used by this Sone, or {@code null}
+ * The client used by this Sone, or {@code null}
* @return This Sone (for method chaining)
*/
public Sone setClient(Client client) {
@@ -487,7 +483,7 @@ public class Sone implements Fingerprintable, Comparable {
* Sets whether this Sone is known.
*
* @param known
- * {@code true} if this Sone is known, {@code false} otherwise
+ * {@code true} if this Sone is known, {@code false} otherwise
* @return This Sone
*/
public Sone setKnown(boolean known) {
@@ -509,9 +505,9 @@ public class Sone implements Fingerprintable, Comparable {
* Returns whether this Sone has the given Sone as a friend Sone.
*
* @param friendSoneId
- * The ID of the Sone to check for
- * @return {@code true} if this Sone has the given Sone as a friend,
- * {@code false} otherwise
+ * The ID of the Sone to check for
+ * @return {@code true} if this Sone has the given Sone as a friend, {@code
+ * false} otherwise
*/
public boolean hasFriend(String friendSoneId) {
return friendSones.contains(friendSoneId);
@@ -521,7 +517,7 @@ public class Sone implements Fingerprintable, Comparable {
* Adds the given Sone as a friend Sone.
*
* @param friendSone
- * The friend Sone to add
+ * The friend Sone to add
* @return This Sone (for method chaining)
*/
public Sone addFriend(String friendSone) {
@@ -535,7 +531,7 @@ public class Sone implements Fingerprintable, Comparable {
* Removes the given Sone as a friend Sone.
*
* @param friendSoneId
- * The ID of the friend Sone to remove
+ * The ID of the friend Sone to remove
* @return This Sone (for method chaining)
*/
public Sone removeFriend(String friendSoneId) {
@@ -561,7 +557,7 @@ public class Sone implements Fingerprintable, Comparable {
* Sets all posts of this Sone at once.
*
* @param posts
- * The new (and only) posts of this Sone
+ * The new (and only) posts of this Sone
* @return This Sone (for method chaining)
*/
public Sone setPosts(Collection posts) {
@@ -573,11 +569,11 @@ public class Sone implements Fingerprintable, Comparable {
}
/**
- * Adds the given post to this Sone. The post will not be added if its
- * {@link Post#getSone() Sone} is not this Sone.
+ * Adds the given post to this Sone. The post will not be added if its {@link
+ * Post#getSone() Sone} is not this Sone.
*
* @param post
- * The post to add
+ * The post to add
*/
public void addPost(Post post) {
if (post.getSone().equals(this) && posts.add(post)) {
@@ -589,7 +585,7 @@ public class Sone implements Fingerprintable, Comparable {
* Removes the given post from this Sone.
*
* @param post
- * The post to remove
+ * The post to remove
*/
public void removePost(Post post) {
if (post.getSone().equals(this)) {
@@ -610,7 +606,7 @@ public class Sone implements Fingerprintable, Comparable {
* Sets all replies of this Sone at once.
*
* @param replies
- * The new (and only) replies of this Sone
+ * The new (and only) replies of this Sone
* @return This Sone (for method chaining)
*/
public Sone setReplies(Collection replies) {
@@ -624,7 +620,7 @@ public class Sone implements Fingerprintable, Comparable {
* nothing is added to this Sone.
*
* @param reply
- * The reply to add
+ * The reply to add
*/
public void addReply(PostReply reply) {
if (reply.getSone().equals(this)) {
@@ -636,7 +632,7 @@ public class Sone implements Fingerprintable, Comparable {
* Removes a reply from this Sone.
*
* @param reply
- * The reply to remove
+ * The reply to remove
*/
public void removeReply(PostReply reply) {
if (reply.getSone().equals(this)) {
@@ -657,7 +653,7 @@ public class Sone implements Fingerprintable, Comparable {
* Sets the IDs of all liked posts.
*
* @param likedPostIds
- * All liked postsâ IDs
+ * All liked postsâ IDs
* @return This Sone (for method chaining)
*/
public Sone setLikePostIds(Set likedPostIds) {
@@ -670,7 +666,7 @@ public class Sone implements Fingerprintable, Comparable {
* Checks whether the given post ID is liked by this Sone.
*
* @param postId
- * The ID of the post
+ * The ID of the post
* @return {@code true} if this Sone likes the given post, {@code false}
* otherwise
*/
@@ -682,7 +678,7 @@ public class Sone implements Fingerprintable, Comparable {
* Adds the given post ID to the list of posts this Sone likes.
*
* @param postId
- * The ID of the post
+ * The ID of the post
* @return This Sone (for method chaining)
*/
public Sone addLikedPostId(String postId) {
@@ -694,7 +690,7 @@ public class Sone implements Fingerprintable, Comparable {
* Removes the given post ID from the list of posts this Sone likes.
*
* @param postId
- * The ID of the post
+ * The ID of the post
* @return This Sone (for method chaining)
*/
public Sone removeLikedPostId(String postId) {
@@ -715,7 +711,7 @@ public class Sone implements Fingerprintable, Comparable {
* Sets the IDs of all liked replies.
*
* @param likedReplyIds
- * All liked repliesâ IDs
+ * All liked repliesâ IDs
* @return This Sone (for method chaining)
*/
public Sone setLikeReplyIds(Set likedReplyIds) {
@@ -728,7 +724,7 @@ public class Sone implements Fingerprintable, Comparable {
* Checks whether the given reply ID is liked by this Sone.
*
* @param replyId
- * The ID of the reply
+ * The ID of the reply
* @return {@code true} if this Sone likes the given reply, {@code false}
* otherwise
*/
@@ -740,7 +736,7 @@ public class Sone implements Fingerprintable, Comparable {
* Adds the given reply ID to the list of replies this Sone likes.
*
* @param replyId
- * The ID of the reply
+ * The ID of the reply
* @return This Sone (for method chaining)
*/
public Sone addLikedReplyId(String replyId) {
@@ -752,7 +748,7 @@ public class Sone implements Fingerprintable, Comparable {
* Removes the given post ID from the list of replies this Sone likes.
*
* @param replyId
- * The ID of the reply
+ * The ID of the reply
* @return This Sone (for method chaining)
*/
public Sone removeLikedReplyId(String replyId) {
@@ -770,35 +766,14 @@ public class Sone implements Fingerprintable, Comparable {
}
/**
- * Returns a flattened list of all albums of this Sone. The resulting list
- * contains parent albums before child albums so that the resulting list can
- * be parsed in a single pass.
- *
- * @return The flattened albums
- */
- public List getAllAlbums() {
- List flatAlbums = new ArrayList();
- flatAlbums.addAll(albums);
- int lastAlbumIndex = 0;
- while (lastAlbumIndex < flatAlbums.size()) {
- int previousAlbumCount = flatAlbums.size();
- for (Album album : new ArrayList(flatAlbums.subList(lastAlbumIndex, flatAlbums.size()))) {
- flatAlbums.addAll(album.getAlbums());
- }
- lastAlbumIndex = previousAlbumCount;
- }
- return flatAlbums;
- }
-
- /**
- * Returns all images of a Sone. Images of a album are inserted into this
- * list before images of all child albums.
+ * Returns all images of a Sone. Images of a album are inserted into this list
+ * before images of all child albums.
*
* @return The list of all images
*/
public List getAllImages() {
List allImages = new ArrayList();
- for (Album album : getAllAlbums()) {
+ for (Album album : FluentIterable.from(getAlbums()).transformAndConcat(Album.FLATTENER).toList()) {
allImages.addAll(album.getImages());
}
return allImages;
@@ -808,7 +783,7 @@ public class Sone implements Fingerprintable, Comparable {
* Adds an album to this Sone.
*
* @param album
- * The album to add
+ * The album to add
*/
public void addAlbum(Album album) {
checkNotNull(album, "album must not be null");
@@ -822,7 +797,7 @@ public class Sone implements Fingerprintable, Comparable {
* Sets the albums of this Sone.
*
* @param albums
- * The albums of this Sone
+ * The albums of this Sone
*/
public void setAlbums(Collection extends Album> albums) {
checkNotNull(albums, "albums must not be null");
@@ -836,7 +811,7 @@ public class Sone implements Fingerprintable, Comparable {
* Removes an album from this Sone.
*
* @param album
- * The album to remove
+ * The album to remove
*/
public void removeAlbum(Album album) {
checkNotNull(album, "album must not be null");
@@ -845,11 +820,11 @@ public class Sone implements Fingerprintable, Comparable {
}
/**
- * Moves the given album up in this albumâs albums. If the album is already
- * the first album, nothing happens.
+ * Moves the given album up in this albumâs albums. If the album is already the
+ * first album, nothing happens.
*
* @param album
- * The album to move up
+ * The album to move up
* @return The album that the given album swapped the place with, or
* null
if the album did not change its place
*/
@@ -867,11 +842,11 @@ public class Sone implements Fingerprintable, Comparable {
}
/**
- * Moves the given album down in this albumâs albums. If the album is
- * already the last album, nothing happens.
+ * Moves the given album down in this albumâs albums. If the album is already
+ * the last album, nothing happens.
*
* @param album
- * The album to move down
+ * The album to move down
* @return The album that the given album swapped the place with, or
* null
if the album did not change its place
*/
@@ -901,7 +876,7 @@ public class Sone implements Fingerprintable, Comparable {
* Sets the options of this Sone.
*
* @param options
- * The options of this Sone
+ * The options of this Sone
*/
/* TODO - remove this method again, maybe add an option provider */
public void setOptions(Options options) {
@@ -912,9 +887,7 @@ public class Sone implements Fingerprintable, Comparable {
// FINGERPRINTABLE METHODS
//
- /**
- * {@inheritDoc}
- */
+ /** {@inheritDoc} */
@Override
public synchronized String getFingerprint() {
Hasher hash = Hashing.sha256().newHasher();
@@ -963,9 +936,7 @@ public class Sone implements Fingerprintable, Comparable {
// INTERFACE Comparable
//
- /**
- * {@inheritDoc}
- */
+ /** {@inheritDoc} */
@Override
public int compareTo(Sone sone) {
return NICE_NAME_COMPARATOR.compare(this, sone);
@@ -975,17 +946,13 @@ public class Sone implements Fingerprintable, Comparable {
// OBJECT METHODS
//
- /**
- * {@inheritDoc}
- */
+ /** {@inheritDoc} */
@Override
public int hashCode() {
return id.hashCode();
}
- /**
- * {@inheritDoc}
- */
+ /** {@inheritDoc} */
@Override
public boolean equals(Object object) {
if (!(object instanceof Sone)) {
@@ -994,9 +961,7 @@ public class Sone implements Fingerprintable, Comparable {
return ((Sone) object).id.equals(id);
}
- /**
- * {@inheritDoc}
- */
+ /** {@inheritDoc} */
@Override
public String toString() {
return getClass().getName() + "[identity=" + identity + ",requestUri=" + requestUri + ",insertUri(" + String.valueOf(insertUri).length() + "),friends(" + friendSones.size() + "),posts(" + posts.size() + "),replies(" + replies.size() + ")]";