debug/list: parallelize index loading

This commit is contained in:
Michael Eischer 2020-11-07 18:19:25 +01:00
parent 96904f8972
commit ccc84af73d
2 changed files with 2 additions and 6 deletions

View file

@ -110,10 +110,8 @@ func printPacks(ctx context.Context, repo *repository.Repository, wr io.Writer)
} }
func dumpIndexes(ctx context.Context, repo restic.Repository, wr io.Writer) error { func dumpIndexes(ctx context.Context, repo restic.Repository, wr io.Writer) error {
return repo.List(ctx, restic.IndexFile, func(id restic.ID, size int64) error { return repository.ForAllIndexes(ctx, repo, func(id restic.ID, idx *repository.Index, oldFormat bool, err error) error {
Printf("index_id: %v\n", id) Printf("index_id: %v\n", id)
idx, err := repository.LoadIndex(ctx, repo, id)
if err != nil { if err != nil {
return err return err
} }

View file

@ -60,8 +60,7 @@ func runList(cmd *cobra.Command, opts GlobalOptions, args []string) error {
case "locks": case "locks":
t = restic.LockFile t = restic.LockFile
case "blobs": case "blobs":
return repo.List(opts.ctx, restic.IndexFile, func(id restic.ID, size int64) error { return repository.ForAllIndexes(opts.ctx, repo, func(id restic.ID, idx *repository.Index, oldFormat bool, err error) error {
idx, err := repository.LoadIndex(opts.ctx, repo, id)
if err != nil { if err != nil {
return err return err
} }
@ -70,7 +69,6 @@ func runList(cmd *cobra.Command, opts GlobalOptions, args []string) error {
} }
return nil return nil
}) })
default: default:
return errors.Fatal("invalid type") return errors.Fatal("invalid type")
} }