Blame vendor/golang.org/x/sys/unix/syscall_darwin.1_12.go
|
Packit |
63bb0d |
// Copyright 2019 The Go Authors. All rights reserved.
|
|
Packit |
63bb0d |
// Use of this source code is governed by a BSD-style
|
|
Packit |
63bb0d |
// license that can be found in the LICENSE file.
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
// +build darwin,go1.12,!go1.13
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
package unix
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
import (
|
|
Packit |
63bb0d |
"unsafe"
|
|
Packit |
63bb0d |
)
|
|
Packit |
63bb0d |
|
|
Packit Service |
3a6627 |
const _SYS_GETDIRENTRIES64 = 344
|
|
Packit Service |
3a6627 |
|
|
Packit |
63bb0d |
func Getdirentries(fd int, buf []byte, basep *uintptr) (n int, err error) {
|
|
Packit |
63bb0d |
// To implement this using libSystem we'd need syscall_syscallPtr for
|
|
Packit |
63bb0d |
// fdopendir. However, syscallPtr was only added in Go 1.13, so we fall
|
|
Packit |
63bb0d |
// back to raw syscalls for this func on Go 1.12.
|
|
Packit |
63bb0d |
var p unsafe.Pointer
|
|
Packit |
63bb0d |
if len(buf) > 0 {
|
|
Packit |
63bb0d |
p = unsafe.Pointer(&buf[0])
|
|
Packit |
63bb0d |
} else {
|
|
Packit |
63bb0d |
p = unsafe.Pointer(&_zero)
|
|
Packit |
63bb0d |
}
|
|
Packit Service |
3a6627 |
r0, _, e1 := Syscall6(_SYS_GETDIRENTRIES64, uintptr(fd), uintptr(p), uintptr(len(buf)), uintptr(unsafe.Pointer(basep)), 0, 0)
|
|
Packit |
63bb0d |
n = int(r0)
|
|
Packit |
63bb0d |
if e1 != 0 {
|
|
Packit |
63bb0d |
return n, errnoErr(e1)
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
return n, nil
|
|
Packit |
63bb0d |
}
|