Skip to content

Commit

Permalink
engine: factor out unsafeNextVersion
Browse files Browse the repository at this point in the history
To address cockroachdb#20554, we'll need to use this in more places.

Release note: None
  • Loading branch information
tbg committed Dec 24, 2017
1 parent ed342d1 commit 68b8e5d
Showing 1 changed file with 27 additions and 13 deletions.
40 changes: 27 additions & 13 deletions pkg/storage/engine/mvcc.go
Original file line number Diff line number Diff line change
Expand Up @@ -1844,6 +1844,24 @@ func MVCCResolveWriteIntentUsingIter(
intent, iterAndBuf.buf)
}

// unsafeNextVersion positions the iterator at the successor to latestKey. If this value
// exists and is a version of the same key, returns the UnsafeKey() and UnsafeValue() of that
// key-value pair along with `true`.
func unsafeNextVersion(iter Iterator, latestKey MVCCKey) (MVCCKey, []byte, bool, error) {
// Compute the next possible mvcc value for this key.
nextKey := latestKey.Next()
iter.Seek(nextKey)

if ok, err := iter.Valid(); err != nil || !ok || !iter.UnsafeKey().Key.Equal(latestKey.Key) {
return MVCCKey{}, nil, false /* never ok */, err
}
unsafeKey := iter.UnsafeKey()
if !unsafeKey.IsValue() {
return MVCCKey{}, nil, false, errors.Errorf("expected an MVCC value key: %s", unsafeKey)
}
return unsafeKey, iter.UnsafeValue(), true, nil
}

func mvccResolveWriteIntent(
ctx context.Context,
engine ReadWriter,
Expand Down Expand Up @@ -2026,14 +2044,14 @@ func mvccResolveWriteIntent(
return err
}

// Compute the next possible mvcc value for this key.
nextKey := latestKey.Next()
iter.Seek(nextKey)

// If there is no other version, we should just clean up the key entirely.
if ok, err := iter.Valid(); err != nil {
unsafeNextKey, unsafeNextValue, ok, err := unsafeNextVersion(iter, latestKey)
if err != nil {
return err
} else if !ok || !iter.UnsafeKey().Key.Equal(intent.Key) {
}
iter = nil // prevent accidental use below

if !ok {
// If there is no other version, we should just clean up the key entirely.
if err = engine.Clear(metaKey); err != nil {
return err
}
Expand All @@ -2044,12 +2062,8 @@ func mvccResolveWriteIntent(
return nil
}

unsafeIterKey := iter.UnsafeKey()
if !unsafeIterKey.IsValue() {
return errors.Errorf("expected an MVCC value key: %s", unsafeIterKey)
}
// Get the bytes for the next version so we have size for stat counts.
valueSize := int64(len(iter.UnsafeValue()))
valueSize := int64(len(unsafeNextValue))
// Update the keyMetadata with the next version.
buf.newMeta = enginepb.MVCCMetadata{
Deleted: valueSize == 0,
Expand All @@ -2065,7 +2079,7 @@ func mvccResolveWriteIntent(
// Update stat counters with older version.
if ms != nil {
ms.Add(updateStatsOnAbort(intent.Key, origMetaKeySize, origMetaValSize,
metaKeySize, metaValSize, meta, &buf.newMeta, unsafeIterKey.Timestamp.WallTime,
metaKeySize, metaValSize, meta, &buf.newMeta, unsafeNextKey.Timestamp.WallTime,
intent.Txn.Timestamp.WallTime))
}

Expand Down

0 comments on commit 68b8e5d

Please sign in to comment.