From 61aaddac280087ab73d01d7ad2060bd603ab0ae8 Mon Sep 17 00:00:00 2001 From: Michael Eischer Date: Thu, 15 Aug 2024 21:17:49 +0200 Subject: [PATCH] restic: restore timestamps after extended attributes restoring the xattr containing resource forks on macOS apparently modifies the file modification timestamps. Thus, restore the timestamp after xattrs. --- changelog/unreleased/issue-4969 | 7 +++++++ internal/restic/node.go | 14 +++++++------- 2 files changed, 14 insertions(+), 7 deletions(-) create mode 100644 changelog/unreleased/issue-4969 diff --git a/changelog/unreleased/issue-4969 b/changelog/unreleased/issue-4969 new file mode 100644 index 000000000..ce76a7389 --- /dev/null +++ b/changelog/unreleased/issue-4969 @@ -0,0 +1,7 @@ +Bugfix: Correctly restore timestamp for files with resource forks on macOS + +On macOS, timestamps were incorrectly restored for files with resource forks. +This has been fixed. + +https://github.com/restic/restic/issues/4969 +https://github.com/restic/restic/pull/5006 diff --git a/internal/restic/node.go b/internal/restic/node.go index 7c1988227..6afdff64a 100644 --- a/internal/restic/node.go +++ b/internal/restic/node.go @@ -249,13 +249,6 @@ func (node Node) restoreMetadata(path string, warn func(msg string)) error { firsterr = errors.WithStack(err) } - if err := node.RestoreTimestamps(path); err != nil { - debug.Log("error restoring timestamps for dir %v: %v", path, err) - if firsterr == nil { - firsterr = err - } - } - if err := node.restoreExtendedAttributes(path); err != nil { debug.Log("error restoring extended attributes for %v: %v", path, err) if firsterr == nil { @@ -270,6 +263,13 @@ func (node Node) restoreMetadata(path string, warn func(msg string)) error { } } + if err := node.RestoreTimestamps(path); err != nil { + debug.Log("error restoring timestamps for %v: %v", path, err) + if firsterr == nil { + firsterr = err + } + } + // Moving RestoreTimestamps and restoreExtendedAttributes calls above as for readonly files in windows // calling Chmod below will no longer allow any modifications to be made on the file and the // calls above would fail.