io.reactors.protocol

Patterns

trait Patterns extends AnyRef

General communication patterns.

Allows specifying communication patterns in a generic way.

As an example, one can declaratively retry server requests until a timeout, by sending a throttled sequence of requests until a timeout, and taking the first reply that comes:

Seq(1, 2, 4).toEvents.throttle(x => x.seconds).map(_ => server ? "req")
  .first.until(timeout(3.seconds))
Linear Supertypes
AnyRef, Any
Ordering
  1. Alphabetic
  2. By inheritance
Inherited
  1. Patterns
  2. AnyRef
  3. Any
Implicitly
  1. by any2stringadd
  2. by StringFormat
  3. by Ensuring
  4. by ArrowAssoc
  1. Hide All
  2. Show all
Learn more about member selection
Visibility
  1. Public
  2. All

Type Members

  1. implicit class DurationEventOps[T] extends AnyRef

Value Members

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

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

    Definition Classes
    AnyRef → Any
  3. def +(other: String): String

    Implicit information
    This member is added by an implicit conversion from Patterns to any2stringadd[Patterns] performed by method any2stringadd in scala.Predef.
    Definition Classes
    any2stringadd
  4. def ->[B](y: B): (Patterns, B)

    Implicit information
    This member is added by an implicit conversion from Patterns to ArrowAssoc[Patterns] performed by method ArrowAssoc in scala.Predef.
    Definition Classes
    ArrowAssoc
    Annotations
    @inline()
  5. final def ==(arg0: Any): Boolean

    Definition Classes
    AnyRef → Any
  6. object Backoff

    Utility methods for frequently used delay sequences.

  7. final def asInstanceOf[T0]: T0

    Definition Classes
    Any
  8. def clone(): AnyRef

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  9. def ensuring(cond: (Patterns) ⇒ Boolean, msg: ⇒ Any): Patterns

    Implicit information
    This member is added by an implicit conversion from Patterns to Ensuring[Patterns] performed by method Ensuring in scala.Predef.
    Definition Classes
    Ensuring
  10. def ensuring(cond: (Patterns) ⇒ Boolean): Patterns

    Implicit information
    This member is added by an implicit conversion from Patterns to Ensuring[Patterns] performed by method Ensuring in scala.Predef.
    Definition Classes
    Ensuring
  11. def ensuring(cond: Boolean, msg: ⇒ Any): Patterns

    Implicit information
    This member is added by an implicit conversion from Patterns to Ensuring[Patterns] performed by method Ensuring in scala.Predef.
    Definition Classes
    Ensuring
  12. def ensuring(cond: Boolean): Patterns

    Implicit information
    This member is added by an implicit conversion from Patterns to Ensuring[Patterns] performed by method Ensuring in scala.Predef.
    Definition Classes
    Ensuring
  13. final def eq(arg0: AnyRef): Boolean

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

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

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  16. def formatted(fmtstr: String): String

    Implicit information
    This member is added by an implicit conversion from Patterns to StringFormat[Patterns] performed by method StringFormat in scala.Predef.
    Definition Classes
    StringFormat
    Annotations
    @inline()
  17. final def getClass(): Class[_]

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

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

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

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

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

    Definition Classes
    AnyRef
  23. def retry[T](backoffScheme: Seq[Duration])(req: ⇒ Events[T]): Events[T]

    Retry the specified request with a backoff scheme.

    Retry the specified request with a backoff scheme.

    After a stream from one of the requests starts emitting events, all the other requests are unsubscribed from, and not further retrying takes place.

    To create different backoff schemes, see the Backoff object.

    backoffScheme

    the duration of subsequent delays between requests

    req

    the code that creates the request and a stream of replies

    returns

    the stream of replies that was first to emit an event

  24. def retry[T](numTimes: Int, delay: Duration)(req: ⇒ Events[T]): Events[T]

    Retry the specified request a fixed number of times.

    Retry the specified request a fixed number of times.

    numTimes

    the number of times to retry the request

    delay

    the delay between each request

    req

    the code that creates the request and a stream of replies

    returns

    the stream of replies that was first to emit an event

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

    Definition Classes
    AnyRef
  26. def toString(): String

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

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

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

    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  30. def [B](y: B): (Patterns, B)

    Implicit information
    This member is added by an implicit conversion from Patterns to ArrowAssoc[Patterns] performed by method ArrowAssoc in scala.Predef.
    Definition Classes
    ArrowAssoc

Inherited from AnyRef

Inherited from Any

Inherited by implicit conversion any2stringadd from Patterns to any2stringadd[Patterns]

Inherited by implicit conversion StringFormat from Patterns to StringFormat[Patterns]

Inherited by implicit conversion Ensuring from Patterns to Ensuring[Patterns]

Inherited by implicit conversion ArrowAssoc from Patterns to ArrowAssoc[Patterns]

Ungrouped