Reactive Programming in Swift
Go to file
2017-01-04 11:46:32 +00:00
.github Fix incorrect Slack URL in GitHub Issue template 2016-11-02 08:18:41 +02:00
assets Adds proper attribution to Rx Logo and license (at least I think it does) . Sry guys. 2015-05-19 20:44:29 +02:00
Documentation Added information on enabling debug mode 2016-12-29 11:24:29 +02:00
Platform Improves hiding of Bag as implementation detail. 2016-11-06 17:55:14 +01:00
Preprocessor Adds unit test to ensure sequence resources will be cleaned on terminal events without external disposing and fixes some cases when this wasn't happening. 2017-01-01 12:48:19 +01:00
Rx.playground Update SupportCode of Rx.playground 2016-12-14 23:10:49 +08:00
Rx.xcodeproj Merge branch 'develop' into feature/switch_if_empty 2017-01-03 20:05:43 +00:00
Rx.xcworkspace [Fix] Removes API reference. 2016-12-27 19:06:42 +01:00
RxBlocking Updates versions. 2016-12-28 20:43:38 +01:00
RxCocoa Updates versions. 2016-12-28 20:43:38 +01:00
RxExample [Fix] Removes missing file link again. 2016-12-17 23:30:30 +01:00
RxSwift Add RxSwift to the file header 2017-01-04 11:45:58 +00:00
RxTest Updates versions. 2016-12-28 20:43:38 +01:00
scripts Improves package-spm script to exclude additional tests that aren't applicable for SPM. 2017-01-01 13:22:37 +01:00
Sources Run ./scripts/package-spm.swift 2017-01-04 11:46:32 +00:00
Tests Add Tests for ifEmpty(switchTo:) 2017-01-03 22:05:25 +00:00
.gitignore RxSwift compiles first time on Linux. 2015-12-25 19:29:39 -08:00
.jazzy.yml Fix incorrect filename 2016-12-30 01:57:47 +09:00
.swift-version Adds .swift-version. 2016-10-21 00:32:43 +02:00
.travis.yml Hopefully improves Travis stability. 2016-10-30 09:40:04 +01:00
CHANGELOG.md Add ifEmpty(switchTo:) operator to changelog 2017-01-03 22:09:44 +00:00
CODE_OF_CONDUCT.md Fixes contact info. 2016-05-21 16:17:17 +02:00
CONTRIBUTING.md Improves CONTRIBUTING.md 2016-06-26 14:59:45 +02:00
Dangerfile Adds swift-3.0 as valid branch in Dangerfile. 2016-07-11 01:36:22 +02:00
Gemfile Danger base setup 2016-06-03 10:27:01 +03:00
Gemfile.lock Danger base setup 2016-06-03 10:27:01 +03:00
LICENSE.md Standardizes header format. 2015-12-29 16:56:21 +01:00
Package.swift Removes RxTest from OSX + SPM until real XCTest support on OSX. 2016-10-23 00:41:51 +02:00
README.md [Fix] Adds isEmpty guard. 2016-12-17 17:27:52 +01:00
RxBlocking.podspec Adds .0 to podspecs. 2016-12-28 20:26:47 +01:00
RxCocoa.podspec Adds .0 to podspecs. 2016-12-28 20:26:47 +01:00
RxSwift.podspec Adds .0 to podspecs. 2016-12-28 20:26:47 +01:00
RxTest.podspec Adds .0 to podspecs. 2016-12-28 20:26:47 +01:00

Miss Electric Eel 2016 RxSwift: ReactiveX for Swift

Travis CI platforms pod Carthage compatible Swift Package Manager compatible

About Rx

⚠️ This readme describes RxSwift 3.0 version that requires Swift 3.0.

⚠️ If you are looking for Swift 2.3 compatible version, please take a look at RxSwift ~> 2.0 versions and swift-2.3 branch.

Rx is a generic abstraction of computation expressed through Observable<Element> interface.

This is a Swift version of Rx.

It tries to port as many concepts from the original version as possible, but some concepts were adapted for more pleasant and performant integration with iOS/macOS environment.

Cross platform documentation can be found on ReactiveX.io.

Like the original Rx, its intention is to enable easy composition of asynchronous operations and event/data streams.

KVO observing, async operations and streams are all unified under abstraction of sequence. This is the reason why Rx is so simple, elegant and powerful.

I came here because I want to ...

... understand
... install
... hack around
... interact
... compare
... find compatible
... see the broader vision
  • Does this exist for Android? RxJava
  • Where is all of this going, what is the future, what about reactive architectures, how do you design entire apps this way? Cycle.js - this is javascript, but RxJS is javascript version of Rx.

Usage

Here's an example In Action
Define search for GitHub repositories ...
let searchResults = searchBar.rx.text.orEmpty
    .throttle(0.3, scheduler: MainScheduler.instance)
    .distinctUntilChanged()
    .flatMapLatest { query -> Observable<[Repository]> in
        if query.isEmpty {
            return .just([])
        }
    return searchGitHub(query)
        .catchErrorJustReturn([])
}
.observeOn(MainScheduler.instance)</pre></div></td>
... then bind the results to your tableview
searchResults
    .bindTo(tableView.rx.items(cellIdentifier: "Cell")) {
        (index, repository: Repository, cell) in
        cell.textLabel?.text = repository.name
        cell.detailTextLabel?.text = repository.url
    }
    .addDisposableTo(disposeBag)

Requirements

  • Xcode 8.0
  • Swift 3.0

Installation

Rx doesn't contain any external dependencies.

These are currently the supported options:

Manual

Open Rx.xcworkspace, choose RxExample and hit run. This method will build everything and run the sample app

CocoaPods

Tested with pod --version: 1.1.1

# Podfile
use_frameworks!

target 'YOUR_TARGET_NAME' do
    pod 'RxSwift',    '~> 3.0'
    pod 'RxCocoa',    '~> 3.0'
end

# RxTests and RxBlocking make the most sense in the context of unit/integration tests
target 'YOUR_TESTING_TARGET' do
    pod 'RxBlocking', '~> 3.0'
    pod 'RxTest',     '~> 3.0'
end

Replace YOUR_TARGET_NAME and then, in the Podfile directory, type:

$ pod install

Carthage

Tested with carthage version: 0.18.1

Add this to Cartfile

github "ReactiveX/RxSwift" ~> 3.0
$ carthage update

Swift Package Manager

Tested with swift build --version: 3.0.0 (swiftpm-19)

Create a Package.swift file.

import PackageDescription

let package = Package(
    name: "RxTestProject",
    targets: [],
    dependencies: [
        .Package(url: "https://github.com/ReactiveX/RxSwift.git", majorVersion: 3)
    ]
)
$ swift build

Manually using git submodules

  • Add RxSwift as a submodule
$ git submodule add git@github.com:ReactiveX/RxSwift.git
  • Drag Rx.xcodeproj into Project Navigator
  • Go to Project > Targets > Build Phases > Link Binary With Libraries, click + and select RxSwift-[Platform] and RxCocoa-[Platform] targets

References