rescala.interface.RescalaInterface.scala Maven / Gradle / Ivy
package rescala.interface
import rescala.operator._
/** Rescala has two main abstractions. [[Event]] and [[Signal]] commonly referred to as reactives.
* Use [[Var]] to create signal sources and [[Evt]] to create event sources.
*
* Events and signals can be created from other reactives by using combinators,
* signals additionally can be created using [[Signal]] expressions.
*
* @groupname reactive Type aliases for reactives
* @groupprio reactive 50
* @groupdesc reactive Rescala has multiple schedulers and each scheduler provides reactives with different internal state.
* To ensure safety, each reactive is parameterized over the type of internal state, represented by the type
* parameter. To make usage more convenient, we provide type aliases which hide these internals.
* @groupname create Create new reactives
* @groupprio create 100
* @groupname update Update multiple reactives
* @groupprio update 200
* @groupname internal Advanced functions used when extending REScala
* @groupprio internal 900
* @groupdesc internal Methods and type aliases for advanced usages, these are most relevant to abstract
* over multiple scheduler implementations.
*/
trait RescalaInterface extends Operators {
/** @group internal */
def scheduler: Scheduler
override def toString: String = s"Api»${scheduler.schedulerName}«"
/** @group internal */
implicit def implicitScheduler: Scheduler = scheduler
implicit def OnEv[T](e: Event[T]): Events.OnEv[T] = new Events.OnEv[T](e)
implicit def OnEvs[T](e: => Seq[Event[T]]): Events.OnEvs[T] = new Events.OnEvs[T](e)
/** Executes a transaction.
*
* @param initialWrites All inputs that might be changed by the transaction
* @param admissionPhase An admission function that may
* [[rescala.operator.Sources.Evt.admit]] / [[rescala.operator.Sources.Var.admit]] arbitrary
* input changes that will be applied as an atomic transaction at the end.
* @tparam R Result type of the admission function
* @return Result of the admission function
* @group update
* @example transaction(a, b){ implicit at => a.set(5); b.set(1); at.now(a) }
*/
def transaction[R](initialWrites: ReSource*)(admissionPhase: AdmissionTicket => R): R = {
scheduler.forceNewTransaction(initialWrites: _*)(admissionPhase)
}
/** Executes a transaction with WrapUpPhase.
* @see transaction
* @group update
*/
def transactionWithWrapup[I, R](iw: ReSource*)(ap: AdmissionTicket => I)(wrapUp: (I, Transaction) => R): R = {
var res: Option[R] = None
transaction(iw: _*)(at => {
val apr: I = ap(at)
at.wrapUp = wut => { res = Some(wrapUp(apr, wut)) }
})
res.get
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy