k3s/vendor/github.com/Microsoft/hcsshim/internal/wclayer/layerexists.go

34 lines
807 B
Go
Raw Normal View History

2019-01-12 04:58:27 +00:00
package wclayer
import (
"github.com/Microsoft/hcsshim/internal/hcserror"
"github.com/sirupsen/logrus"
)
// LayerExists will return true if a layer with the given id exists and is known
// to the system.
2019-07-10 00:29:38 +00:00
func LayerExists(path string) (_ bool, err error) {
title := "hcsshim::LayerExists"
fields := logrus.Fields{
"path": path,
}
logrus.WithFields(fields).Debug(title)
defer func() {
if err != nil {
fields[logrus.ErrorKey] = err
logrus.WithFields(fields).Error(err)
} else {
logrus.WithFields(fields).Debug(title + " - succeeded")
}
}()
2019-01-12 04:58:27 +00:00
// Call the procedure itself.
var exists uint32
2019-07-10 00:29:38 +00:00
err = layerExists(&stdDriverInfo, path, &exists)
2019-01-12 04:58:27 +00:00
if err != nil {
2019-07-10 00:29:38 +00:00
return false, hcserror.New(err, title+" - failed", "")
2019-01-12 04:58:27 +00:00
}
2019-07-10 00:29:38 +00:00
fields["layer-exists"] = exists != 0
2019-01-12 04:58:27 +00:00
return exists != 0, nil
}