mirror of
https://github.com/anchore/syft.git
synced 2025-11-17 16:33:21 +01:00
46 lines
927 B
Go
46 lines
927 B
Go
package internal
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
"io"
|
|
"io/fs"
|
|
"os"
|
|
|
|
"github.com/anchore/syft/internal/log"
|
|
)
|
|
|
|
// CloseAndLogError closes the given io.Closer and reports any errors found as a warning in the log
|
|
func CloseAndLogError(closer io.Closer, location string) {
|
|
if err := closer.Close(); err != nil {
|
|
// suppress "file already closed" log messages
|
|
if errors.Is(err, fs.ErrClosed) {
|
|
return
|
|
}
|
|
log.Debugf("unable to close file for location=%q: %+v", location, err)
|
|
}
|
|
}
|
|
|
|
type ErrPath struct {
|
|
Context string
|
|
Path string
|
|
Err error
|
|
}
|
|
|
|
func (e ErrPath) Error() string {
|
|
return fmt.Sprintf("%s unable to observe contents of %+v: %v", e.Context, e.Path, e.Err)
|
|
}
|
|
|
|
func IsErrPath(err error) bool {
|
|
var pathErr ErrPath
|
|
return errors.As(err, &pathErr)
|
|
}
|
|
|
|
func IsErrPathPermission(err error) bool {
|
|
var pathErr ErrPath
|
|
if errors.As(err, &pathErr) {
|
|
return os.IsPermission(pathErr.Err)
|
|
}
|
|
return false
|
|
}
|