All Downloads are FREE. Search and download functionalities are using the official Maven repository.

commonMain.co.touchlab.stately.collections.IsoArrayDeque.kt Maven / Gradle / Ivy

package co.touchlab.stately.collections

import co.touchlab.stately.isolate.StateHolder
import co.touchlab.stately.isolate.StateRunner
import co.touchlab.stately.isolate.createState

open class IsoArrayDeque
internal constructor(stateHolder: StateHolder>) :
    IsoMutableList(stateHolder) {
    constructor(stateRunner: StateRunner? = null, producer: () -> ArrayDeque = { ArrayDeque() }) : this(createState(stateRunner, producer))

    /**
     * Returns the first element, or throws [NoSuchElementException] if this deque is empty.
     */
    public fun first(): E = asAccess { it.first() }

    /**
     * Returns the first element, or `null` if this deque is empty.
     */
    public fun firstOrNull(): E? = asAccess { it.firstOrNull() }

    /**
     * Returns the last element, or throws [NoSuchElementException] if this deque is empty.
     */
    public fun last(): E = asAccess { it.last() }

    /**
     * Returns the last element, or `null` if this deque is empty.
     */
    public fun lastOrNull(): E? = asAccess { it.lastOrNull() }

    /**
     * Prepends the specified [element] to this deque.
     */
    public fun addFirst(element: E) = asAccess { it.addFirst(element) }

    /**
     * Appends the specified [element] to this deque.
     */
    public fun addLast(element: E) = asAccess { it.addLast(element) }

    /**
     * Removes the first element from this deque and returns that removed element, or throws [NoSuchElementException] if this deque is empty.
     */
    public fun removeFirst(): E = asAccess { it.removeFirst() }

    /**
     * Removes the first element from this deque and returns that removed element, or returns `null` if this deque is empty.
     */
    public fun removeFirstOrNull(): E? = asAccess { it.removeFirstOrNull() }

    /**
     * Removes the last element from this deque and returns that removed element, or throws [NoSuchElementException] if this deque is empty.
     */
    public fun removeLast(): E = asAccess { it.removeLast() }

    /**
     * Removes the last element from this deque and returns that removed element, or returns `null` if this deque is empty.
     */
    public fun removeLastOrNull(): E? = asAccess { it.removeLastOrNull() }

    private inline fun  asAccess(crossinline block: (ArrayDeque) -> R): R =
        access { block(it as ArrayDeque) }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy