needle_types.go 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. package types
  2. import (
  3. "fmt"
  4. "strconv"
  5. "github.com/seaweedfs/seaweedfs/weed/util"
  6. )
  7. type Offset struct {
  8. OffsetHigher
  9. OffsetLower
  10. }
  11. type Size int32
  12. func (s Size) IsDeleted() bool {
  13. return s < 0 || s == TombstoneFileSize
  14. }
  15. func (s Size) IsValid() bool {
  16. return s > 0 && s != TombstoneFileSize
  17. }
  18. type OffsetLower struct {
  19. b3 byte
  20. b2 byte
  21. b1 byte
  22. b0 byte // the smaller byte
  23. }
  24. type Cookie uint32
  25. const (
  26. SizeSize = 4 // uint32 size
  27. NeedleHeaderSize = CookieSize + NeedleIdSize + SizeSize
  28. DataSizeSize = 4
  29. NeedleMapEntrySize = NeedleIdSize + OffsetSize + SizeSize
  30. TimestampSize = 8 // int64 size
  31. NeedlePaddingSize = 8
  32. TombstoneFileSize = Size(-1)
  33. CookieSize = 4
  34. )
  35. func CookieToBytes(bytes []byte, cookie Cookie) {
  36. util.Uint32toBytes(bytes, uint32(cookie))
  37. }
  38. func Uint32ToCookie(cookie uint32) Cookie {
  39. return Cookie(cookie)
  40. }
  41. func BytesToCookie(bytes []byte) Cookie {
  42. return Cookie(util.BytesToUint32(bytes[0:4]))
  43. }
  44. func ParseCookie(cookieString string) (Cookie, error) {
  45. cookie, err := strconv.ParseUint(cookieString, 16, 32)
  46. if err != nil {
  47. return 0, fmt.Errorf("needle cookie %s format error: %v", cookieString, err)
  48. }
  49. return Cookie(cookie), nil
  50. }
  51. func BytesToSize(bytes []byte) Size {
  52. return Size(util.BytesToUint32(bytes))
  53. }
  54. func SizeToBytes(bytes []byte, size Size) {
  55. util.Uint32toBytes(bytes, uint32(size))
  56. }