提交 5ead2a9f 作者: Jeromy

overwrite optimization for dagmodifier

上级 370285fc
...@@ -63,7 +63,12 @@ func (dm *DagModifier) WriteAt(b []byte, offset int64) (int, error) { ...@@ -63,7 +63,12 @@ func (dm *DagModifier) WriteAt(b []byte, offset int64) (int, error) {
// TODO: this is currently VERY inneficient // TODO: this is currently VERY inneficient
// each write that happens at an offset other than the current one causes a // each write that happens at an offset other than the current one causes a
// flush to disk, and dag rewrite // flush to disk, and dag rewrite
if uint64(offset) != dm.curWrOff { if offset == int64(dm.writeStart) && dm.wrBuf != nil {
// If we would overwrite the previous write
if len(b) >= dm.wrBuf.Len() {
dm.wrBuf.Reset()
}
} else if uint64(offset) != dm.curWrOff {
size, err := dm.Size() size, err := dm.Size()
if err != nil { if err != nil {
return 0, err return 0, err
...@@ -242,6 +247,7 @@ func (dm *DagModifier) modifyDag(node *mdag.Node, offset uint64, data io.Reader) ...@@ -242,6 +247,7 @@ func (dm *DagModifier) modifyDag(node *mdag.Node, offset uint64, data io.Reader)
var cur uint64 var cur uint64
var done bool var done bool
for i, bs := range f.GetBlocksizes() { for i, bs := range f.GetBlocksizes() {
// We found the correct child to write into
if cur+bs > offset { if cur+bs > offset {
child, err := node.Links[i].GetNode(dm.dagserv) child, err := node.Links[i].GetNode(dm.dagserv)
if err != nil { if err != nil {
...@@ -256,6 +262,7 @@ func (dm *DagModifier) modifyDag(node *mdag.Node, offset uint64, data io.Reader) ...@@ -256,6 +262,7 @@ func (dm *DagModifier) modifyDag(node *mdag.Node, offset uint64, data io.Reader)
node.Links[i].Hash = mh.Multihash(k) node.Links[i].Hash = mh.Multihash(k)
if sdone { if sdone {
// No more bytes to write!
done = true done = true
break break
} }
......
...@@ -314,7 +314,6 @@ func TestMultiWriteCoal(t *testing.T) { ...@@ -314,7 +314,6 @@ func TestMultiWriteCoal(t *testing.T) {
u.NewTimeSeededRand().Read(data) u.NewTimeSeededRand().Read(data)
for i := 0; i < len(data); i++ { for i := 0; i < len(data); i++ {
log.Error(i)
n, err := dagmod.WriteAt(data[:i+1], 0) n, err := dagmod.WriteAt(data[:i+1], 0)
if err != nil { if err != nil {
fmt.Println("FAIL AT ", i) fmt.Println("FAIL AT ", i)
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论