mirror of
https://github.com/golang/go.git
synced 2025-12-08 06:10:04 +00:00
You were a useful port and you've served your purpose. Thanks for all the play. A subsequent CL will remove amd64p32 (including assembly files and toolchain bits) and remaining bits. The amd64p32 removal will be separated into its own CL in case we want to support the Linux x32 ABI in the future and want our old amd64p32 support as a starting point. Updates #30439 Change-Id: Ia3a0c7d49804adc87bf52a4dea7e3d3007f2b1cd Reviewed-on: https://go-review.googlesource.com/c/go/+/199499 Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org> Reviewed-by: Ian Lance Taylor <iant@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org>
70 lines
1.5 KiB
Go
70 lines
1.5 KiB
Go
// Copyright 2009 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
// +build aix dragonfly freebsd js,wasm linux netbsd openbsd solaris
|
|
|
|
package os
|
|
|
|
import (
|
|
"io"
|
|
"runtime"
|
|
"syscall"
|
|
)
|
|
|
|
// Auxiliary information if the File describes a directory
|
|
type dirInfo struct {
|
|
buf []byte // buffer for directory I/O
|
|
nbuf int // length of buf; return value from Getdirentries
|
|
bufp int // location of next record in buf.
|
|
}
|
|
|
|
const (
|
|
// More than 5760 to work around https://golang.org/issue/24015.
|
|
blockSize = 8192
|
|
)
|
|
|
|
func (d *dirInfo) close() {}
|
|
|
|
func (f *File) readdirnames(n int) (names []string, err error) {
|
|
// If this file has no dirinfo, create one.
|
|
if f.dirinfo == nil {
|
|
f.dirinfo = new(dirInfo)
|
|
// The buffer must be at least a block long.
|
|
f.dirinfo.buf = make([]byte, blockSize)
|
|
}
|
|
d := f.dirinfo
|
|
|
|
size := n
|
|
if size <= 0 {
|
|
size = 100
|
|
n = -1
|
|
}
|
|
|
|
names = make([]string, 0, size) // Empty with room to grow.
|
|
for n != 0 {
|
|
// Refill the buffer if necessary
|
|
if d.bufp >= d.nbuf {
|
|
d.bufp = 0
|
|
var errno error
|
|
d.nbuf, errno = f.pfd.ReadDirent(d.buf)
|
|
runtime.KeepAlive(f)
|
|
if errno != nil {
|
|
return names, wrapSyscallError("readdirent", errno)
|
|
}
|
|
if d.nbuf <= 0 {
|
|
break // EOF
|
|
}
|
|
}
|
|
|
|
// Drain the buffer
|
|
var nb, nc int
|
|
nb, nc, names = syscall.ParseDirent(d.buf[d.bufp:d.nbuf], n, names)
|
|
d.bufp += nb
|
|
n -= nc
|
|
}
|
|
if n >= 0 && len(names) == 0 {
|
|
return names, io.EOF
|
|
}
|
|
return names, nil
|
|
}
|