forked from TrueCloudLab/restic
add progress
This commit is contained in:
parent
0e66a66bce
commit
3ac1d0e4d1
2 changed files with 48 additions and 3 deletions
|
@ -639,6 +639,11 @@ func (c *Checker) OrphanedPacks() backend.IDs {
|
||||||
return c.orphanedPacks
|
return c.orphanedPacks
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// CountPacks returns the number of packs in the repository.
|
||||||
|
func (c *Checker) CountPacks() uint64 {
|
||||||
|
return uint64(len(c.packs))
|
||||||
|
}
|
||||||
|
|
||||||
// checkPack reads a pack and checks the integrity of all blobs.
|
// checkPack reads a pack and checks the integrity of all blobs.
|
||||||
func checkPack(r *repository.Repository, id backend.ID) error {
|
func checkPack(r *repository.Repository, id backend.ID) error {
|
||||||
debug.Log("Checker.checkPack", "checking pack %v", id.Str())
|
debug.Log("Checker.checkPack", "checking pack %v", id.Str())
|
||||||
|
@ -690,9 +695,12 @@ func checkPack(r *repository.Repository, id backend.ID) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
// ReadData loads all data from the repository and checks the integrity.
|
// ReadData loads all data from the repository and checks the integrity.
|
||||||
func (c *Checker) ReadData(errChan chan<- error, done <-chan struct{}) {
|
func (c *Checker) ReadData(p *restic.Progress, errChan chan<- error, done <-chan struct{}) {
|
||||||
defer close(errChan)
|
defer close(errChan)
|
||||||
|
|
||||||
|
p.Start()
|
||||||
|
defer p.Done()
|
||||||
|
|
||||||
worker := func(wg *sync.WaitGroup, in <-chan backend.ID) {
|
worker := func(wg *sync.WaitGroup, in <-chan backend.ID) {
|
||||||
defer wg.Done()
|
defer wg.Done()
|
||||||
for {
|
for {
|
||||||
|
@ -709,6 +717,7 @@ func (c *Checker) ReadData(errChan chan<- error, done <-chan struct{}) {
|
||||||
}
|
}
|
||||||
|
|
||||||
err := checkPack(c.repo, id)
|
err := checkPack(c.repo, id)
|
||||||
|
p.Report(restic.Stat{Blobs: 1})
|
||||||
if err == nil {
|
if err == nil {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,11 @@ import (
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"golang.org/x/crypto/ssh/terminal"
|
||||||
|
|
||||||
|
"github.com/restic/restic"
|
||||||
"github.com/restic/restic/checker"
|
"github.com/restic/restic/checker"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -29,6 +33,37 @@ func (cmd CmdCheck) Usage() string {
|
||||||
return "[check-options]"
|
return "[check-options]"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (cmd CmdCheck) newReadProgress(todo restic.Stat) *restic.Progress {
|
||||||
|
if !cmd.global.ShowProgress() {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
readProgress := restic.NewProgress(time.Second)
|
||||||
|
|
||||||
|
readProgress.OnUpdate = func(s restic.Stat, d time.Duration, ticker bool) {
|
||||||
|
status := fmt.Sprintf("[%s] %s %d / %d items",
|
||||||
|
formatDuration(d),
|
||||||
|
formatPercent(s.Blobs, todo.Blobs),
|
||||||
|
s.Blobs, todo.Blobs)
|
||||||
|
|
||||||
|
w, _, err := terminal.GetSize(int(os.Stdout.Fd()))
|
||||||
|
if err == nil {
|
||||||
|
if len(status) > w {
|
||||||
|
max := w - len(status) - 4
|
||||||
|
status = status[:max] + "... "
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fmt.Printf("\x1b[2K%s\r", status)
|
||||||
|
}
|
||||||
|
|
||||||
|
readProgress.OnDone = func(s restic.Stat, d time.Duration, ticker bool) {
|
||||||
|
fmt.Printf("\nduration: %s\n", formatDuration(d))
|
||||||
|
}
|
||||||
|
|
||||||
|
return readProgress
|
||||||
|
}
|
||||||
|
|
||||||
func (cmd CmdCheck) Execute(args []string) error {
|
func (cmd CmdCheck) Execute(args []string) error {
|
||||||
if len(args) != 0 {
|
if len(args) != 0 {
|
||||||
return errors.New("check has no arguments")
|
return errors.New("check has no arguments")
|
||||||
|
@ -110,11 +145,12 @@ func (cmd CmdCheck) Execute(args []string) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
if cmd.ReadData {
|
if cmd.ReadData {
|
||||||
cmd.global.Verbosef("reading all data\n")
|
cmd.global.Verbosef("Read all data\n")
|
||||||
|
|
||||||
|
p := cmd.newReadProgress(restic.Stat{Blobs: chkr.CountPacks()})
|
||||||
errChan := make(chan error)
|
errChan := make(chan error)
|
||||||
|
|
||||||
go chkr.ReadData(errChan, done)
|
go chkr.ReadData(p, errChan, done)
|
||||||
|
|
||||||
for err := range errChan {
|
for err := range errChan {
|
||||||
errorsFound = true
|
errorsFound = true
|
||||||
|
|
Loading…
Reference in a new issue