Skip to content

A simple cache that can hold anything, including Swift items

License

Notifications You must be signed in to change notification settings

nuudles/CacheIsKing

Repository files navigation

CacheIsKing

CacheIsKing is a simple cache that allows you to store any item, including objects, pure Swift structs, enums (with associated values), etc. Simply put, it's designed to act like an NSCache for everything, including Swift variables.

Features

  • Simply set, get, and remove items based on any key that is Hashable
  • Remove items for any key that matches a filter
  • The cache is cleared when the app receives a memory warning
  • Similar to NSCache, the cache is cleared when the app enters the background
  • Subscripts are supported for String, Int, and Float keys
  • item(for:) uses generics so you don't have to cast the return value when the type is inferred correctly
  • Similar to NSCache, the cache can have a countLimit set to ensure that the cache doesn't get too large

Requirements

  • iOS 8.0+
  • tvOS 9.0+
  • Xcode 7+

Installation using CocoaPods

CocoaPods is a dependency manager for Cocoa projects.

Because CacheIsKing is written in Swift, you must use frameworks.

To integrate CacheIsKing into your Xcode project using CocoaPods, specify it in your Podfile:

source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '8.0'
use_frameworks!

pod 'CacheIsKing'

Then, run the following command:

$ pod install

Installation using Carthage

Add this to your Cartfile:

github "nuudles/CacheIsKing"

Usage

Simply use the KingCache class similar to how you'd use a NSCache. Using the setItem and itemForKey methods allow you to use type inference to get the values you want.

let cache = KingCache()
cache.set(item: 123, for: "123")

if let item: Int = cache.item(for: 456) {
	doSomethingWithItem(item)
}

You can also use subscripts to set/get items from the cache. Unfortunately since Swift doesn't support subscript methods with generics yet, you'll have to cast your items as necessary. Also currently only String, Int, and Float keys are supported:

let cache = KingCache()
cache["123"] = 123

if let item = cache[456] as? Int {
	doSomethingWithItem(item)
}

The KingCache also has a countLimit property, which allows you to set the maximum number of items in the cache. It currently evicts randomly until the countLimit is met.

let cache = KingCache()
cache.countLimit = 2

cache[123] = 123
cache[234] = 234
cache[345] = 345

print("\(cache.count)") // shows a count of 2

TODO

  • Refine eviction algorithm (currently evicts randomly)
  • Update with better subscript support once Swift supports subscripts with generics

About

A simple cache that can hold anything, including Swift items

Resources

License

Stars

Watchers

Forks

Packages

No packages published