Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/zolomatok/Johnny
Melodic Caching for Swift
https://github.com/zolomatok/Johnny
caching generic ios macos tvos watchos
Last synced: about 1 month ago
JSON representation
Melodic Caching for Swift
- Host: GitHub
- URL: https://github.com/zolomatok/Johnny
- Owner: zolomatok
- License: other
- Created: 2016-06-30T15:22:35.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2019-09-10T08:14:11.000Z (over 5 years ago)
- Last Synced: 2024-04-26T07:22:12.214Z (9 months ago)
- Topics: caching, generic, ios, macos, tvos, watchos
- Language: Swift
- Homepage:
- Size: 327 KB
- Stars: 36
- Watchers: 2
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ios - Johnny - Melodic Caching for Swift. (Cache)
- awesome-ios-star - Johnny - Melodic Caching for Swift. (Cache)
- fucking-awesome-ios - Johnny - Melodic Caching for Swift. (Cache)
- fucking-awesome-ios - Johnny - Melodic Caching for Swift. (Cache)
README
![Logo](/Johnny/johnny-logo.png?raw=true)
![platform](https://cdn.rawgit.com/zolomatok/Johnny/master/platform.svg)
![license](https://cdn.rawgit.com/zolomatok/Johnny/master/license.svg)Johnny is a generic caching library written for Swift 4.
## Features
**Johnny can cache any model object that conforms to the `Cachable` protocol.**- [x] Out-of-the-box support:
- String, Bool, Int, UInt, Int64, UInt64, Float, Double
- URL, Data, Date
- UIImage, UIColor **by wrapping them in an Image or Color wrapper class respectively**
- Arrays, Dictionaries and Sets of the above
- [x] Multiplatform, supporting iOS, macOS, tvOS & watchOS
- [x] First-level memory cache using `NSCache`
- [x] Second-level LRU disk cache
- [x] Disk access in background thread (always when saving, optionally when fetching)
- [x] Syncronous & Asynchronous API support
- [x] Automatic cache eviction on memory warnings & disk capacity reached
- [x] Unit tested
- [x] Concise, well-structured code to encourage contributionsExtra ❤️ for images:
- [x] `func setImageWithURL` extension on UIImageView, UIButton & NSImageView, optimized for cell reuse## Usage
### Caching ###
```swift
Johnny.cache(user, key: "LocalUser")let imgage = UIImage(named: "awesomeness")
Johnny.cache(Image(image), key: "Image") // Caching a UIImage. UIColor objects must be wrapped in the Color wrapper class the same way.// You can flag a value to be stored in the Library instead of the Caches folder if you don't want it to be automatically purged:
Johnny.cache(Date(), key: "FirstStart", library: true)
```### Pulling ###
```swift
// The type of the retrived value must be explicitly stated for the compiler.
let date: Date? = Johnny.pull("FirstStart")// If you know you are retrieving a large object (> 1.5 MB) you can do it asynchronously
Johnny.pull("4KImage") { (image: Image?) in
let img = image.uiImage()
}
```### Removing ###
```swift
Johnny.remove("LocalUser")
```## Examples
### Collections ###
You can cache any collection of items conforming to the Storable protocol (most standard library data types already do)
```swift
let array: [String] = ["Folsom", "Prison", "Blues"]
let stringSet: Set = ["I've", "been", "everywhere"]
// In case of dictionaries, the value must explicitly conform to Storable (so [String: AnyObject] does not work, while [String: Double] does)
let dictionary: [String: String] = ["first": "Solitary", "second": "man"]Johnny.cache(array, key: "folsom")
Johnny.cache(stringSet, key: "everywhere")
Johnny.cache(dictionary, key: "solitary")
```### Custom types ###
Due to current Swift limitations, since the Storable protocol has an `associatedType`, conformance must be added through an extension.
`class User: Storable` will not work.```swift
struct User {
enum Badassery: String { case Total }
var name: String?
var uid: Int
var badassery: Badassery
}extension User: Storable {
typealias Result = Userstatic func fromData(data: NSData) -> User.Result? {
let dict = try! NSJSONSerialization.JSONObjectWithData(data, options: NSJSONReadingOptions()) as! [NSObject: AnyObject]let user = User()
user.uid = dict["identification"] as! Int
user.name = dict["name"] as? String
user.badassery = Badassery(rawValue: dict["badassery"] as! String)!
return user
}func toData() -> NSData {
let json = ["identification": uid, "name": name, "badassery": badassery.rawValue]
return try! NSJSONSerialization.dataWithJSONObject(json, options: NSJSONWritingOptions())
}
}
```**Using it with Johnny:**
```swift
let lily = User(name: "Lily", uid: 84823682, badassery: .Total)
Johnny.cache(lily, key: "Lily")let cachedLily: User = Johnny.pull("Lily")
```## Requirements
- iOS 8.0+
- macOS 10.10+
- tvOS 9.0+
- watchOS 2.0+
- Swift 4.0## Install
**CocoaPods**
```
pod 'Johnny'
```**Carthage**
```
github "zolomatok/Johnny"
```**Manual**
- Clone the project
- Select the scheme (platform) and build
- Drag Johnny.framework to your project
- In the project settings under your target's General tab, scroll down and add Johhny to the ```Embedded Binaries``` section if it's not already added.## Attribution
I'd like to thank the creators of [Pantry](https://github.com/nickoneill/Pantry) and [Haneke](https://github.com/Haneke/HanekeSwift) as those projects provided much of the inspiration and some code. Johnny was dreamed up to be the best of both worlds.## License
Johnny is released under the MIT license. See LICENSE for details.