forked from TrueCloudLab/restic
Use array instead of hash for backend.ID
Since backend.ID is always a slice of constant length, use an array instead of a slice. Mostly, arrays behave as slices, except that an array cannot be nil, so use `*backend.ID` insteaf of `backend.ID` in places where the absence of an ID is possible (e.g. for the Subtree of a Node, which may not present when the node is a file node). This change allows to directly use backend.ID as the the key for a map, so that arbitrary data structures (e.g. a Set implemented as a map[backend.ID]struct{}) can easily be formed.
This commit is contained in:
parent
2fa6124545
commit
5cdcc99eba
31 changed files with 244 additions and 208 deletions
16
node.go
16
node.go
|
@ -35,7 +35,7 @@ type Node struct {
|
|||
LinkTarget string `json:"linktarget,omitempty"`
|
||||
Device uint64 `json:"device,omitempty"`
|
||||
Content []backend.ID `json:"content"`
|
||||
Subtree backend.ID `json:"subtree,omitempty"`
|
||||
Subtree *backend.ID `json:"subtree,omitempty"`
|
||||
|
||||
Error string `json:"error,omitempty"`
|
||||
|
||||
|
@ -316,8 +316,18 @@ func (node Node) Equals(other Node) bool {
|
|||
if !node.sameContent(other) {
|
||||
return false
|
||||
}
|
||||
if !node.Subtree.Equal(other.Subtree) {
|
||||
return false
|
||||
if node.Subtree != nil {
|
||||
if other.Subtree == nil {
|
||||
return false
|
||||
}
|
||||
|
||||
if !node.Subtree.Equal(*other.Subtree) {
|
||||
return false
|
||||
}
|
||||
} else {
|
||||
if other.Subtree != nil {
|
||||
return false
|
||||
}
|
||||
}
|
||||
if node.Error != other.Error {
|
||||
return false
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue