Reactive Extensions for Lua

bjorn f128b4844a Improve test coverage; 8 роки тому
doc 1ca187506b Fix documentation generator formatting; 8 роки тому
examples 4b0833d44e Rename fromValue to of; 9 роки тому
rockspec dbb27e6589 Forgot dependencies 8 роки тому
src 449e29b31c Preserve ordering in CooperativeScheduler; 8 роки тому
tests f128b4844a Improve test coverage; 8 роки тому
tools 1ca187506b Fix documentation generator formatting; 8 роки тому
.luacov c6688ff79e Test for 5.3 and luajit 2.1. 8 роки тому
.travis.yml c6688ff79e Test for 5.3 and luajit 2.1. 8 роки тому
LICENSE d64834faa6 Initial commit; 10 роки тому
README.md 679f3b5ec8 Add coveralls badge 8 роки тому
rx.lua 449e29b31c Preserve ordering in CooperativeScheduler; 8 роки тому

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'

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.