Store any object in a flat cache by String id and notify listeners when changes occur.
This is an implementation of Soroush Khanlou's The Flat Cache blog post used in GitHawk.
Just add FlatCache to your Podfile and pod install. Done!
pod 'FlatCache'
Add the Cachable protocol to models that you want to store in the cache. Conform to the protocol by returning a String identifier used for lookup.
struct User {
let name: String
}
extension User: Cachable {
var id: String {
return name
}
}Don't worry about
idcollisions between objects. The cache "namespaces" different models by type.
Now just create a FlatCache object and start reading & writing with it.
let cache = FlatCache()
let user = User(name: "ryan")
cache.set(value: user)
if let cached = cache.get(id: user.id) as User? {
print(cached.name) // "ryan"
}
FlatCacheuses the type information with theget(id:)function to lookup the appropriate object. You must type the result somehow.
One of the strengths of FlatCache is adding "listeners" to the cache to be notified when an object is changed. This powerful tool lets multiple systems respond to object changes.
let cache = FlatCache()
let user = User(name: "ryan")
let listener = MyUserListener()
cache.add(listener: listener, value: user)Now whenever user is set again in the cache, MyUserListener will be notified with the following function:
func flatCacheDidUpdate(cache: FlatCache, update: FlatCache.Update) {
switch update {
case .item(let item):
// just a single object updated
case .list:
// a list of subscribed objects updated
}
}
FlatCachecoalesces so only a single event is delivered when something changes, no matter if an update has just a single object or hundreds.
- Code used and inspired from Soroush Khanlou's The Flat Cache
- Created with ❤️ by Ryan Nystrom