GithubHelp home page GithubHelp logo

reactor-1's Introduction

Reactor core

A reactor is a process that receives input on form:

  {reactor_signal,Src,SrcField,Field,Value}

Where Src is an other reactor or undefined if sent from any process.
SrcField is the originating field when sent from a connected channel.

This event, trigger event handlers to evaluate and set output 
fields which in turn send reactor signals on connected outputs.

A reactor process consists of fields and event handlers.
A field may be assigned any value either by assign it in the event handler
using assign(Field, Value) or set(Field, Value) or set(self(),Field,Value)
Any field in one reactor may be connected to one or several fields
in other reactors. This makes the value propagtion automatic.

Example:

    Pid = reactor:create(
      name,
      [
        {x,1},  %% x::integer()
        {y,2}   %% y::integer()
      ],

      [
        {id1, 10, x, [x,y], fun(X,Y) -> X+Y end},
	{id2, 20, @exit, [y],   fun(0) -> normal; (_) -> false }
      ]).

This reactor has two fields x and y wih the default values 1 and 2 respectivily.
The create of the reactor can the use reactor:set(Pid,x,2) to make
the reactor trigger the first script (because x is in the input list) and
evaluate a new x value to X+Y = 2+2 = 4.
An other example is to call reactor:set(Pid,y,0) this will trigger the
reactor script number 20 that will set the special field @exit to normal
and will effectivly exit the reactor with reason normal.

Standard field in a reactor core:

@id :: atom()
    Name of reactor "class"

@init :: void()
    Set only when reactor is create and can / should be used
    as constructor. A @init constructor must be given as:
       {constructor, 1, [a,b,c], ['@init'],
       		     fun(_) -> initialize() end}
    The important thing here is that the input fields are ['@init'] to
    trigger on '@init'.
    
@terminate :: void()
    A reactor destructor, trigger before reactor terminates. For example
    after @exit has been set.

@exit :: atom() 
    Stop object when set.

@auto_exit :: boolean()
    Allow reactor to be terminated  - when available.

@dump :: boolean()
    Debug print all fields.

@add_field :: atom()|{atom(),term()}
    Add a dynamic field to the reactor.

@del_field  :: atom() 
    Delete a field from a reactor (even @del_field can be deleted)

@add_handler :: handler()
    Add a dynamic handler to the reactor.

@del_handler :: identifier() 
    Delete a handler from a reactor.

@connect    :: {atom(),pid(),atom()}
    Connect a field to an other reactor field.
	
@disconnect :: {atom(),pid(),atom()}
    Disconnect a field.

@child :: void()
    used to connect @parent in children.
    The {channel,'@child'} is used to get the list of children

@parent :: void()
    store 'parent'.
    
@event :: term()
    Set when an event a message that is not on form:

    {reactor_signal,Src,SrcField,Field,Value}

    is received by the reactor.

@error_handler :: term()
    Set when an error is detect in a destination reactor, when for example
    a reactor tries to send a value to a non existing field.

reactor-1's People

Contributors

tonyrog avatar uwiger avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.