Safe Haskell | None |
---|---|
Language | Haskell2010 |
This module provides utilities which help ensure that we aren't
attempting to de-serialize data that is an older or newer version.
The WithVersion
utility wraps up a datatype along with a version
tag. This version tag can either be provided by the user
(namedVersionConfig
), or use a computed hash
(hashedVersionConfig
).
The magic here is using an SYB traversal (Data
) to get the
structure of all the data-types involved. This info is rendered to
text and hashed to yield a hash which describes it.
NOTE that this API is still quite new and so is likely to break compatibility in the future. It should also be expected that the computed hashes may change between major version bumps, though this will be minimized when directly feasible.
- newtype StoreVersion = StoreVersion {}
- data WithVersion a = WithVersion a StoreVersion
- data VersionConfig a = VersionConfig {}
- hashedVersionConfig :: String -> VersionConfig a
- namedVersionConfig :: String -> String -> VersionConfig a
- wrapVersion :: Data a => VersionConfig a -> Q Exp
- checkVersion :: Data a => VersionConfig a -> Q Exp
- data VersionCheckException = VersionCheckException {}
Documentation
newtype StoreVersion Source #
data WithVersion a Source #
Eq a => Eq (WithVersion a) Source # | |
Data a => Data (WithVersion a) Source # | |
Ord a => Ord (WithVersion a) Source # | |
Show a => Show (WithVersion a) Source # | |
Generic (WithVersion a) Source # | |
Store a => Store (WithVersion a) Source # | |
type Rep (WithVersion a) Source # | |
data VersionConfig a Source #
Configuration for the version checking of a particular type.
VersionConfig | |
|
Eq (VersionConfig a) Source # | |
Data a => Data (VersionConfig a) Source # | |
Show (VersionConfig a) Source # | |
Generic (VersionConfig a) Source # | |
type Rep (VersionConfig a) Source # | |
hashedVersionConfig :: String -> VersionConfig a Source #
namedVersionConfig :: String -> String -> VersionConfig a Source #
wrapVersion :: Data a => VersionConfig a -> Q Exp Source #
checkVersion :: Data a => VersionConfig a -> Q Exp Source #