@ -215,12 +215,12 @@ bool TransactionLogIteratorImpl::IsBatchExpected(
}
}
void TransactionLogIteratorImpl : : UpdateCurrentWriteBatch ( const Slice & record ) {
void TransactionLogIteratorImpl : : UpdateCurrentWriteBatch ( const Slice & record ) {
WriteBatch * batch = new WriteBatch ( ) ;
std : : unique_ptr < WriteBatch > batch ( new WriteBatch ( ) ) ;
WriteBatchInternal : : SetContents ( batch , record ) ;
WriteBatchInternal : : SetContents ( batch . get ( ) , record ) ;
SequenceNumber expectedSeq = currentLastSeq_ + 1 ;
SequenceNumber expectedSeq = currentLastSeq_ + 1 ;
// If the iterator has started, then confirm that we get continuous batches
// If the iterator has started, then confirm that we get continuous batches
if ( started_ & & ! IsBatchExpected ( batch , expectedSeq ) ) {
if ( started_ & & ! IsBatchExpected ( batch . get ( ) , expectedSeq ) ) {
// Seek to the batch having expected sequence number
// Seek to the batch having expected sequence number
if ( expectedSeq < files_ - > at ( currentFileIndex_ ) - > StartSequence ( ) ) {
if ( expectedSeq < files_ - > at ( currentFileIndex_ ) - > StartSequence ( ) ) {
// Expected batch must lie in the previous log file
// Expected batch must lie in the previous log file
@ -233,12 +233,13 @@ void TransactionLogIteratorImpl::UpdateCurrentWriteBatch(const Slice& record) {
return SeekToStartSequence ( currentFileIndex_ , true ) ;
return SeekToStartSequence ( currentFileIndex_ , true ) ;
}
}
currentBatchSeq_ = WriteBatchInternal : : Sequence ( batch ) ;
currentBatchSeq_ = WriteBatchInternal : : Sequence ( batch . get ( ) ) ;
currentLastSeq_ = currentBatchSeq_ + WriteBatchInternal : : Count ( batch ) - 1 ;
currentLastSeq_ = currentBatchSeq_ +
WriteBatchInternal : : Count ( batch . get ( ) ) - 1 ;
// currentBatchSeq_ can only change here
// currentBatchSeq_ can only change here
assert ( currentLastSeq_ < = dbimpl_ - > GetLatestSequenceNumber ( ) ) ;
assert ( currentLastSeq_ < = dbimpl_ - > GetLatestSequenceNumber ( ) ) ;
currentBatch_ . reset ( batch ) ;
currentBatch_ = move ( batch ) ;
isValid_ = true ;
isValid_ = true ;
currentStatus_ = Status : : OK ( ) ;
currentStatus_ = Status : : OK ( ) ;
}
}