2011-09-16 15:47:21 +00: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-13 05:11:45 +00:00
|
|
|
// +build darwin freebsd linux netbsd openbsd
|
2011-10-26 23:57:58 +00:00
|
|
|
|
2011-09-16 15:47:21 +00:00
|
|
|
package time
|
|
|
|
|
2012-03-02 20:01:37 +00:00
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"syscall"
|
|
|
|
)
|
2011-09-16 15:47:21 +00:00
|
|
|
|
2011-10-26 23:57:58 +00:00
|
|
|
// for testing: whatever interrupts a sleep
|
|
|
|
func interrupt() {
|
2011-12-13 19:16:27 +00:00
|
|
|
syscall.Kill(syscall.Getpid(), syscall.SIGCHLD)
|
2011-10-26 23:57:58 +00:00
|
|
|
}
|
2012-01-12 01:31:45 +00: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, 0)
|
|
|
|
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 20:01:37 +00:00
|
|
|
|
|
|
|
func open(name string) (uintptr, error) {
|
|
|
|
fd, err := syscall.Open(name, syscall.O_RDONLY, 0)
|
|
|
|
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 {
|
|
|
|
whence := 0
|
|
|
|
if off < 0 {
|
|
|
|
whence = 2
|
|
|
|
}
|
|
|
|
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
|
|
|
|
}
|