mirror of
https://github.com/octoleo/restic.git
synced 2025-01-04 07:37:57 +00:00
internal: check error before deferring file Close()
If there is an error, file will be `nil`. We should check the returned error before deferring file `Close()`.
This commit is contained in:
parent
a0966e1d1d
commit
c2ff7150aa
internal
@ -210,10 +210,10 @@ func updateNodeContent(node *restic.Node, results []saveResult) error {
|
|||||||
// Save for each chunk.
|
// Save for each chunk.
|
||||||
func (arch *Archiver) SaveFile(ctx context.Context, p *restic.Progress, node *restic.Node) (*restic.Node, error) {
|
func (arch *Archiver) SaveFile(ctx context.Context, p *restic.Progress, node *restic.Node) (*restic.Node, error) {
|
||||||
file, err := fs.Open(node.Path)
|
file, err := fs.Open(node.Path)
|
||||||
defer file.Close()
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return node, errors.Wrap(err, "Open")
|
return node, errors.Wrap(err, "Open")
|
||||||
}
|
}
|
||||||
|
defer file.Close()
|
||||||
|
|
||||||
debug.RunHook("archiver.SaveFile", node.Path)
|
debug.RunHook("archiver.SaveFile", node.Path)
|
||||||
|
|
||||||
|
@ -243,11 +243,10 @@ func (node Node) createFileAt(ctx context.Context, path string, repo Repository,
|
|||||||
}
|
}
|
||||||
|
|
||||||
f, err := fs.OpenFile(path, os.O_CREATE|os.O_WRONLY|os.O_TRUNC, 0600)
|
f, err := fs.OpenFile(path, os.O_CREATE|os.O_WRONLY|os.O_TRUNC, 0600)
|
||||||
defer f.Close()
|
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return errors.Wrap(err, "OpenFile")
|
return errors.Wrap(err, "OpenFile")
|
||||||
}
|
}
|
||||||
|
defer f.Close()
|
||||||
|
|
||||||
var buf []byte
|
var buf []byte
|
||||||
for _, id := range node.Content {
|
for _, id := range node.Content {
|
||||||
|
@ -94,8 +94,8 @@ func Random(seed, count int) []byte {
|
|||||||
// SetupTarTestFixture extracts the tarFile to outputDir.
|
// SetupTarTestFixture extracts the tarFile to outputDir.
|
||||||
func SetupTarTestFixture(t testing.TB, outputDir, tarFile string) {
|
func SetupTarTestFixture(t testing.TB, outputDir, tarFile string) {
|
||||||
input, err := os.Open(tarFile)
|
input, err := os.Open(tarFile)
|
||||||
defer input.Close()
|
|
||||||
OK(t, err)
|
OK(t, err)
|
||||||
|
defer input.Close()
|
||||||
|
|
||||||
var rd io.Reader
|
var rd io.Reader
|
||||||
switch filepath.Ext(tarFile) {
|
switch filepath.Ext(tarFile) {
|
||||||
|
Loading…
Reference in New Issue
Block a user