From 6589f42e28afe1ac1ddeae4a72b98e774642a594 Mon Sep 17 00:00:00 2001 From: mramotar Date: Sat, 16 Mar 2024 11:00:34 -0400 Subject: [PATCH 1/2] Define PagingBuffer Signed-off-by: mramotar --- .../paging/core/PagingBuffer.kt | 59 +++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100644 paging/core/src/commonMain/kotlin/org/mobilenativefoundation/paging/core/PagingBuffer.kt diff --git a/paging/core/src/commonMain/kotlin/org/mobilenativefoundation/paging/core/PagingBuffer.kt b/paging/core/src/commonMain/kotlin/org/mobilenativefoundation/paging/core/PagingBuffer.kt new file mode 100644 index 000000000..38a6c7fed --- /dev/null +++ b/paging/core/src/commonMain/kotlin/org/mobilenativefoundation/paging/core/PagingBuffer.kt @@ -0,0 +1,59 @@ +package org.mobilenativefoundation.paging.core + +/** + * A custom data structure for efficiently storing and retrieving paging data. + * + * The [PagingBuffer] is responsible for caching and providing access to the loaded pages of data. + * It allows retrieving data by load parameters, page key, or accessing the entire buffer. + * + * @param Id The type of the unique identifier for each item in the paged data. + * @param K The type of the key used for paging. + * @param P The type of the parameters associated with each page of data. + * @param D The type of the data items. + */ +interface PagingBuffer, K : Any, P : Any, D : Any> { + /** + * Retrieves the data associated with the specified [PagingSource.LoadParams]. + * + * @param params The [PagingSource.LoadParams] to retrieve the data for. + * @return The [PagingSource.LoadResult.Data] associated with the specified [params], or `null` if not found. + */ + fun get(params: PagingSource.LoadParams): PagingSource.LoadResult.Data? + + /** + * Retrieves the data associated with the specified [PagingKey]. + * + * @param key The [PagingKey] to retrieve the data for. + * @return The [PagingSource.LoadResult.Data] associated with the specified [key], or `null` if not found. + */ + fun get(key: PagingKey): PagingSource.LoadResult.Data? + + /** + * Retrieves the data at the head of the buffer. + * + * @return The [PagingSource.LoadResult.Data] at the head of the buffer, or `null` if the buffer is empty. + */ + fun head(): PagingSource.LoadResult.Data? + + /** + * Retrieves all the data in the buffer as a list. + * + * @return A list of all the [PagingSource.LoadResult.Data] in the buffer. + */ + fun getAll(): List> + + /** + * Checks if the buffer is empty. + * + * @return `true` if the buffer is empty, `false` otherwise. + */ + fun isEmpty(): Boolean + + /** + * Returns the index of the data associated with the specified [PagingKey] in the buffer. + * + * @param key The [PagingKey] to find the index for. + * @return The index of the data associated with the specified [key], or -1 if not found. + */ + fun indexOf(key: PagingKey): Int +} From 86b9f39fd4bdc0c43326f34d1c30ee40e7c2169d Mon Sep 17 00:00:00 2001 From: mramotar Date: Sat, 16 Mar 2024 11:02:23 -0400 Subject: [PATCH 2/2] Define MutablePagingBuffer Signed-off-by: mramotar --- .../paging/core/MutablePagingBuffer.kt | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) create mode 100644 paging/core/src/commonMain/kotlin/org/mobilenativefoundation/paging/core/MutablePagingBuffer.kt diff --git a/paging/core/src/commonMain/kotlin/org/mobilenativefoundation/paging/core/MutablePagingBuffer.kt b/paging/core/src/commonMain/kotlin/org/mobilenativefoundation/paging/core/MutablePagingBuffer.kt new file mode 100644 index 000000000..c79da554c --- /dev/null +++ b/paging/core/src/commonMain/kotlin/org/mobilenativefoundation/paging/core/MutablePagingBuffer.kt @@ -0,0 +1,19 @@ +package org.mobilenativefoundation.paging.core + +/** + * Represents a mutable version of [PagingBuffer] that allows adding and updating paging data. + * + * @param Id The type of the unique identifier for each item in the paged data. + * @param K The type of the key used for paging. + * @param P The type of the parameters associated with each page of data. + * @param D The type of the data items. + */ +interface MutablePagingBuffer, K : Any, P : Any, D : Any> : PagingBuffer { + /** + * Puts the loaded page of data associated with the specified [PagingSource.LoadParams] into the buffer. + * + * @param params The [PagingSource.LoadParams] associated with the loaded page. + * @param page The [PagingSource.LoadResult.Data] representing the loaded page of data. + */ + fun put(params: PagingSource.LoadParams, page: PagingSource.LoadResult.Data) +} \ No newline at end of file