2011-12-15 07:12:03 +00:00
|
|
|
// 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.
|
|
|
|
|
|
|
|
package syscall
|
|
|
|
|
2019-09-06 18:12:46 +00:00
|
|
|
import "internal/oserror"
|
|
|
|
|
2011-12-15 07:12:03 +00:00
|
|
|
// An Errno is an unsigned number describing an error condition.
|
|
|
|
// It implements the error interface. The zero Errno is by convention
|
|
|
|
// a non-error, so code to convert from Errno to error should use:
|
|
|
|
// err = nil
|
|
|
|
// if errno != 0 {
|
|
|
|
// err = errno
|
|
|
|
// }
|
|
|
|
type Errno uintptr
|
|
|
|
|
|
|
|
func (e Errno) Error() string {
|
|
|
|
return Errstr(int(e))
|
|
|
|
}
|
|
|
|
|
2019-09-06 18:12:46 +00:00
|
|
|
func (e Errno) Is(target error) bool {
|
|
|
|
switch target {
|
|
|
|
case oserror.ErrPermission:
|
|
|
|
return e == EACCES || e == EPERM
|
|
|
|
case oserror.ErrExist:
|
|
|
|
return e == EEXIST || e == ENOTEMPTY
|
|
|
|
case oserror.ErrNotExist:
|
|
|
|
return e == ENOENT
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2011-12-15 07:12:03 +00:00
|
|
|
func (e Errno) Temporary() bool {
|
2018-09-24 21:46:21 +00:00
|
|
|
return e == EINTR || e == EMFILE || e.Timeout()
|
2011-12-15 07:12:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (e Errno) Timeout() bool {
|
|
|
|
return e == EAGAIN || e == EWOULDBLOCK || e == ETIMEDOUT
|
|
|
|
}
|