aboutsummaryrefslogtreecommitdiff
path: root/src/os/root_unix.go
diff options
context:
space:
mode:
authorDamien Neil <dneil@google.com>2025-03-28 16:14:43 -0700
committerGopher Robot <gobot@golang.org>2025-03-31 15:36:10 -0700
commit6d418096b2dfe2a2e47b7aa83b46748fb301e6cb (patch)
treed7740233a1d75c56e4aef697da8241396946dc43 /src/os/root_unix.go
parentc6a1dc47297a47e6111e3a00911393c355800023 (diff)
downloadgo-6d418096b2dfe2a2e47b7aa83b46748fb301e6cb.tar.xz
os: avoid symlink races in RemoveAll on Windows
Make the openat-using version of RemoveAll use the appropriate Windows equivalent, via new portable (but internal) functions added for os.Root. We could reimplement everything in terms of os.Root, but this is a bit simpler and keeps the existing code structure. Fixes #52745 Change-Id: I0eba0286398b351f2ee9abaa60e1675173988787 Reviewed-on: https://go-review.googlesource.com/c/go/+/661575 Reviewed-by: Alan Donovan <adonovan@google.com> Auto-Submit: Damien Neil <dneil@google.com> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
Diffstat (limited to 'src/os/root_unix.go')
-rw-r--r--src/os/root_unix.go12
1 files changed, 12 insertions, 0 deletions
diff --git a/src/os/root_unix.go b/src/os/root_unix.go
index ed7a406cc7..19a84c4da0 100644
--- a/src/os/root_unix.go
+++ b/src/os/root_unix.go
@@ -219,6 +219,18 @@ func removeat(fd int, name string) error {
return e
}
+func removefileat(fd int, name string) error {
+ return ignoringEINTR(func() error {
+ return unix.Unlinkat(fd, name, 0)
+ })
+}
+
+func removedirat(fd int, name string) error {
+ return ignoringEINTR(func() error {
+ return unix.Unlinkat(fd, name, unix.AT_REMOVEDIR)
+ })
+}
+
func renameat(oldfd int, oldname string, newfd int, newname string) error {
return unix.Renameat(oldfd, oldname, newfd, newname)
}