2012-11-29 17:28:37 -08:00
|
|
|
// Copyright 2008-present Facebook. All Rights Reserved.
|
|
|
|
#ifndef STORAGE_LEVELDB_INCLUDE_TRANSACTION_LOG_ITERATOR_H_
|
|
|
|
#define STORAGE_LEVELDB_INCLUDE_TRANSACTION_LOG_ITERATOR_H_
|
|
|
|
|
|
|
|
#include "leveldb/status.h"
|
|
|
|
#include "leveldb/write_batch.h"
|
|
|
|
|
|
|
|
namespace leveldb {
|
|
|
|
|
|
|
|
|
2013-03-04 10:44:04 -08:00
|
|
|
struct BatchResult {
|
|
|
|
SequenceNumber sequence;
|
|
|
|
std::unique_ptr<WriteBatch> writeBatchPtr;
|
|
|
|
};
|
|
|
|
|
2012-11-29 17:28:37 -08:00
|
|
|
// A TransactionLogIterator is used to iterate over the Transaction's in a db.
|
|
|
|
class TransactionLogIterator {
|
|
|
|
public:
|
|
|
|
TransactionLogIterator() {}
|
|
|
|
virtual ~TransactionLogIterator() {}
|
|
|
|
|
|
|
|
// An iterator is either positioned at a WriteBatch or not valid.
|
|
|
|
// This method returns true if the iterator is valid.
|
2013-03-04 10:44:04 -08:00
|
|
|
// Can read data from a valid iterator.
|
2012-11-29 17:28:37 -08:00
|
|
|
virtual bool Valid() = 0;
|
|
|
|
|
|
|
|
// Moves the iterator to the next WriteBatch.
|
|
|
|
// REQUIRES: Valid() to be true.
|
|
|
|
virtual void Next() = 0;
|
|
|
|
|
2013-03-04 10:44:04 -08:00
|
|
|
// Return's ok if the iterator is valid.
|
|
|
|
// Return the Error when something has gone wrong.
|
2012-11-29 17:28:37 -08:00
|
|
|
virtual Status status() = 0;
|
|
|
|
|
2012-12-11 12:24:55 -08:00
|
|
|
// If valid return's the current write_batch and the sequence number of the
|
|
|
|
// latest transaction contained in the batch.
|
2013-03-04 10:44:04 -08:00
|
|
|
// ONLY use if Valid() is true and status() is OK.
|
|
|
|
virtual BatchResult GetBatch() = 0;
|
2012-11-29 17:28:37 -08:00
|
|
|
};
|
|
|
|
} // namespace leveldb
|
|
|
|
|
|
|
|
#endif // STORAGE_LEVELDB_INCLUDE_TRANSACTION_LOG_ITERATOR_H_
|