Building out schema comparison mechanism

Which has led to a new wider hashing capability for the low level API. hashing makes it very easy to determine changes quickly, without having to run comparisons to discover changes, could really speed things up moving forward.
This commit is contained in:
Dave Shanley
2022-10-08 14:09:46 -04:00
parent 7f61a7624d
commit 4b9c5fba1e
13 changed files with 1276 additions and 64 deletions

View File

@@ -22,6 +22,12 @@ type HasValueNode[T any] interface {
*T
}
// Hashable defines any struct that implements a Hash function that returns a 256SHA hash of the state of the
// representative object. Great for equality checking!
type Hashable interface {
Hash() [32]byte
}
// HasExtensions is implemented by any object that exposes extensions
type HasExtensions[T any] interface {
GetExtensions() map[KeyReference[string]]ValueReference[any]