Reactive Programming in Swift
Go to file
2016-08-21 02:06:40 +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 Update documentation (.md files) 2016-08-16 09:05:24 +02:00
Preprocessor Fixes for Swift 3.0 2016-07-23 16:05:04 +02:00
Rx.playground WIP: Updates code for Xcode 8 beta 6 using the migrator with manual auditing. 2016-08-16 14:00:14 +01:00
Rx.xcodeproj Fixes RxCocoa compilation issues. 2016-08-19 01:59:06 +02:00
Rx.xcworkspace Changes order of pre-release tests. 2016-08-20 23:06:30 +02:00
RxBlocking WIP: Updates code for Xcode 8 beta 6 using the migrator with manual auditing. 2016-08-16 14:00:14 +01:00
RxCocoa Adds UITests. 2016-08-20 22:59:34 +02:00
RxExample Temporary disables example failing tests. ¯\_(ツ)_/¯ 2016-08-21 00:24:15 +02:00
RxSwift Fixes deprecated rename for NopDisposable. 2016-08-19 15:34:22 +02:00
RxTests Replaces open with public. 2016-08-16 22:10:41 +02:00
scripts Adds skip automation flags. 2016-08-21 02:06:40 +02:00
Sources Adds test to Linux tests. 2016-05-31 21:54:57 +02:00
Tests Merge branch 'swift-3.0-removing-rx_-prefix' of https://github.com/JegnuX/RxSwift into JegnuX-swift-3.0-removing-rx_-prefix 2016-08-19 00:45:51 +02:00
.gitignore RxSwift compiles first time on Linux. 2015-12-25 19:29:39 -08:00
.jazzy.yml Add a .jazzy.yml file and scripts that create and update it 2016-06-08 15:19:50 +02:00
.travis.yml Adds printing of environment info. 2016-07-10 13:06:00 +02:00
CHANGELOG.md Merge branch 'master' into swift-3.0 2016-07-05 18:00:36 +03: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
ISSUE_TEMPLATE.md Moves issue template to root. 2016-06-26 14:53:12 +02:00
LICENSE.md Standardizes header format. 2015-12-29 16:56:21 +01:00
Package.swift Update for Xcode 8 beta 5 2016-08-10 09:45:23 +10:00
README.md Update documentation (.md files) 2016-08-16 09:05:24 +02:00
RxBlocking.podspec Bumps up podspec OSX minimal version to 10.10. #791 2016-08-07 20:27:31 +02:00
RxCocoa.podspec Bumps up podspec OSX minimal version to 10.10. #791 2016-08-07 20:27:31 +02:00
RxSwift.podspec Bumps up podspec OSX minimal version to 10.10. #791 2016-08-07 20:27:31 +02:00
RxTests.podspec Bumps up podspec OSX minimal version to 10.10. #791 2016-08-07 20:27:31 +02:00

Miss Electric Eel 2016 RxSwift: ReactiveX for Swift

Travis CI platforms pod Carthage compatible

Xcode 7.3 Swift 2.2 required

About Rx

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/OSX 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
    .throttle(0.3, scheduler: MainScheduler.instance)
    .distinctUntilChanged()
    .flatMapLatest { query -> Observable<[Repository]> in
        if query.isEmpty {
            return Observable.just([])
        }
    return searchGitHub(query)
        .catchErrorJustReturn([])
}
.observeOn(MainScheduler.instance)</pre></div></td>
... then bind the results to your tableview
searchResults
    .bindTo(tableView.rx.itemsWithCellIdentifier("Cell")) {
        (index, repository: Repository, cell) in
        cell.textLabel?.text = repository.name
        cell.detailTextLabel?.text = repository.url
    }
    .addDisposableTo(disposeBag)

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

⚠️ IMPORTANT! For tvOS support, CocoaPods 0.39 is required. ⚠️

# Podfile
use_frameworks!

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

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

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

⚠️ If you want to use CocoaPods with Xcode 8.0 beta and Swift 2.3, you might need to add the following lines to your podfile: ⚠️

  post_install do |installer|
	  installer.pods_project.targets.each do |target|
	    target.build_configurations.each do |config|
	      config.build_settings['SWIFT_VERSION'] = '2.3'
	      config.build_settings['MACOSX_DEPLOYMENT_TARGET'] = '10.10'
	    end
	  end
	end
$ pod install

Carthage

Xcode 7.1 required

Add this to Cartfile

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

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