mirror of
https://github.com/ceph/go-ceph
synced 2024-12-24 23:22:33 +00:00
d4079e3949
Add a Statx wrapper for ceph_statx. Add a type wrapping the statx status info that exposes the various fields from the C-struct. Add a type wrapping struct timespec, based on golang's x/sys, for the time fields in the struct. Note that the ceph struct is not the same as the linux statx struct. Signed-off-by: John Mulligan <jmulligan@redhat.com>
52 lines
965 B
Go
52 lines
965 B
Go
package cephfs
|
|
|
|
/*
|
|
#include <errno.h>
|
|
*/
|
|
import "C"
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/ceph/go-ceph/internal/errutil"
|
|
)
|
|
|
|
// revive:disable:exported Temporarily live with stuttering
|
|
|
|
// CephFSError represents an error condition returned from the CephFS APIs.
|
|
type CephFSError int
|
|
|
|
// revive:enable:exported
|
|
|
|
// Error returns the error string for the CephFSError type.
|
|
func (e CephFSError) Error() string {
|
|
errno, s := errutil.FormatErrno(int(e))
|
|
if s == "" {
|
|
return fmt.Sprintf("cephfs: ret=%d", errno)
|
|
}
|
|
return fmt.Sprintf("cephfs: ret=%d, %s", errno, s)
|
|
}
|
|
|
|
func getError(e C.int) error {
|
|
if e == 0 {
|
|
return nil
|
|
}
|
|
return CephFSError(e)
|
|
}
|
|
|
|
// Public go errors:
|
|
|
|
const (
|
|
// ErrNotConnected may be returned when client is not connected
|
|
// to a cluster.
|
|
ErrNotConnected = CephFSError(-C.ENOTCONN)
|
|
)
|
|
|
|
// Private errors:
|
|
|
|
const (
|
|
errInvalid = CephFSError(-C.EINVAL)
|
|
errNameTooLong = CephFSError(-C.ENAMETOOLONG)
|
|
errNoEntry = CephFSError(-C.ENOENT)
|
|
)
|