Skip to content

Commit

Permalink
e3: don't loose nil-value in reconstitution (#7117)
Browse files Browse the repository at this point in the history
  • Loading branch information
AskAlexSharov authored Mar 16, 2023
1 parent 157a380 commit 60fb9c1
Showing 1 changed file with 15 additions and 3 deletions.
18 changes: 15 additions & 3 deletions eth/stagedsync/exec3.go
Original file line number Diff line number Diff line change
Expand Up @@ -1213,7 +1213,11 @@ func reconstituteStep(last bool,
}
lastKey = append(lastKey[:0], k[:len(k)-8]...)
}
lastVal = append(lastVal[:0], v...)
if v == nil { // `nil` value means delete, `empty value []byte{}` means empty value
lastVal = nil
} else {
lastVal = append(lastVal[:0], v...)
}
return nil
}, etl.TransformArgs{}); err != nil {
return err
Expand Down Expand Up @@ -1241,7 +1245,11 @@ func reconstituteStep(last bool,
}
lastKey = append(lastKey[:0], k[:len(k)-8]...)
}
lastVal = append(lastVal[:0], v...)
if v == nil {
lastVal = nil
} else {
lastVal = append(lastVal[:0], v...)
}
return nil
}, etl.TransformArgs{}); err != nil {
return err
Expand Down Expand Up @@ -1269,7 +1277,11 @@ func reconstituteStep(last bool,
}
lastKey = append(lastKey[:0], k[:len(k)-8]...)
}
lastVal = append(lastVal[:0], v...)
if v == nil {
lastVal = nil
} else {
lastVal = append(lastVal[:0], v...)
}
return nil
}, etl.TransformArgs{}); err != nil {
return err
Expand Down

0 comments on commit 60fb9c1

Please sign in to comment.