Files
backrest/pkg/restic/error.go
2024-05-27 10:26:18 -07:00

78 lines
1.4 KiB
Go

package restic
import (
"context"
"fmt"
"os/exec"
"strings"
)
const outputBufferLimit = 1000
type CmdError struct {
Command string
Err error
}
func (e *CmdError) Error() string {
m := fmt.Sprintf("command %q failed: %s", e.Command, e.Err.Error())
return m
}
func (e *CmdError) Unwrap() error {
return e.Err
}
func (e *CmdError) Is(target error) bool {
_, ok := target.(*CmdError)
return ok
}
// newCmdError creates a new error indicating that running a command failed.
func newCmdError(ctx context.Context, cmd *exec.Cmd, err error) *CmdError {
cerr := &CmdError{
Command: cmd.String(),
Err: err,
}
if logger := LoggerFromContext(ctx); logger != nil {
logger.Write([]byte(cerr.Error()))
}
return cerr
}
type ErrorWithOutput struct {
Err error
Output string
}
func (e *ErrorWithOutput) Error() string {
return fmt.Sprintf("%v\nOutput:\n%s", e.Err, e.Output)
}
func (e *ErrorWithOutput) Unwrap() error {
return e.Err
}
func (e *ErrorWithOutput) Is(target error) bool {
_, ok := target.(*ErrorWithOutput)
return ok
}
// newErrorWithOutput creates a new error with the given output.
func newErrorWithOutput(err error, output string) error {
firstNewLine := strings.Index(output, "\n")
if firstNewLine > 0 {
output = output[:firstNewLine]
}
if len(output) == 0 {
return err
}
return &ErrorWithOutput{
Err: err,
Output: output,
}
}