cmd/restic: Add locks to commands

This commit is contained in:
Alexander Neumann 2015-06-27 14:40:18 +02:00
parent 7d2699b429
commit 65a0def949
10 changed files with 62 additions and 0 deletions

View file

@ -220,6 +220,12 @@ func (cmd CmdBackup) Execute(args []string) error {
return err return err
} }
lock, err := restic.NewLock(repo)
defer lock.Unlock()
if err != nil {
return err
}
err = repo.LoadIndex() err = repo.LoadIndex()
if err != nil { if err != nil {
return err return err

View file

@ -34,6 +34,12 @@ func (cmd CmdCache) Execute(args []string) error {
return err return err
} }
lock, err := restic.NewLock(repo)
defer lock.Unlock()
if err != nil {
return err
}
cache, err := restic.NewCache(repo, cmd.global.CacheDir) cache, err := restic.NewCache(repo, cmd.global.CacheDir)
if err != nil { if err != nil {
return err return err

View file

@ -42,6 +42,12 @@ func (cmd CmdCat) Execute(args []string) error {
return err return err
} }
lock, err := restic.NewLock(repo)
defer lock.Unlock()
if err != nil {
return err
}
tpe := args[0] tpe := args[0]
var id backend.ID var id backend.ID

View file

@ -109,6 +109,12 @@ func (cmd CmdDump) Execute(args []string) error {
return err return err
} }
lock, err := restic.NewLock(repo)
defer lock.Unlock()
if err != nil {
return err
}
err = repo.LoadIndex() err = repo.LoadIndex()
if err != nil { if err != nil {
return err return err

View file

@ -162,6 +162,12 @@ func (c CmdFind) Execute(args []string) error {
return err return err
} }
lock, err := restic.NewLock(repo)
defer lock.Unlock()
if err != nil {
return err
}
c.pattern = args[0] c.pattern = args[0]
if c.Snapshot != "" { if c.Snapshot != "" {

View file

@ -195,6 +195,12 @@ func (cmd CmdFsck) Execute(args []string) error {
return err return err
} }
lock, err := restic.NewExclusiveLock(repo)
defer lock.Unlock()
if err != nil {
return err
}
err = repo.LoadIndex() err = repo.LoadIndex()
if err != nil { if err != nil {
return err return err

View file

@ -4,6 +4,7 @@ import (
"errors" "errors"
"fmt" "fmt"
"github.com/restic/restic"
"github.com/restic/restic/backend" "github.com/restic/restic/backend"
"github.com/restic/restic/repository" "github.com/restic/restic/repository"
) )
@ -121,6 +122,12 @@ func (cmd CmdKey) Execute(args []string) error {
return err return err
} }
lock, err := restic.NewExclusiveLock(repo)
defer lock.Unlock()
if err != nil {
return err
}
switch args[0] { switch args[0] {
case "list": case "list":
return cmd.listKeys(repo) return cmd.listKeys(repo)

View file

@ -4,6 +4,7 @@ import (
"errors" "errors"
"fmt" "fmt"
"github.com/restic/restic"
"github.com/restic/restic/backend" "github.com/restic/restic/backend"
) )
@ -35,6 +36,12 @@ func (cmd CmdList) Execute(args []string) error {
return err return err
} }
lock, err := restic.NewLock(repo)
defer lock.Unlock()
if err != nil {
return err
}
var t backend.Type var t backend.Type
switch args[0] { switch args[0] {
case "blobs": case "blobs":

View file

@ -35,6 +35,12 @@ func (cmd CmdRestore) Execute(args []string) error {
return err return err
} }
lock, err := restic.NewLock(repo)
defer lock.Unlock()
if err != nil {
return err
}
err = repo.LoadIndex() err = repo.LoadIndex()
if err != nil { if err != nil {
return err return err

View file

@ -99,6 +99,12 @@ func (cmd CmdSnapshots) Execute(args []string) error {
return err return err
} }
lock, err := restic.NewLock(repo)
defer lock.Unlock()
if err != nil {
return err
}
tab := NewTable() tab := NewTable()
tab.Header = fmt.Sprintf("%-8s %-19s %-10s %s", "ID", "Date", "Source", "Directory") tab.Header = fmt.Sprintf("%-8s %-19s %-10s %s", "ID", "Date", "Source", "Directory")
tab.RowFormat = "%-8s %-19s %-10s %s" tab.RowFormat = "%-8s %-19s %-10s %s"