Packages

trait DurablePersistentMap[T <: Txn[T], K] extends AnyRef

Interface for a confluently or partially persistent storing key value map. Keys (type K) might be single object identifiers (as the variable storage case), or combined keys (as in the live map case).

T

the underlying system's transaction type

K

the key type

Linear Supertypes
AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. DurablePersistentMap
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. Protected

Abstract Value Members

  1. abstract def get[A](key: K, tx: T)(implicit path: T.Acc, format: TFormat[T, A]): Option[A]

    Finds the most recent value for an entity id with respect to version path.

    Finds the most recent value for an entity id with respect to version path. If a value is found, it is return along with a suffix suitable for identifier path actualisation.

    A

    the type of values stored with the entity

    key

    the identifier for the object

    tx

    the transaction within which the access is performed

    path

    the path through which the object has been accessed (the version at which it is read)

    format

    the format used to store the entity's values

    returns

    None if no value was found, otherwise a Some of the tuple consisting of the suffix and the value. The suffix is the access path minus the prefix at which the value was found. However, the suffix overlaps the prefix in that it begins with the tree entering/exiting tuple at which the value was found.

  2. abstract def getImmutable[A](key: K, tx: T)(implicit path: T.Acc, format: ConstFormat[A]): Option[A]

    Finds the most recent value for an entity id with respect to version path.

    Finds the most recent value for an entity id with respect to version path.

    The format given is _non_transactional. This is because this trait bridges confluent and ephemeral world (it may use a durable backend, but the data structures used for storing the confluent graph are themselves ephemeral). If the value A requires a transactional serialization, the current approach is to pre-serialize the value into an appropriate format (e.g. a byte array) before calling into put. In that case the wrapping structure must be de-serialized after calling get.

    A

    the type of values stored with the entity

    key

    the identifier for the object

    tx

    the transaction within which the access is performed

    path

    the path through which the object has been accessed (the version at which it is read)

    format

    the format used to store the entity's values

    returns

    None if no value was found, otherwise a Some of that value.

  3. abstract def isFresh(key: K, tx: T)(implicit path: T.Acc): Boolean

    Note: requires that path is non-empty.

  4. abstract def put[A](key: K, value: A, tx: T)(implicit path: T.Acc, format: TFormat[T, A]): Unit
  5. abstract def putImmutable[A](key: K, value: A, tx: T)(implicit path: T.Acc, format: ConstFormat[A]): Unit

    Stores a new value for a given write path.

    Stores a new value for a given write path.

    The format given is _non_transactional. This is because this trait bridges confluent and ephemeral world (it may use a durable backend, but the data structures used for storing the confluent graph are themselves ephemeral). If the value A requires a transactional serialization, the current approach is to pre-serialize the value into an appropriate format (e.g. a byte array) before calling into put. In that case the wrapping structure must be de-serialized after calling get.

    A

    the type of values stored with the entity

    key

    the identifier for the object

    value

    the value to store

    tx

    the transaction within which the access is performed

    path

    the path through which the object has been accessed (the version at which it is read)

    format

    the format used to store the entity's values

  6. abstract def remove(key: K, tx: T)(implicit path: T.Acc): Boolean

Concrete Value Members

  1. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  2. final def ##: Int
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  5. def clone(): AnyRef
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.CloneNotSupportedException]) @native() @HotSpotIntrinsicCandidate()
  6. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  7. def equals(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef → Any
  8. final def getClass(): Class[_ <: AnyRef]
    Definition Classes
    AnyRef → Any
    Annotations
    @native() @HotSpotIntrinsicCandidate()
  9. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native() @HotSpotIntrinsicCandidate()
  10. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  11. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  12. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native() @HotSpotIntrinsicCandidate()
  13. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native() @HotSpotIntrinsicCandidate()
  14. final def synchronized[T0](arg0: => T0): T0
    Definition Classes
    AnyRef
  15. def toString(): String
    Definition Classes
    AnyRef → Any
  16. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  17. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException]) @native()
  18. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])

Deprecated Value Members

  1. def finalize(): Unit
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.Throwable]) @Deprecated
    Deprecated

Inherited from AnyRef

Inherited from Any

Ungrouped