mirror of
https://github.com/garethgeorge/backrest.git
synced 2025-12-12 08:45:38 +00:00
78 lines
1.4 KiB
Go
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,
|
|
}
|
|
}
|