Skip to content

🦄 TypedID -- trivial compiler-time safety for your ID types.

License

Notifications You must be signed in to change notification settings

adam-zethraeus/TypedID

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

TypedID

TypedID turns otherwise dangerously interchangeable IDs backed by common values types like String into compiler differentiated, self-documenting, types like UserID.

Add type-safety to your IDs with one trivial conformance.

Usage

  1. Add the SwiftPM dependency to your project:
.package(url: "https://github.com/adam-zethraeus/TypedID.git", from: "1.0.0")
  1. Import the library:
import TypeID
  1. Define your unique ID type:
struct UserID: TypedID {
  let raw: String
}

Working with the resulting ID type is intuitive:

let myID = UserID("usr99999")
let otherID = UserID("usr11111")

// Equatabilty
let isSameUser = myID == otherID

// Hashability
let users = Set([myID, otherID])

// Codability
let encoded = try JSONEncoder().encode(myID)
let decoded = String(data: encoded, encoding: .utf8)
// TypedID is totally transparent. Serialized values remain the same.
assert(decoded == "usr99999")

TypeID works with common ID types, including String, Int, UUID, UInt, Double — but see the conformance for Foundation's UUID if you'd like to make new types conform.

About

🦄 TypedID -- trivial compiler-time safety for your ID types.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages