read_callback.h 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. // Copyright (c) 2011-present, Facebook, Inc. All rights reserved.
  2. // This source code is licensed under both the GPLv2 (found in the
  3. // COPYING file in the root directory) and Apache 2.0 License
  4. // (found in the LICENSE.Apache file in the root directory).
  5. #pragma once
  6. #include "rocksdb/types.h"
  7. namespace ROCKSDB_NAMESPACE {
  8. class ReadCallback {
  9. public:
  10. ReadCallback(SequenceNumber last_visible_seq)
  11. : max_visible_seq_(last_visible_seq) {}
  12. ReadCallback(SequenceNumber last_visible_seq, SequenceNumber min_uncommitted)
  13. : max_visible_seq_(last_visible_seq), min_uncommitted_(min_uncommitted) {}
  14. virtual ~ReadCallback() {}
  15. // Will be called to see if the seq number visible; if not it moves on to
  16. // the next seq number.
  17. virtual bool IsVisibleFullCheck(SequenceNumber seq) = 0;
  18. inline bool IsVisible(SequenceNumber seq) {
  19. assert(min_uncommitted_ > 0);
  20. assert(min_uncommitted_ >= kMinUnCommittedSeq);
  21. if (seq < min_uncommitted_) { // handles seq == 0 as well
  22. assert(seq <= max_visible_seq_);
  23. return true;
  24. } else if (max_visible_seq_ < seq) {
  25. assert(seq != 0);
  26. return false;
  27. } else {
  28. assert(seq != 0); // already handled in the first if-then clause
  29. return IsVisibleFullCheck(seq);
  30. }
  31. }
  32. inline SequenceNumber max_visible_seq() { return max_visible_seq_; }
  33. // Refresh to a more recent visible seq
  34. virtual void Refresh(SequenceNumber seq) { max_visible_seq_ = seq; }
  35. protected:
  36. // The max visible seq, it is usually the snapshot but could be larger if
  37. // transaction has its own writes written to db.
  38. SequenceNumber max_visible_seq_ = kMaxSequenceNumber;
  39. // Any seq less than min_uncommitted_ is committed.
  40. const SequenceNumber min_uncommitted_ = kMinUnCommittedSeq;
  41. };
  42. } // namespace ROCKSDB_NAMESPACE