aboutsummaryrefslogtreecommitdiff
path: root/weed/filer
diff options
context:
space:
mode:
Diffstat (limited to 'weed/filer')
-rw-r--r--weed/filer/entry.go60
-rw-r--r--weed/filer/entry_codec.go23
2 files changed, 38 insertions, 45 deletions
diff --git a/weed/filer/entry.go b/weed/filer/entry.go
index b7c8370e6..ede58a384 100644
--- a/weed/filer/entry.go
+++ b/weed/filer/entry.go
@@ -42,6 +42,7 @@ type Entry struct {
HardLinkId HardLinkId
HardLinkCounter int32
Content []byte
+ Remote *filer_pb.Entry_Remote
}
func (entry *Entry) Size() uint64 {
@@ -60,16 +61,34 @@ func (entry *Entry) ToProtoEntry() *filer_pb.Entry {
if entry == nil {
return nil
}
- return &filer_pb.Entry{
- Name: entry.FullPath.Name(),
- IsDirectory: entry.IsDirectory(),
- Attributes: EntryAttributeToPb(entry),
- Chunks: entry.Chunks,
- Extended: entry.Extended,
- HardLinkId: entry.HardLinkId,
- HardLinkCounter: entry.HardLinkCounter,
- Content: entry.Content,
+ message := &filer_pb.Entry{}
+ message.Name = entry.FullPath.Name()
+ entry.ToExistingProtoEntry(message)
+ return message
+}
+
+func (entry *Entry) ToExistingProtoEntry(message *filer_pb.Entry) {
+ if entry == nil {
+ return
}
+ message.IsDirectory = entry.IsDirectory()
+ message.Attributes = EntryAttributeToPb(entry)
+ message.Chunks = entry.Chunks
+ message.Extended = entry.Extended
+ message.HardLinkId = entry.HardLinkId
+ message.HardLinkCounter = entry.HardLinkCounter
+ message.Content = entry.Content
+ message.Remote = entry.Remote
+}
+
+func FromPbEntryToExistingEntry(message *filer_pb.Entry, fsEntry *Entry) {
+ fsEntry.Attr = PbToEntryAttribute(message.Attributes)
+ fsEntry.Chunks = message.Chunks
+ fsEntry.Extended = message.Extended
+ fsEntry.HardLinkId = HardLinkId(message.HardLinkId)
+ fsEntry.HardLinkCounter = message.HardLinkCounter
+ fsEntry.Content = message.Content
+ fsEntry.Remote = message.Remote
}
func (entry *Entry) ToProtoFullEntry() *filer_pb.FullEntry {
@@ -83,26 +102,11 @@ func (entry *Entry) ToProtoFullEntry() *filer_pb.FullEntry {
}
}
-func (entry *Entry) Clone() *Entry {
- return &Entry{
- FullPath: entry.FullPath,
- Attr: entry.Attr,
- Chunks: entry.Chunks,
- Extended: entry.Extended,
- HardLinkId: entry.HardLinkId,
- HardLinkCounter: entry.HardLinkCounter,
- }
-}
-
func FromPbEntry(dir string, entry *filer_pb.Entry) *Entry {
- return &Entry{
- FullPath: util.NewFullPath(dir, entry.Name),
- Attr: PbToEntryAttribute(entry.Attributes),
- Chunks: entry.Chunks,
- HardLinkId: HardLinkId(entry.HardLinkId),
- HardLinkCounter: entry.HardLinkCounter,
- Content: entry.Content,
- }
+ t := &Entry{}
+ t.FullPath = util.NewFullPath(dir, entry.Name)
+ FromPbEntryToExistingEntry(entry, t)
+ return t
}
func maxUint64(x, y uint64) uint64 {
diff --git a/weed/filer/entry_codec.go b/weed/filer/entry_codec.go
index 4c613f068..55c937b39 100644
--- a/weed/filer/entry_codec.go
+++ b/weed/filer/entry_codec.go
@@ -12,14 +12,8 @@ import (
)
func (entry *Entry) EncodeAttributesAndChunks() ([]byte, error) {
- message := &filer_pb.Entry{
- Attributes: EntryAttributeToPb(entry),
- Chunks: entry.Chunks,
- Extended: entry.Extended,
- HardLinkId: entry.HardLinkId,
- HardLinkCounter: entry.HardLinkCounter,
- Content: entry.Content,
- }
+ message := &filer_pb.Entry{}
+ entry.ToExistingProtoEntry(message)
return proto.Marshal(message)
}
@@ -31,15 +25,7 @@ func (entry *Entry) DecodeAttributesAndChunks(blob []byte) error {
return fmt.Errorf("decoding value blob for %s: %v", entry.FullPath, err)
}
- entry.Attr = PbToEntryAttribute(message.Attributes)
-
- entry.Extended = message.Extended
-
- entry.Chunks = message.Chunks
-
- entry.HardLinkId = message.HardLinkId
- entry.HardLinkCounter = message.HardLinkCounter
- entry.Content = message.Content
+ FromPbEntryToExistingEntry(message, entry)
return nil
}
@@ -129,6 +115,9 @@ func EqualEntry(a, b *Entry) bool {
if !bytes.Equal(a.Content, b.Content) {
return false
}
+ if !proto.Equal(a.Remote, b.Remote) {
+ return false
+ }
return true
}