2011-09-16 17:47:21 +02:00
|
|
|
// Copyright 2011 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.
|
|
|
|
|
2012-01-12 02:31:45 +01:00
|
|
|
// +build plan9
|
|
|
|
|
2011-09-16 17:47:21 +02:00
|
|
|
package time
|
|
|
|
|
2012-03-02 21:01:37 +01:00
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"syscall"
|
|
|
|
)
|
2012-01-12 02:31:45 +01:00
|
|
|
|
2011-10-27 01:57:58 +02:00
|
|
|
// for testing: whatever interrupts a sleep
|
|
|
|
func interrupt() {
|
|
|
|
// cannot predict pid, don't want to kill group
|
|
|
|
}
|
2012-01-12 02:31:45 +01:00
|
|
|
|
|
|
|
// readFile reads and returns the content of the named file.
|
|
|
|
// It is a trivial implementation of ioutil.ReadFile, reimplemented
|
|
|
|
// here to avoid depending on io/ioutil or os.
|
|
|
|
func readFile(name string) ([]byte, error) {
|
|
|
|
f, err := syscall.Open(name, syscall.O_RDONLY)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
defer syscall.Close(f)
|
|
|
|
var (
|
|
|
|
buf [4096]byte
|
|
|
|
ret []byte
|
|
|
|
n int
|
|
|
|
)
|
|
|
|
for {
|
|
|
|
n, err = syscall.Read(f, buf[:])
|
|
|
|
if n > 0 {
|
|
|
|
ret = append(ret, buf[:n]...)
|
|
|
|
}
|
|
|
|
if n == 0 || err != nil {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return ret, err
|
|
|
|
}
|
2012-03-02 21:01:37 +01:00
|
|
|
|
|
|
|
func open(name string) (uintptr, error) {
|
|
|
|
fd, err := syscall.Open(name, syscall.O_RDONLY)
|
|
|
|
if err != nil {
|
|
|
|
return 0, err
|
|
|
|
}
|
|
|
|
return uintptr(fd), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func closefd(fd uintptr) {
|
|
|
|
syscall.Close(int(fd))
|
|
|
|
}
|
|
|
|
|
|
|
|
func preadn(fd uintptr, buf []byte, off int) error {
|
2016-07-22 20:15:38 +02:00
|
|
|
whence := seekStart
|
2012-03-02 21:01:37 +01:00
|
|
|
if off < 0 {
|
2016-07-22 20:15:38 +02:00
|
|
|
whence = seekEnd
|
2012-03-02 21:01:37 +01:00
|
|
|
}
|
|
|
|
if _, err := syscall.Seek(int(fd), int64(off), whence); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
for len(buf) > 0 {
|
|
|
|
m, err := syscall.Read(int(fd), buf)
|
|
|
|
if m <= 0 {
|
|
|
|
if err == nil {
|
|
|
|
return errors.New("short read")
|
|
|
|
}
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
buf = buf[m:]
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|