Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/luoxiu/future
A futures and promises implementation for Swift.
https://github.com/luoxiu/future
async dispatch fast future gcd ios macos promise swift
Last synced: 2 months ago
JSON representation
A futures and promises implementation for Swift.
- Host: GitHub
- URL: https://github.com/luoxiu/future
- Owner: luoxiu
- License: mit
- Created: 2019-05-30T15:49:50.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-01-30T01:50:49.000Z (almost 2 years ago)
- Last Synced: 2024-10-18T19:31:12.742Z (3 months ago)
- Topics: async, dispatch, fast, future, gcd, ios, macos, promise, swift
- Language: Swift
- Homepage:
- Size: 293 KB
- Stars: 12
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Future.swift
![travis](https://img.shields.io/travis/luoxiu/Future.svg)
![release](https://img.shields.io/github/v/release/luoxiu/Future?include_prereleases)
![install](https://img.shields.io/badge/install-spm%20%7C%20cocoapods%20%7C%20carthage-ff69b4)
![platform](https://img.shields.io/badge/platform-ios%20%7C%20macos%20%7C%20watchos%20%7C%20tvos%20%7C%20linux-lightgrey)
![license](https://img.shields.io/github/license/luoxiu/Future.swift?color=black)`Future.swift` is a [futures and promises](https://en.wikipedia.org/wiki/Futures_and_promises) implementation for Swift.
## Highlights
- **Unlimited features**
- **Unmatched performance**
- **Friendly api**
- **Type safe**## Benchmark
The performance tests I'm using follows [google/promises](https://github.com/google/promises/blob/master/g3doc/index.md#benchmark). The comparison libraries include [promises](https://github.com/google/promises), [PromiseKit](https://github.com/mxcl/PromiseKit), [BrightFutures](https://github.com/Thomvis/BrightFutures) and [Hydra](https://github.com/malcommac/Hydra). In fact, [promises](https://github.com/google/promises) is implemented in Objective-C, but whatever.
You can see [benchmark/benchmark.xcodeporj](https://github.com/luoxiu/Future.swift/tree/master/benchmark) for more information.
> Average time in nanoseconds needed to create a resolved promise, chain 1/2/3 blocks and get into the last chained block on a serial queue (measured with 10,000 tries).
> Average time in nanoseconds needed to resolve 10,000 pending promises with chained blocks and wait for control to get into each block on a concurrent queue.
## Usage
`Future.swift`'s api is very friendly, here is a real-wold demo:
```swift
func fetch(_ str: String) -> Future {
guard let url = URL(string: str) else {
return .failure(.invalidURL(str))
}let p = Promise()
URLSession.shared.dataTask(with: url) { (data, response, error) in
if let e = error {
p.fail(HTTPError.session(e))
return
}
p.succeed(HTTPResponse(response, data))
}
return p.future
}let img = "https://cdn.io/me.png"
fetch(img)
.validate {
$0.status.isValid()
}
.userInitiated()
.tryMap {
try ImageDecoder().decode($0.data)
}
.main {
self.imageView = $0
}
.background {
cache.add($0, for: img)
}
.catch {
Log.error($0)
}
````Future.swift`'s core interface is extremely simple, let's take a look:
### Future
A future represents an eventual result of an asynchronous operation.
- `isPending`: Return true if the future is pending.
- `isCompleted`: Return true if the future is completed.
- `inspect()`: Inspect the future atomically, return nil if the future is pending.
- `whenComplete(_ callback: @escaping (Result) -> Void)`: Add a callback to the future that will be called when the future is completed.
### Promise
A promise is responsible for managing the state of a future.
```swift
let p = Promise()DispatchQueue.background {
do {
let r = try task()
p.succeed(r)
} catch let e {
p.fail(e)
}
}p.future
```### Features
`Future.swift` provides 30+ methods to enhance future's capabilities:
- `always`
- `and`
- `any`
- `asAny`
- `asVoid`
- `catch`
- `delay`
- `done`
- `finally`
- `flat`
- `flatMap`
- `hush`
- `map`
- `mute`
- `pipe`
- `race`
- `recover`
- `reduce`
- `retry`
- `return`
- `some`
- `tap`
- `then`
- `timeout`
- `validate`
- `wait`
- `yield`
- `whenAll`
- `whenAny`
- ...Detailed documentation is still being written, if you have good new ideas, welcome to contribute!
## Install
```swift
dependencies: [
.package(url: "https://github.com/luoxiu/Future.swift", from: "0.0.0")
]
```## License
MIT