|
|
package filer2
import ( "os" "time"
"fmt" "github.com/joeslay/seaweedfs/weed/pb/filer_pb" "github.com/golang/protobuf/proto" )
func (entry *Entry) EncodeAttributesAndChunks() ([]byte, error) { message := &filer_pb.Entry{ Attributes: EntryAttributeToPb(entry), Chunks: entry.Chunks, } return proto.Marshal(message) }
func (entry *Entry) DecodeAttributesAndChunks(blob []byte) error {
message := &filer_pb.Entry{}
if err := proto.UnmarshalMerge(blob, message); err != nil { return fmt.Errorf("decoding value blob for %s: %v", entry.FullPath, err) }
entry.Attr = PbToEntryAttribute(message.Attributes)
entry.Chunks = message.Chunks
return nil }
func EntryAttributeToPb(entry *Entry) *filer_pb.FuseAttributes {
return &filer_pb.FuseAttributes{ Crtime: entry.Attr.Crtime.Unix(), Mtime: entry.Attr.Mtime.Unix(), FileMode: uint32(entry.Attr.Mode), Uid: entry.Uid, Gid: entry.Gid, Mime: entry.Mime, Collection: entry.Attr.Collection, Replication: entry.Attr.Replication, TtlSec: entry.Attr.TtlSec, UserName: entry.Attr.UserName, GroupName: entry.Attr.GroupNames, SymlinkTarget: entry.Attr.SymlinkTarget, } }
func PbToEntryAttribute(attr *filer_pb.FuseAttributes) Attr {
t := Attr{}
t.Crtime = time.Unix(attr.Crtime, 0) t.Mtime = time.Unix(attr.Mtime, 0) t.Mode = os.FileMode(attr.FileMode) t.Uid = attr.Uid t.Gid = attr.Gid t.Mime = attr.Mime t.Collection = attr.Collection t.Replication = attr.Replication t.TtlSec = attr.TtlSec t.UserName = attr.UserName t.GroupNames = attr.GroupName t.SymlinkTarget = attr.SymlinkTarget
return t }
func EqualEntry(a, b *Entry) bool { if a == b { return true } if a == nil && b != nil || a != nil && b == nil { return false } if !proto.Equal(EntryAttributeToPb(a), EntryAttributeToPb(b)) { return false } if len(a.Chunks) != len(b.Chunks) { return false }
for i := 0; i < len(a.Chunks); i++ { if !proto.Equal(a.Chunks[i], b.Chunks[i]) { return false } } return true }
|