Reactive Extensions for Lua

Junseong Jang f9ff630135 Add an assertion like 'expect(observable).to.produce.error()' to test 'onError'. vor 6 Jahren
doc f9ff630135 Add an assertion like 'expect(observable).to.produce.error()' to test 'onError'. vor 6 Jahren
examples 4b0833d44e Rename fromValue to of; vor 8 Jahren
rockspec 763ab162cd Add 0.0.3 rockspec; vor 8 Jahren
src f9ff630135 Add an assertion like 'expect(observable).to.produce.error()' to test 'onError'. vor 6 Jahren
tests f9ff630135 Add an assertion like 'expect(observable).to.produce.error()' to test 'onError'. vor 6 Jahren
tools 8b825ffc44 Update tools build version; vor 7 Jahren
.luacov c6688ff79e Test for 5.3 and luajit 2.1. vor 8 Jahren
.travis.yml c6688ff79e Test for 5.3 and luajit 2.1. vor 8 Jahren
LICENSE d64834faa6 Initial commit; vor 10 Jahren
README.md ef6f80be0b Update README; vor 7 Jahren
rx.lua f9ff630135 Add an assertion like 'expect(observable).to.produce.error()' to test 'onError'. vor 6 Jahren

README.md

RxLua Build Status Coverage Status

Reactive Extensions for Lua.

RxLua gives Lua the power of Observables, which are data structures that represent a stream of values that arrive over time. They're very handy when dealing with events, streams of data, asynchronous requests, and concurrency.

Getting Started

Lua

Copy the rx.lua file into your project and require it:

local rx = require 'rx'

You can also install RxLua using luarocks:

luarocks install bjornbytes/rxlua

Luvit

Install using lit:

lit install bjornbytes/rx

Then require it:

local rx = require 'rx'

Love2D

See RxLove.

Example Usage

Use RxLua to construct a simple cheer:

local Rx = require 'rx'

Rx.Observable.fromRange(1, 8)
  :filter(function(x) return x % 2 == 0 end)
  :concat(Rx.Observable.of('who do we appreciate'))
  :map(function(value) return value .. '!' end)
  :subscribe(print)

-- => 2! 4! 6! 8! who do we appreciate!

See examples for more.

Resources

Tests

Uses lust. Run with:

lua tests/runner.lua

or, to run a specific test:

lua tests/runner.lua skipUntil

License

MIT, see LICENSE for details.