Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ulrikdamm/Forbind
Functional chaining and promises in Swift
https://github.com/ulrikdamm/Forbind
async binding monads promise result swift
Last synced: about 2 months ago
JSON representation
Functional chaining and promises in Swift
- Host: GitHub
- URL: https://github.com/ulrikdamm/Forbind
- Owner: ulrikdamm
- License: mit
- Created: 2015-03-24T18:45:19.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2017-05-03T13:12:20.000Z (over 7 years ago)
- Last Synced: 2024-04-26T23:22:02.212Z (9 months ago)
- Topics: async, binding, monads, promise, result, swift
- Language: Swift
- Homepage:
- Size: 139 KB
- Stars: 45
- Watchers: 5
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ios - Forbind - Functional chaining and promises in Swift. (Functional Programming / Getting Started)
- awesome-ios-star - Forbind - Functional chaining and promises in Swift. (Functional Programming / Getting Started)
- awesome-swift-cn - Forbind - Functional chaining and Promises in Swift. (Libs / Events)
README
# Forbind
Functional chaining and promises in Swift
Note: still in an experimental state. Everything could change. I would love some feedback on this. Write to [@ulrikdamm](https://twitter.com/ulrikdamm) on Twitter.
# What is it
Bind local or async expressions together functionally, all error handling taken care of for you:
```swift
func getUser(id : String) -> Promise> {
let data = NSURL(string: id)
=> { NSURLRequest(URL: $0) }
=> NSURLConnection.sendRequest(.mainQueue())
=> { response, data in data }
return data
=> NSJSONSerialization.toJSON(options: nil)
=> { $0.dictionaryValue }
=> User.fromJSON
}
```• Bind operations together with =>
• No error handling inside your logic
• Transparent async calls
• No if-lets
• Combine inputs with ++
For more details, read my [Blog post](http://ufd.dk/blog/Binds-and-promises-with-Forbind).
## New in 1.1
• ResultPromise and OptionalPromise has been replaced with Promise> and Promise. Still works the same.
• You can use the bind operator to map over lists of promises!
```swift
let user = User(name: "Ulrik")
let names = user.loadFriends() => { $0.name } // [Promise]
```• And you can also filter and reduce with filterp and reducep:
```swift
let someNames = filterp(names) { $0 != "Peter" } // Promise<[String]>
```• The NSJSONSerialization extension now returns a JSONResult, which is either a Dictionary or Array.
# Get started
You can add Forbind to your project using [CocoaPods](https://cocoapods.org). Just add it to your Podfile:
```ruby
use_frameworks!pod 'Forbind', '~> 1.1'
pod 'ForbindExtensions', :git => 'https://github.com/ulrikdamm/Forbind'
```(You need the ```use_frameworks!``` since that feature of CocoaPods is still in beta. ForbindExtensions are optional)
Or you can add it using [Carthage](https://github.com/Carthage/Carthage) by adding this to your cartfile:
```
github "ulrikdamm/Forbind" ~> 1.0
```This will add both Forbind.framework and ForbindExtensions.framework, which you can drag into your Xcode project.
Then in your files just import Forbind and optionally ForbindExtensions
```
import Forbind
import ForbindExtensions
```The Forbind library is the bind operator (```=>```) and the combine operator (```++```), along with the Result enum and Promise classes.
ForbindExtensions are extensions to Foundation and UIKit for working better with Forbind, by, for example, returning a promise instead of using a completion block. The ForbindExtensions are still a work in progress, so you might want to make your own extensions instead. In this case, just only include the Forbind framework.
# What is the state of the project?
It’s still very experimental, so I would love some feedback on it. I wouldn’t recommend relying on this for product code yet. If you have a good idea, or just questions, submit a pull request or contact me at [@ulrikdamm](https://twitter.com/ulrikdamm) on Twitter.
Things that still needs to be considered:
• General direction of the project (are there some fundamental flaws?)
• Promise cancellation (support for cancelling an async operation if a promise is deallocated)
• Handling of dispatch queues (currently promise callbacks are run on the same queue as the operation finished on)
• More extensions for common UIKit/AppKit/Foundation methods to use Promise and Result instead of NSErrorPointer and completion blocks.
• "Expression was too complex to be solved in reasonable time" for big expressions.