add progress

This commit is contained in:
Alexander Neumann 2015-12-06 17:29:31 +01:00
parent 0e66a66bce
commit 3ac1d0e4d1
2 changed files with 48 additions and 3 deletions

View file

@ -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
} }

View file

@ -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