🎨 Replace in-memory post with Kotlin version
authorDavid ‘Bombe’ Roden <bombe@pterodactylus.net>
Thu, 6 Aug 2020 18:28:46 +0000 (20:28 +0200)
committerDavid ‘Bombe’ Roden <bombe@pterodactylus.net>
Thu, 6 Aug 2020 18:28:46 +0000 (20:28 +0200)
src/main/java/net/pterodactylus/sone/database/memory/MemoryPost.java [deleted file]
src/main/kotlin/net/pterodactylus/sone/database/memory/MemoryDatabase.kt
src/main/kotlin/net/pterodactylus/sone/database/memory/MemoryPost.kt [new file with mode: 0644]

diff --git a/src/main/java/net/pterodactylus/sone/database/memory/MemoryPost.java b/src/main/java/net/pterodactylus/sone/database/memory/MemoryPost.java
deleted file mode 100644 (file)
index 451b6b5..0000000
+++ /dev/null
@@ -1,191 +0,0 @@
-/*
- * Sone - MemoryPost.java - Copyright Â© 2010–2020 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
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program.  If not, see <http://www.gnu.org/licenses/>.
- */
-
-package net.pterodactylus.sone.database.memory;
-
-import static com.google.common.base.Optional.fromNullable;
-
-import java.util.UUID;
-
-import net.pterodactylus.sone.data.Post;
-import net.pterodactylus.sone.data.Sone;
-import net.pterodactylus.sone.database.SoneProvider;
-
-import com.google.common.base.Optional;
-
-/**
- * A post is a short message that a user writes in his Sone to let other users
- * know what is going on.
- */
-class MemoryPost implements Post {
-
-       /** The post database. */
-       private final MemoryDatabase postDatabase;
-
-       /** The Sone provider. */
-       private final SoneProvider soneProvider;
-
-       /** The GUID of the post. */
-       private final UUID id;
-
-       /** The ID of the owning Sone. */
-       private final String soneId;
-
-       /** The ID of the recipient Sone. */
-       private final String recipientId;
-
-       /** The time of the post (in milliseconds since Jan 1, 1970 UTC). */
-       private final long time;
-
-       /** The text of the post. */
-       private final String text;
-
-       /**
-        * Creates a new post.
-        *
-        * @param postDatabase
-        *            The post database
-        * @param soneProvider
-        *            The Sone provider
-        * @param id
-        *            The ID of the post
-        * @param soneId
-        *            The ID of the Sone this post belongs to
-        * @param recipientId
-        *            The ID of the recipient of the post
-        * @param time
-        *            The time of the post (in milliseconds since Jan 1, 1970 UTC)
-        * @param text
-        *            The text of the post
-        */
-       public MemoryPost(MemoryDatabase postDatabase, SoneProvider soneProvider, String id, String soneId, String recipientId, long time, String text) {
-               this.postDatabase = postDatabase;
-               this.soneProvider = soneProvider;
-               this.id = UUID.fromString(id);
-               this.soneId = soneId;
-               this.recipientId = recipientId;
-               this.time = time;
-               this.text = text;
-       }
-
-       //
-       // ACCESSORS
-       //
-
-       /**
-        * {@inheritDoc}
-        */
-       @Override
-       public String getId() {
-               return id.toString();
-       }
-
-       @Override
-       public boolean isLoaded() {
-               return true;
-       }
-
-       /**
-        * {@inheritDoc}
-        */
-       @Override
-       public Sone getSone() {
-               return soneProvider.getSone(soneId);
-       }
-
-       /**
-        * {@inheritDocs}
-        */
-       @Override
-       public Optional<String> getRecipientId() {
-               return fromNullable(recipientId);
-       }
-
-       /**
-        * {@inheritDoc}
-        */
-       @Override
-       public Optional<Sone> getRecipient() {
-               return recipientId == null ? Optional.<Sone>absent() : fromNullable(soneProvider.getSone(recipientId));
-       }
-
-       /**
-        * {@inheritDoc}
-        */
-       @Override
-       public long getTime() {
-               return time;
-       }
-
-       /**
-        * {@inheritDoc}
-        */
-       @Override
-       public String getText() {
-               return text;
-       }
-
-       /**
-        * {@inheritDoc}
-        */
-       @Override
-       public boolean isKnown() {
-               return postDatabase.isPostKnown(this);
-       }
-
-       /**
-        * {@inheritDoc}
-        */
-       @Override
-       public MemoryPost setKnown(boolean known) {
-               postDatabase.setPostKnown(this, known);
-               return this;
-       }
-
-       //
-       // OBJECT METHODS
-       //
-
-       /**
-        * {@inheritDoc}
-        */
-       @Override
-       public int hashCode() {
-               return id.hashCode();
-       }
-
-       /**
-        * {@inheritDoc}
-        */
-       @Override
-       public boolean equals(Object object) {
-               if (!(object instanceof MemoryPost)) {
-                       return false;
-               }
-               MemoryPost post = (MemoryPost) object;
-               return post.id.equals(id);
-       }
-
-       /**
-        * {@inheritDoc}
-        */
-       @Override
-       public String toString() {
-               return String.format("%s[id=%s,sone=%s,recipient=%s,time=%d,text=%s]", getClass().getName(), id, soneId, recipientId, time, text);
-       }
-
-}
index ad7ab07..589d977 100644 (file)
@@ -291,7 +291,7 @@ class MemoryDatabase @Inject constructor(private val configuration: Configuratio
        override fun isPostBookmarked(post: Post) =
                        memoryBookmarkDatabase.isPostBookmarked(post)
 
-       protected fun isPostKnown(post: Post) = readLock.withLock { post.id in knownPosts }
+       internal fun isPostKnown(post: Post) = readLock.withLock { post.id in knownPosts }
 
        fun setPostKnown(post: Post, known: Boolean): Unit =
                        writeLock.withLock {
diff --git a/src/main/kotlin/net/pterodactylus/sone/database/memory/MemoryPost.kt b/src/main/kotlin/net/pterodactylus/sone/database/memory/MemoryPost.kt
new file mode 100644 (file)
index 0000000..c435084
--- /dev/null
@@ -0,0 +1,62 @@
+/*
+ * Sone - MemoryPost.kt - Copyright Â© 2010–2020 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
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program.  If not, see <http://www.gnu.org/licenses/>.
+ */
+package net.pterodactylus.sone.database.memory
+
+import net.pterodactylus.sone.data.Post
+import net.pterodactylus.sone.data.Sone
+import net.pterodactylus.sone.database.SoneProvider
+import net.pterodactylus.sone.utils.asOptional
+
+/**
+ * A post is a short message that a user writes in his Sone to let other users
+ * know what is going on.
+ */
+internal class MemoryPost(
+               private val postDatabase: MemoryDatabase,
+               private val soneProvider: SoneProvider,
+               override val id: String,
+               private val soneId: String,
+               private val recipientId: String?,
+               private val time: Long,
+               private val text: String
+) : Post {
+
+       override fun isLoaded() = true
+
+       override fun getSone(): Sone = soneProvider.getSone(soneId)!!
+
+       override fun getRecipientId() = recipientId.asOptional()
+
+       override fun getRecipient() = recipientId?.let(soneProvider::getSone).asOptional()
+
+       override fun getTime() = time
+
+       override fun getText() = text
+
+       override fun isKnown() = postDatabase.isPostKnown(this)
+
+       override fun setKnown(known: Boolean) = apply {
+               postDatabase.setPostKnown(this, known)
+       }
+
+       override fun hashCode() = id.hashCode()
+
+       override fun equals(other: Any?) = (other is MemoryPost) && (other.id == id)
+
+       override fun toString() = "${javaClass.name}[id=$id,sone=$soneId,recipient=$recipientId,time=$time,text=$text]"
+
+}