diff options
author | Sebastian Lackner | 2017-11-29 12:23:40 +0100 |
---|---|---|
committer | Sebastian Lackner | 2017-11-29 12:41:23 +0100 |
commit | 0f44c617d01f3e203933459be5fb64c1904d40b6 (patch) | |
tree | 14e266ea6e8218d04c58b6dd622ab68810792550 /internal/syscallcompat/sys_linux.go | |
parent | 5d44a31b412e3db07313d3f7e839e2838cff67c0 (diff) |
syscallcompat: Introduce unlinkat syscall with flags argument
Diffstat (limited to 'internal/syscallcompat/sys_linux.go')
-rw-r--r-- | internal/syscallcompat/sys_linux.go | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/internal/syscallcompat/sys_linux.go b/internal/syscallcompat/sys_linux.go index 277015e..0e9d6ac 100644 --- a/internal/syscallcompat/sys_linux.go +++ b/internal/syscallcompat/sys_linux.go @@ -54,9 +54,19 @@ func Renameat(olddirfd int, oldpath string, newdirfd int, newpath string) (err e return syscall.Renameat(olddirfd, oldpath, newdirfd, newpath) } -// Unlinkat wraps the Unlinkat syscall. -func Unlinkat(dirfd int, path string) error { - return syscall.Unlinkat(dirfd, path) +// Unlinkat syscall. In old versions the 'flags' argument was missing, so +// manually call it by using the corresponding syscall number. +func Unlinkat(dirfd int, path string, flags int) (err error) { + var _p0 *byte + _p0, err = syscall.BytePtrFromString(path) + if err != nil { + return + } + _, _, e1 := syscall.Syscall(syscall.SYS_UNLINKAT, uintptr(dirfd), uintptr(unsafe.Pointer(_p0)), uintptr(flags)) + if e1 != 0 { + err = e1 + } + return } // Mknodat wraps the Mknodat syscall. |