Reactive Programming in Swift
Go to file
2017-10-23 16:38:47 +03:00
.github [Fix] Slack legacy URL. 2017-02-16 15:51:54 +01: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 Merge branch 'master' into rxswift4.0-swift4.0 2017-10-17 23:16:00 +02:00
Platform Remove unnecessary in Bag 2017-10-21 16:44:07 +02:00
Preprocessor Removes deprecated APIs from Swift preprocessor. 2017-10-15 21:00:05 +02:00
Rx.playground Moves TryYourself playground to the top. 2017-10-15 21:47:03 +02:00
Rx.xcodeproj Adds global Hooks and implements error handling hook. 2017-10-16 12:54:49 +02:00
Rx.xcworkspace Removes Linux.md from project file. 2017-05-11 00:27:55 +02:00
RxBlocking Set version in Info.plist to 4.0.0 because of ERROR ITMS-90060: "This bundle is invalid. The value for key CFBundleShortVersionString '4.0.0-beta.0' in the Info.plist file must be a period-separated list of at most three non-negative integers." 2017-09-25 21:17:37 +02:00
RxCocoa Added bind(to:) methods for PublishRelay and BehaviorRelay. Added relevant tests for binding. 2017-10-23 16:38:47 +03:00
RxExample Updates DataSources to latest version. 2017-10-15 21:43:54 +02:00
RxSwift Merge branch 'master' into rxswift4.0-swift4.0 2017-10-17 23:16:00 +02:00
RxTest Changes publish, replay, replay all to clear state in case of sequence termination. 2017-10-01 13:14:58 +02:00
scripts Fixes SPM tests. 2017-10-08 13:14:11 +02:00
Sources Adds global Hooks and implements error handling hook. 2017-10-16 12:54:49 +02:00
Tests Added bind(to:) methods for PublishRelay and BehaviorRelay. Added relevant tests for binding. 2017-10-23 16:38:47 +03:00
.gitignore RxSwift compiles first time on Linux. 2015-12-25 19:29:39 -08:00
.jazzy.yml Deprecates asSharedSequence extensions on ObservableType. 2017-10-15 22:57:33 +02:00
.swift-version Updates SPM to use release version of Swift 4.0. 2017-10-07 20:38:36 +02:00
.travis.yml Updates SPM to use release version of Swift 4.0. 2017-10-07 20:38:36 +02:00
CHANGELOG.md Release 4.0.0 2017-10-16 20:55:29 +02: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 Merge branch 'develop' into fix/danger-changelog 2017-04-06 00:07:59 +03:00
default.profraw Release 4.0.0-beta.0 2017-09-18 01:08:40 +02:00
Gemfile Danger base setup 2016-06-03 10:27:01 +03:00
Gemfile.lock Update to latest Danger gem to fix Github Markdown issues 2017-04-05 23:02:27 +02:00
LICENSE.md Standardizes header format. 2015-12-29 16:56:21 +01:00
Package.swift Deprecates Variable in favor of BehaviorRelay. 2017-10-08 13:14:11 +02:00
README.md Updates README.md 2017-10-18 00:56:32 +02:00
RxBlocking.podspec Release 4.0.0 2017-10-16 20:55:29 +02:00
RxCocoa.podspec Release 4.0.0 2017-10-16 20:55:29 +02:00
RxSwift.podspec Release 4.0.0 2017-10-16 20:55:29 +02:00
RxTest.podspec Release 4.0.0 2017-10-16 20:55:29 +02:00

Miss Electric Eel 2016 RxSwift: ReactiveX for Swift

Travis CI platforms pod Carthage compatible Swift Package Manager compatible

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)
... then bind the results to your tableview
searchResults
    .bind(to: tableView.rx.items(cellIdentifier: "Cell")) {
        (index, repository: Repository, cell) in
        cell.textLabel?.text = repository.name
        cell.detailTextLabel?.text = repository.url
    }
    .disposed(by: disposeBag)

Requirements

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.3.1

# Podfile
use_frameworks!

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

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

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

$ pod install

Carthage

Tested with carthage version: 0.26.2

Add this to Cartfile

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

Swift Package Manager

Tested with swift build --version: Swift 4.0.0-dev (swiftpm-13126)

Create a Package.swift file.

// swift-tools-version:4.0

import PackageDescription

let package = Package(
  name: "RxTestProject",
  dependencies: [
    .package(url: "https://github.com/ReactiveX/RxSwift.git", "4.0.0" ..< "5.0.0")
  ],
  targets: [
    .target(name: "RxTestProject", dependencies: ["RxSwift", "RxCocoa"])
  ]
)
$ swift build

To build or test a module with RxTest dependency, set TEST=1. (RxSwift >= 3.4.2)

$ TEST=1 swift test

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