Object/Trait

scala.concurrent.stm.impl

STMImpl

Related Docs: trait STMImpl | package impl

Permalink

object STMImpl

STMImpl gathers all of the functionality required to plug an STM implementation into scala.concurrent.stm. Only one implementation can be selected, because Refs and atomic blocks from different STM implementations are not compatible. STMImpl.instance returns the STMImpl instance that has been selected for this program execution.

There are two ways to explicitly select the STMImpl instance:

  1. set the JVM system property "scala.stm.impl" to the name of a class that implements STMImpl; or

2. arrange for STMImpl.select or STMImpl.trySelect to be called before any Refs are constructed and before any atomic blocks are executed.

Setting the JVM system property "scala.stm.impl" is equivalent to making a call to STMImpl.select(System.getProperty("scala.stm.impl")) before any other STMImpl selections.

If there is no explicitly selected STMImpl instance and the classpath contains a class scala.concurrent.stm.impl.DefaultFactory that extends scala.concurrent.stm.impl.STMImpl.Factory, then an instance of that class will be instantiated and used to generate the STMImpl instance. ScalaSTM implementations are encouraged to implement DefaultFactory so that if a user includes the implementation's JAR file, it will be automatically selected.

If no explicit selection has been made and there is no definition of scala.concurrent.stm.impl.DefaultFactory present in the classpath, then ScalaSTM will fall back to the reference implementation "scala.concurrent.stm.ccstm.CCSTM".

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

Type Members

  1. trait Factory extends AnyRef

    Permalink

Value Members

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

    Permalink
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

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

    Permalink
    Definition Classes
    AnyRef → Any
  4. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  5. def clone(): AnyRef

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

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

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

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

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

    Permalink
    Definition Classes
    AnyRef → Any
  11. def instance: STMImpl

    Permalink

    Returns the instance of STMImpl that should be used to implement all ScalaSTM functionality.

    Returns the instance of STMImpl that should be used to implement all ScalaSTM functionality. Calling this method forces the implementation to be chosen if it has not already been selected.

  12. final def isInstanceOf[T0]: Boolean

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

    Permalink
    Definition Classes
    AnyRef
  14. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  15. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  16. def select(impl: STMImpl): Unit

    Permalink

    Installs impl as the system-wide STM implementation if no STMImpl has yet been chosen, or verifies that impl is equal to the previously selected instance, throwing IllegalStateException if an STM implementation has already been selected and impl != instance

  17. def select(implClassName: String): Unit

    Permalink

    Installs Class.forName(implClassName) as the system-wide STM implementation if no STMImpl has yet been chosen, or verifies that implClassName was previously selected, throwing IllegalStateException if a different STM implementation has already been selected

  18. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  19. def toString(): String

    Permalink
    Definition Classes
    AnyRef → Any
  20. def trySelect(implClassName: String): Boolean

    Permalink

    If no STMImpl instance has yet been selected, installs an instance of Class.forName(implClassName) as the system-wide STM implementation.

    If no STMImpl instance has yet been selected, installs an instance of Class.forName(implClassName) as the system-wide STM implementation. Returns true if implClassName was newly or previously selected, or returns false if another STM implementation was chosen.

  21. final def wait(): Unit

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

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

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )

Inherited from AnyRef

Inherited from Any

Ungrouped