Monix

Asynchronous Programming for Scala and Scala.js.

Gitter

Overview

Monix is a high-performance Scala / Scala.js library for composing asynchronous and event-based programs, exposing high-level types, such as observable sequences that are exposed as asynchronous streams, expanding on the observer pattern, strongly inspired by ReactiveX and by Scalaz, but designed from the ground up for back-pressure and made to cleanly interact with Scala’s standard library, compatible out-of-the-box with the Reactive Streams protocol.

Highlights:

Featured presentation:

flatMap(Oslo), 2016

Download and Usage

The packages are published on Maven Central.

For the old 1.x release (use the %%% for Scala.js):

libraryDependencies += "org.monifu" %% "monifu" % "1.2"

For the 2.x release (use the %%% for Scala.js):

libraryDependencies += "io.monix" %% "monix" % "2.0.2"

Monix 2.0 is modular by design, so you can pick and choose:

Optional integrations:

Head over to Usage in SBT and Maven for more details.

Documentation

Links:

Please contribute!

Latest News

  1. Monix: Version 2.0.2 Released for Bug Fixing
  2. Monix: Version 2.0.1 Released for Maintenance
  3. Monix: Version 2.0.0 Final Release
  4. Monix: Version 2.0-RC13 Released
  5. Monix: Version 2.0-RC11 Released

Acknowledgements

YourKit supports the Monix project with its full-featured Java Profiler. YourKit, LLC is the creator YourKit Java Profiler and YourKit .NET Profiler, innovative and intelligent tools for profiling Java and .NET applications.

Development of Monix has been initiated by Eloquentix engineers, with Monix being introduced at E.ON Connecting Energies, powering the next generation energy grid solutions.