Reactive Extensions for Lua

bjorn b1ff4dfd15 Observable.delay; 9 năm trước cách đây
doc b1ff4dfd15 Observable.delay; 9 năm trước cách đây
examples 01b87a5577 Fix scheduler examples; 10 năm trước cách đây
src b1ff4dfd15 Observable.delay; 9 năm trước cách đây
tests 5f6d142f74 Safely execute user supplied code; 9 năm trước cách đây
tools b1ff4dfd15 Observable.delay; 9 năm trước cách đây
.travis.yml c4a0b9f48a test 5.1, 5.2 and luajit 10 năm trước cách đây
LICENSE d64834faa6 Initial commit; 10 năm trước cách đây
README.md 11657baa33 Update README; 9 năm trước cách đây
rx.lua b1ff4dfd15 Observable.delay; 9 năm trước cách đây

README.md

RxLua Build 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.fromValue('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.