| // 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 os |
| |
| import syscall "syscall" |
| |
| // An Error can represent any printable error condition. |
| type Error interface { |
| String() string; |
| } |
| |
| // A helper type that can be embedded or wrapped to simplify satisfying |
| // Error. |
| type ErrorString string |
| |
| func (e ErrorString) String() string { return string(e) } |
| |
| // Note: If the name of the function NewError changes, |
| // pkg/go/doc/doc.go should be adjusted since it hardwires |
| // this name in a heuristic. |
| |
| // NewError converts s to an ErrorString, which satisfies the Error interface. |
| func NewError(s string) Error { return ErrorString(s) } |
| |
| // Errno is the Unix error number. Names such as EINVAL are simple |
| // wrappers to convert the error number into an Error. |
| type Errno int64 |
| |
| func (e Errno) String() string { return syscall.Errstr(int(e)) } |
| |
| // Commonly known Unix errors. |
| var ( |
| EPERM Error = Errno(syscall.EPERM); |
| ENOENT Error = Errno(syscall.ENOENT); |
| ESRCH Error = Errno(syscall.ESRCH); |
| EINTR Error = Errno(syscall.EINTR); |
| EIO Error = Errno(syscall.EIO); |
| ENXIO Error = Errno(syscall.ENXIO); |
| E2BIG Error = Errno(syscall.E2BIG); |
| ENOEXEC Error = Errno(syscall.ENOEXEC); |
| EBADF Error = Errno(syscall.EBADF); |
| ECHILD Error = Errno(syscall.ECHILD); |
| EDEADLK Error = Errno(syscall.EDEADLK); |
| ENOMEM Error = Errno(syscall.ENOMEM); |
| EACCES Error = Errno(syscall.EACCES); |
| EFAULT Error = Errno(syscall.EFAULT); |
| EBUSY Error = Errno(syscall.EBUSY); |
| EEXIST Error = Errno(syscall.EEXIST); |
| EXDEV Error = Errno(syscall.EXDEV); |
| ENODEV Error = Errno(syscall.ENODEV); |
| ENOTDIR Error = Errno(syscall.ENOTDIR); |
| EISDIR Error = Errno(syscall.EISDIR); |
| EINVAL Error = Errno(syscall.EINVAL); |
| ENFILE Error = Errno(syscall.ENFILE); |
| EMFILE Error = Errno(syscall.EMFILE); |
| ENOTTY Error = Errno(syscall.ENOTTY); |
| EFBIG Error = Errno(syscall.EFBIG); |
| ENOSPC Error = Errno(syscall.ENOSPC); |
| ESPIPE Error = Errno(syscall.ESPIPE); |
| EROFS Error = Errno(syscall.EROFS); |
| EMLINK Error = Errno(syscall.EMLINK); |
| EPIPE Error = Errno(syscall.EPIPE); |
| EAGAIN Error = Errno(syscall.EAGAIN); |
| EDOM Error = Errno(syscall.EDOM); |
| ERANGE Error = Errno(syscall.ERANGE); |
| EADDRINUSE Error = Errno(syscall.EADDRINUSE); |
| ECONNREFUSED Error = Errno(syscall.ECONNREFUSED); |
| ENAMETOOLONG Error = Errno(syscall.ENAMETOOLONG); |
| EAFNOSUPPORT Error = Errno(syscall.EAFNOSUPPORT); |
| ) |
| |
| // PathError records an error and the operation and file path that caused it. |
| type PathError struct { |
| Op string; |
| Path string; |
| Error Error; |
| } |
| |
| func (e *PathError) String() string { return e.Op + " " + e.Path + ": " + e.Error.String() } |
| |
| // SyscallError records an error from a specific system call. |
| type SyscallError struct { |
| Syscall string; |
| Errno Errno; |
| } |
| |
| func (e *SyscallError) String() string { return e.Syscall + ": " + e.Errno.String() } |
| |
| // Note: If the name of the function NewSyscallError changes, |
| // pkg/go/doc/doc.go should be adjusted since it hardwires |
| // this name in a heuristic. |
| |
| // NewSyscallError returns, as an Error, a new SyscallError |
| // with the given system call name and error number. |
| // As a convenience, if errno is 0, NewSyscallError returns nil. |
| func NewSyscallError(syscall string, errno int) Error { |
| if errno == 0 { |
| return nil; |
| } |
| return &SyscallError{syscall, Errno(errno)}; |
| } |