Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/JARMourato/Dispatch
Just a tiny library to make using GCD easier and intuitive
https://github.com/JARMourato/Dispatch
async gdc multithreading swift
Last synced: 3 months ago
JSON representation
Just a tiny library to make using GCD easier and intuitive
- Host: GitHub
- URL: https://github.com/JARMourato/Dispatch
- Owner: JARMourato
- License: mit
- Archived: true
- Created: 2016-05-11T18:19:36.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2017-11-14T19:26:09.000Z (over 7 years ago)
- Last Synced: 2024-05-22T15:21:36.487Z (9 months ago)
- Topics: async, gdc, multithreading, swift
- Language: Swift
- Homepage:
- Size: 495 KB
- Stars: 178
- Watchers: 12
- Forks: 21
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ios - Dispatch - Just a tiny library to make using GCD easier and intuitive. (GCD / Getting Started)
- awesome-ios-star - Dispatch - Just a tiny library to make using GCD easier and intuitive. (GCD / Getting Started)
README
![]()
## Build Status|**Branch**| **Status** |
|---|---|
|**master** |[data:image/s3,"s3://crabby-images/c5592/c5592eb9bb9020891a006479c34cb90d1503a147" alt="Bunch Status"](https://travis-ci.org/Swiftification/Dispatch)|
|**develop** |[data:image/s3,"s3://crabby-images/0cb73/0cb73d299b9f830d733d03020be04b5a9217bda1" alt="Bunch Status"](https://travis-ci.org/Swiftification/Dispatch)|## Dispatch
[data:image/s3,"s3://crabby-images/e4b59/e4b59b1f20533c47a10d06ed0cbd1bb49fa975c2" alt="Swift 3.0"](https://developer.apple.com/swift/)
data:image/s3,"s3://crabby-images/d7a73/d7a7360a654a987728d1fde951714a08c32522a9" alt="Platforms"
[data:image/s3,"s3://crabby-images/b802f/b802f870d1448319dc66c70cfbceb47c52b4532f" alt="License"](https://github.com/DynamicThreads/Dispatch/master/LICENSE)[data:image/s3,"s3://crabby-images/2d180/2d1801ae7805458b91e18c5ac4d97d63da45be3a" alt="Carthage compatible"](https://github.com/Carthage/Carthage)
data:image/s3,"s3://crabby-images/8615b/8615b178143992e3d83761194f7cd9cdd1485631" alt="Podspec"[data:image/s3,"s3://crabby-images/c406b/c406bffd5368a86b4fec563774481c50db38083c" alt="codebeat badge"](https://codebeat.co/projects/github-com-swiftification-dispatch)
[data:image/s3,"s3://crabby-images/f0d11/f0d11f49c064f4e250767abfb065093245a33a7b" alt="codecov"](https://codecov.io/gh/S/Dispatch)#### Note:
Dispatch requires swift 3.0. Use version 1.0.0 for swift 2.3 or version 0.9.8 for swift 2.2.
## Installation
#### CocoaPods
Dispatch is available through [CocoaPods](http://cocoapods.org). To install
it, simply add the following line to your Podfile:```ruby
pod 'Dispatch'
```## Carthage
----------------[Carthage](https://github.com/Carthage/Carthage) is a decentralized dependency manager that builds your dependencies and provides you with binary frameworks.
You can install Carthage with [Homebrew](http://brew.sh/) using the following command:
```bash
$ brew update
$ brew install carthage
```To integrate Dispatch into your Xcode project using Carthage, specify it in your `Cartfile`:
```ogdl
github "Swiftification/Dispatch"
```Run `carthage update` to fetch the Dispatch library and drag into your Xcode project.
And then simply
``` swift
import DispatchFramework
```And your good to go!
#### Manually
1. Download and drop ```Dispatch.swift``` anywhere you like in your project.
2. That's it.## Usage
### Basic
```swift
Dispatch.async(dispatch_get_main_queue()) {
//Code to be run on the main thread
}
```##### Or using the helpers provided by Dispatch.Queue enum
```swift
Dispatch.async(Queue.main) {
//Code to be run on the main thread
}
```##### Or using the overloaded method to run on the main thread
```swift
Dispatch.async {
//Code to be run on the main thread
}
```### Types of Dispatch
#### Async
```swift
Dispatch.async(Queue.main) {
//Code to be run on the main thread
}
```#### Sync
```swift
let someCustomQueue = dispatch_queue_create("custom.queue.dispatch", DISPATCH_QUEUE_CONCURRENT)
Dispatch.sync(someCustomQueue) {
//Code to be synchronously on someCustomQueue
}
```#### After
```swift
Dispatch.after(1.0, queue: Queue.main) {
//Code to be run on the main thread after 1 second
}
```
##### Or using the overloaded method to run on the main thread```swift
Dispatch.after(1.0) {
//Code to be run on the main thread after 1 second
}
```#### Once
```swift
let token : dispatch_once_t
Dispatch.once(&token) {
//Code to be run only once in App lifetime
}
```### Queue Helpers
#### Main queue
```swift
let mainQueue = Queue.main
```#### Custom queue
```swift
let customConcurrentQueue = Queue.custom("custom.concurrent.queue.dispatch", Queue.Atribute.concurrent)
let customSerialQueue = Queue.custom("custom.serial.queue.dispatch", Queue.Atribute.serial)
```#### Global queues
```swift
let priority = 0 // or you use one of the Global priorities (ex: Queue.Priority.UserInteractive)
let globalQueue = Queue.global(priority)// For comodity there are helpers for getting the Global queues
let globalUserInteractiveQueue = Queue.globalUserInteractive
let globalUserInitiatedQueue = Queue.globalUserInitiated
let globalUtilityQueue = Queue.globalUtility
let globalBackgroundQueue = Queue.globalBackground
```## TODO
- [X] Carthage compatible
- [X] Chainable methods
- [X] Travis CI
- [X] Unit Tests
- [ ] More examples## Communication
- If you **find a bug**, open an issue.
- If you **have a feature request**, open an issue.
- If you **want to contribute**, submit a pull request.## Authors
- João Mourato, [email protected]
- Gabriel Peart
## License
Dispatch is available under the MIT license. See the LICENSE file for more info.