All Downloads are FREE. Search and download functionalities are using the official Maven repository.

ru.primetalk.synapse.rx.DynamicSystemRx.scala Maven / Gradle / Ivy

Go to download

SynapseGrid is a framework for constructing reactive real-time immutable data flow systems. -core contains everything to run a single-threaded system, -akka contains everything to run systems over Akka actors, -slf4j - enables logging, -concurrent - running systems directly over ExecutorContext without the need for Akka, -examples - a few test systems. Also there are -frames - a framework for type construction with meta information (see relations.scala). -typed-expressions - a framework for defining parsers and generators for natural language. The current version is 1.4.0

There is a newer version: 1.4.7
Show newest version
///////////////////////////////////////////////////////////////
// © ООО «Праймтолк», 2011-2013                              //
// Все права принадлежат компании ООО «Праймтолк».           //
///////////////////////////////////////////////////////////////
/**
 * SynapseGrid
 * © Primetalk Ltd., 2013.
 * All rights reserved.
 * Authors: A.Zhizhelev, A.Nehaev
 *
 * Created: 06.12.13, zhizhelev
 */
package ru.primetalk.synapse.rx

import ru.primetalk.synapse.core.{Signal, Contact, DynamicSystem}
import rx.lang.scala.{Observable, Observer, Subject}

class DynamicSystemRx(ds: DynamicSystem) {
  private
  val spRx = new SimpleSignalProcessorRx(ds.receive)

  private
  def inputRx[T](c: Contact[T]): Observer[T] = {
    val s = rx.lang.scala.Subject[T]()
    s.map(data => Signal(c, data)).subscribe(spRx.rxInput)
    s
  }

  private
  def outputRx[T](contact: Contact[T]): Observable[T] = {
    val s = Subject[T]()
    spRx.rxOutput.filter(_.contact == contact).map(_.data.asInstanceOf[T]).subscribe(s)
    s
  }

  private
  val rxInputs = ds.inputContacts.map(c => (c, inputRx(c))).toMap[Contact[_], Observer[_]]

  private
  val rxOutputs = ds.outputContacts.map(c => (c, outputRx(c))).toMap[Contact[_], Observable[_]]

  def rxInput[T](c: Contact[T]): Observer[T] = rxInputs(c).asInstanceOf[Observer[T]]

  def rxOutput[T](c: Contact[T]): Observable[T] = rxOutputs(c).asInstanceOf[Observable[T]]
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy