de.sciss.lucre.confluent

DurablePersistentMap

trait DurablePersistentMap[S <: Sys[S], 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).

S

the underlying system

K

the key type

Linear Supertypes
AnyRef, Any
Known Subclasses
Ordering
  1. Alphabetic
  2. By inheritance
Inherited
  1. DurablePersistentMap
  2. AnyRef
  3. Any
  1. Hide All
  2. Show all
Learn more about member selection
Visibility
  1. Public
  2. All

Abstract Value Members

  1. abstract def get[A](key: K, path: Access[S])(implicit tx: S.Tx, serializer: Serializer[S.Tx, Access[S], 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

    path

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

    tx

    the transaction within which the access is performed

    serializer

    the serializer 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, path: Access[S])(implicit tx: S.Tx, serializer: ImmutableSerializer[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 serializer 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

    path

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

    tx

    the transaction within which the access is performed

    serializer

    the serializer 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, path: Access[S])(implicit tx: S.Tx): Boolean

    Note: requires that path is non-empty.

  4. abstract def put[A](key: K, path: Access[S], value: A)(implicit tx: S.Tx, serializer: Serializer[S.Tx, Access[S], A]): Unit

  5. abstract def putImmutable[A](key: K, path: Access[S], value: A)(implicit tx: S.Tx, serializer: ImmutableSerializer[A]): Unit

    Stores a new value for a given write path.

    Stores a new value for a given write path.

    The serializer 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

    path

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

    value

    the value to store

    tx

    the transaction within which the access is performed

    serializer

    the serializer used to store the entity's values

  6. abstract def remove(key: K, path: Access[S])(implicit tx: S.Tx): Boolean

Concrete Value Members

  1. final def !=(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  2. final def !=(arg0: Any): Boolean

    Definition Classes
    Any
  3. final def ##(): Int

    Definition Classes
    AnyRef → Any
  4. final def ==(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  5. final def ==(arg0: Any): Boolean

    Definition Classes
    Any
  6. final def asInstanceOf[T0]: T0

    Definition Classes
    Any
  7. def clone(): AnyRef

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  8. final def eq(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  9. def equals(arg0: Any): Boolean

    Definition Classes
    AnyRef → Any
  10. def finalize(): Unit

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  11. final def getClass(): Class[_]

    Definition Classes
    AnyRef → Any
  12. def hashCode(): Int

    Definition Classes
    AnyRef → Any
  13. final def isInstanceOf[T0]: Boolean

    Definition Classes
    Any
  14. final def ne(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  15. final def notify(): Unit

    Definition Classes
    AnyRef
  16. final def notifyAll(): Unit

    Definition Classes
    AnyRef
  17. final def synchronized[T0](arg0: ⇒ T0): T0

    Definition Classes
    AnyRef
  18. def toString(): String

    Definition Classes
    AnyRef → Any
  19. final def wait(): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  20. final def wait(arg0: Long, arg1: Int): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  21. final def wait(arg0: Long): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )

Inherited from AnyRef

Inherited from Any

Ungrouped