Use type switch for syscallErr

This commit is contained in:
Elara 2023-03-25 16:03:56 -07:00
parent 6667ba576c
commit ee5cb174fb

View File

@ -11,41 +11,46 @@ func syscallErr(err error) syscall.Errno {
return 0 return 0
} }
switch err { switch err := err.(type) {
case blefs.FSError{0x02}: // filesystem error case blefs.FSError:
switch err.Code {
case 0x02: // filesystem error
return syscall.EIO // TODO return syscall.EIO // TODO
case blefs.FSError{0x05}: // read-only filesystem case 0x05: // read-only filesystem
return syscall.EROFS return syscall.EROFS
case blefs.FSError{0x03}: // no such file case 0x03: // no such file
return syscall.ENOENT return syscall.ENOENT
case blefs.FSError{0x04}: // protocol error case 0x04: // protocol error
return syscall.EPROTO return syscall.EPROTO
case blefs.FSError{-5}: // input/output error case -5: // input/output error
return syscall.EIO return syscall.EIO
case blefs.FSError{-84}: // filesystem is corrupted case -84: // filesystem is corrupted
return syscall.ENOTRECOVERABLE // TODO return syscall.ENOTRECOVERABLE // TODO
case blefs.FSError{-2}: // no such directory entry case -2: // no such directory entry
return syscall.ENOENT return syscall.ENOENT
case blefs.FSError{-17}: // entry already exists case -17: // entry already exists
return syscall.EEXIST return syscall.EEXIST
case blefs.FSError{-20}: // entry is not a directory case -20: // entry is not a directory
return syscall.ENOTDIR return syscall.ENOTDIR
case blefs.FSError{-39}: // directory is not empty case -39: // directory is not empty
return syscall.ENOTEMPTY return syscall.ENOTEMPTY
case blefs.FSError{-9}: // bad file number case -9: // bad file number
return syscall.EBADF return syscall.EBADF
case blefs.FSError{-27}: // file is too large case -27: // file is too large
return syscall.EFBIG return syscall.EFBIG
case blefs.FSError{-22}: // invalid parameter case -22: // invalid parameter
return syscall.EINVAL return syscall.EINVAL
case blefs.FSError{-28}: // no space left on device case -28: // no space left on device
return syscall.ENOSPC return syscall.ENOSPC
case blefs.FSError{-12}: // no more memory available case -12: // no more memory available
return syscall.ENOMEM return syscall.ENOMEM
case blefs.FSError{-61}: // no attr available case -61: // no attr available
return syscall.ENODATA // TODO return syscall.ENODATA // TODO
case blefs.FSError{-36}: // file name is too long case -36: // file name is too long
return syscall.ENAMETOOLONG return syscall.ENAMETOOLONG
}
default:
switch err {
case blefs.ErrFileNotExists: // file does not exist case blefs.ErrFileNotExists: // file does not exist
return syscall.ENOENT return syscall.ENOENT
case blefs.ErrFileReadOnly: // file is read only case blefs.ErrFileReadOnly: // file is read only
@ -63,6 +68,7 @@ func syscallErr(err error) syscall.Errno {
case blefs.ErrNoRemoveRoot: // refusing to remove root directory case blefs.ErrNoRemoveRoot: // refusing to remove root directory
return syscall.EPERM return syscall.EPERM
} }
}
return syscall.EIO // TODO
return syscall.EIO
} }