mirror of
https://github.com/vbatts/go-mtree.git
synced 2024-11-25 09:35:39 +00:00
35 lines
1.2 KiB
Go
35 lines
1.2 KiB
Go
package mtree
|
|
|
|
// Check a root directory path against the DirectoryHierarchy, regarding only
|
|
// the available keywords from the list and each entry in the hierarchy.
|
|
// If keywords is nil, the check all present in the DirectoryHierarchy
|
|
//
|
|
// This is equivalent to creating a new DirectoryHierarchy with Walk(root, nil,
|
|
// keywords) and then doing a Compare(dh, newDh, keywords).
|
|
func Check(root string, dh *DirectoryHierarchy, keywords []Keyword) ([]InodeDelta, error) {
|
|
if keywords == nil {
|
|
used := dh.UsedKeywords()
|
|
newDh, err := Walk(root, nil, used)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return Compare(dh, newDh, used)
|
|
}
|
|
|
|
newDh, err := Walk(root, nil, keywords)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
// TODO: Handle tar_time, if necessary.
|
|
return Compare(dh, newDh, keywords)
|
|
}
|
|
|
|
// TarCheck is the tar equivalent of checking a file hierarchy spec against a
|
|
// tar stream to determine if files have been changed. This is precisely
|
|
// equivalent to Compare(dh, tarDH, keywords).
|
|
func TarCheck(tarDH, dh *DirectoryHierarchy, keywords []Keyword) ([]InodeDelta, error) {
|
|
if keywords == nil {
|
|
return Compare(dh, tarDH, dh.UsedKeywords())
|
|
}
|
|
return Compare(dh, tarDH, keywords)
|
|
}
|