Quellcode durchsuchen

A number of fixes:

- Replace raw slice comparison with a call to user comparator.
  Added test for custom comparators.

- Fix end of namespace comments.

- Fixed bug in picking inputs for a level-0 compaction.

  When finding overlapping files, the covered range may expand
  as files are added to the input set.  We now correctly expand
  the range when this happens instead of continuing to use the
  old range.  For example, suppose L0 contains files with the
  following ranges:

      F1: a .. d
      F2:    c .. g
      F3:       f .. j

  and the initial compaction target is F3.  We used to search
  for range f..j which yielded {F2,F3}.  However we now expand
  the range as soon as another file is added.  In this case,
  when F2 is added, we expand the range to c..j and restart the
  search.  That picks up file F1 as well.

  This change fixes a bug related to deleted keys showing up
  incorrectly after a compaction as described in Issue 44.

(Sync with upstream @25072954)
ld
Hans Wennborg vor 13 Jahren
Ursprung
Commit
36a5f8ed7f
102 geänderte Dateien mit 258 neuen und 146 gelöschten Zeilen
  1. +1
    -1
      db/builder.cc
  2. +1
    -1
      db/builder.h
  3. +1
    -1
      db/corruption_test.cc
  4. +2
    -2
      db/db_bench.cc
  5. +2
    -2
      db/db_impl.cc
  6. +1
    -1
      db/db_impl.h
  7. +1
    -1
      db/db_iter.cc
  8. +1
    -1
      db/db_iter.h
  9. +100
    -2
      db/db_test.cc
  10. +1
    -1
      db/dbformat.cc
  11. +2
    -2
      db/dbformat.h
  12. +1
    -1
      db/dbformat_test.cc
  13. +1
    -1
      db/filename.cc
  14. +1
    -1
      db/filename.h
  15. +1
    -1
      db/filename_test.cc
  16. +2
    -2
      db/log_format.h
  17. +2
    -2
      db/log_reader.cc
  18. +2
    -2
      db/log_reader.h
  19. +2
    -2
      db/log_test.cc
  20. +2
    -2
      db/log_writer.cc
  21. +2
    -2
      db/log_writer.h
  22. +1
    -1
      db/memtable.cc
  23. +1
    -1
      db/memtable.h
  24. +2
    -2
      db/repair.cc
  25. +1
    -1
      db/skiplist.h
  26. +1
    -1
      db/skiplist_test.cc
  27. +1
    -1
      db/snapshot.h
  28. +1
    -1
      db/table_cache.cc
  29. +1
    -1
      db/table_cache.h
  30. +1
    -1
      db/version_edit.cc
  31. +1
    -1
      db/version_edit.h
  32. +1
    -1
      db/version_edit_test.cc
  33. +25
    -11
      db/version_set.cc
  34. +1
    -1
      db/version_set.h
  35. +1
    -1
      db/version_set_test.cc
  36. +2
    -2
      db/write_batch.cc
  37. +1
    -1
      db/write_batch_internal.h
  38. +1
    -1
      db/write_batch_test.cc
  39. +2
    -2
      doc/bench/db_bench_sqlite3.cc
  40. +2
    -2
      doc/bench/db_bench_tree_db.cc
  41. +2
    -2
      helpers/memenv/memenv.cc
  42. +1
    -1
      helpers/memenv/memenv.h
  43. +1
    -1
      helpers/memenv/memenv_test.cc
  44. +1
    -1
      include/leveldb/cache.h
  45. +1
    -1
      include/leveldb/comparator.h
  46. +1
    -1
      include/leveldb/db.h
  47. +1
    -1
      include/leveldb/env.h
  48. +1
    -1
      include/leveldb/iterator.h
  49. +1
    -1
      include/leveldb/options.h
  50. +1
    -1
      include/leveldb/slice.h
  51. +1
    -1
      include/leveldb/status.h
  52. +1
    -1
      include/leveldb/table.h
  53. +1
    -1
      include/leveldb/table_builder.h
  54. +1
    -1
      include/leveldb/write_batch.h
  55. +2
    -2
      port/atomic_pointer.h
  56. +2
    -2
      port/port_android.cc
  57. +2
    -2
      port/port_android.h
  58. +2
    -2
      port/port_example.h
  59. +2
    -2
      port/port_posix.cc
  60. +1
    -1
      table/block.cc
  61. +1
    -1
      table/block.h
  62. +1
    -1
      table/block_builder.cc
  63. +1
    -1
      table/block_builder.h
  64. +1
    -1
      table/format.cc
  65. +1
    -1
      table/format.h
  66. +2
    -2
      table/iterator.cc
  67. +2
    -2
      table/merger.cc
  68. +1
    -1
      table/merger.h
  69. +1
    -1
      table/table.cc
  70. +1
    -1
      table/table_builder.cc
  71. +3
    -3
      table/table_test.cc
  72. +2
    -2
      table/two_level_iterator.cc
  73. +1
    -1
      table/two_level_iterator.h
  74. +1
    -1
      util/arena.cc
  75. +1
    -1
      util/arena.h
  76. +1
    -1
      util/arena_test.cc
  77. +1
    -1
      util/cache.cc
  78. +1
    -1
      util/cache_test.cc
  79. +1
    -1
      util/coding.cc
  80. +1
    -1
      util/coding.h
  81. +1
    -1
      util/coding_test.cc
  82. +2
    -2
      util/comparator.cc
  83. +2
    -2
      util/crc32c.cc
  84. +2
    -2
      util/crc32c.h
  85. +2
    -2
      util/crc32c_test.cc
  86. +1
    -1
      util/env.cc
  87. +2
    -2
      util/env_posix.cc
  88. +1
    -1
      util/env_test.cc
  89. +1
    -1
      util/hash.cc
  90. +1
    -1
      util/histogram.cc
  91. +1
    -1
      util/histogram.h
  92. +1
    -1
      util/logging.cc
  93. +1
    -1
      util/logging.h
  94. +1
    -1
      util/mutexlock.h
  95. +1
    -1
      util/options.cc
  96. +1
    -1
      util/posix_logger.h
  97. +1
    -1
      util/random.h
  98. +1
    -1
      util/status.cc
  99. +2
    -2
      util/testharness.cc
  100. +2
    -2
      util/testharness.h

+ 1
- 1
db/builder.cc Datei anzeigen

@ -85,4 +85,4 @@ Status BuildTable(const std::string& dbname,
return s;
}
}
} // namespace leveldb

+ 1
- 1
db/builder.h Datei anzeigen

@ -29,6 +29,6 @@ extern Status BuildTable(const std::string& dbname,
Iterator* iter,
FileMetaData* meta);
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_DB_BUILDER_H_

+ 1
- 1
db/corruption_test.cc Datei anzeigen

@ -352,7 +352,7 @@ TEST(CorruptionTest, UnrelatedKeys) {
ASSERT_EQ(Value(1000, &tmp2).ToString(), v);
}
}
} // namespace leveldb
int main(int argc, char** argv) {
return leveldb::test::RunAllTests();

+ 2
- 2
db/db_bench.cc Datei anzeigen

@ -288,7 +288,7 @@ struct ThreadState {
}
};
}
} // namespace
class Benchmark {
private:
@ -829,7 +829,7 @@ class Benchmark {
}
};
}
} // namespace leveldb
int main(int argc, char** argv) {
FLAGS_write_buffer_size = leveldb::Options().write_buffer_size;

+ 2
- 2
db/db_impl.cc Datei anzeigen

@ -985,7 +985,7 @@ static void CleanupIteratorState(void* arg1, void* arg2) {
state->mu->Unlock();
delete state;
}
}
} // namespace
Iterator* DBImpl::NewInternalIterator(const ReadOptions& options,
SequenceNumber* latest_snapshot) {
@ -1378,4 +1378,4 @@ Status DestroyDB(const std::string& dbname, const Options& options) {
return result;
}
}
} // namespace leveldb

+ 1
- 1
db/db_impl.h Datei anzeigen

@ -187,6 +187,6 @@ extern Options SanitizeOptions(const std::string& db,
const InternalKeyComparator* icmp,
const Options& src);
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_DB_DB_IMPL_H_

+ 1
- 1
db/db_iter.cc Datei anzeigen

@ -296,4 +296,4 @@ Iterator* NewDBIterator(
return new DBIter(dbname, env, user_key_comparator, internal_iter, sequence);
}
}
} // namespace leveldb

+ 1
- 1
db/db_iter.h Datei anzeigen

@ -21,6 +21,6 @@ extern Iterator* NewDBIterator(
Iterator* internal_iter,
const SequenceNumber& sequence);
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_DB_DB_ITER_H_

+ 100
- 2
db/db_test.cc Datei anzeigen

@ -136,6 +136,33 @@ class DBTest {
return result;
}
// Return a string that contains all key,value pairs in order,
// formatted like "(k1->v1)(k2->v2)".
std::string Contents() {
std::vector<std::string> forward;
std::string result;
Iterator* iter = db_->NewIterator(ReadOptions());
for (iter->SeekToFirst(); iter->Valid(); iter->Next()) {
std::string s = IterStatus(iter);
result.push_back('(');
result.append(s);
result.push_back(')');
forward.push_back(s);
}
// Check reverse iteration results are the reverse of forward results
int matched = 0;
for (iter->SeekToLast(); iter->Valid(); iter->Prev()) {
ASSERT_LT(matched, forward.size());
ASSERT_EQ(IterStatus(iter), forward[forward.size() - matched - 1]);
matched++;
}
ASSERT_EQ(matched, forward.size());
delete iter;
return result;
}
std::string AllEntriesFor(const Slice& user_key) {
Iterator* iter = dbfull()->TEST_NewInternalIterator();
InternalKey target(user_key, kMaxSequenceNumber, kTypeValue);
@ -1048,6 +1075,49 @@ TEST(DBTest, OverlapInLevel0) {
ASSERT_EQ("NOT_FOUND", Get("600"));
}
TEST(DBTest, L0_CompactionBug_Issue44_a) {
Reopen();
ASSERT_OK(Put("b", "v"));
Reopen();
ASSERT_OK(Delete("b"));
ASSERT_OK(Delete("a"));
Reopen();
ASSERT_OK(Delete("a"));
Reopen();
ASSERT_OK(Put("a", "v"));
Reopen();
Reopen();
ASSERT_EQ("(a->v)", Contents());
env_->SleepForMicroseconds(1000000); // Wait for compaction to finish
ASSERT_EQ("(a->v)", Contents());
}
TEST(DBTest, L0_CompactionBug_Issue44_b) {
Reopen();
Put("","");
Reopen();
Delete("e");
Put("","");
Reopen();
Put("c", "cv");
Reopen();
Put("","");
Reopen();
Put("","");
env_->SleepForMicroseconds(1000000); // Wait for compaction to finish
Reopen();
Put("d","dv");
Reopen();
Put("","");
Reopen();
Delete("d");
Delete("b");
Reopen();
ASSERT_EQ("(->)(c->cv)", Contents());
env_->SleepForMicroseconds(1000000); // Wait for compaction to finish
ASSERT_EQ("(->)(c->cv)", Contents());
}
TEST(DBTest, ComparatorCheck) {
class NewComparator : public Comparator {
public:
@ -1071,6 +1141,34 @@ TEST(DBTest, ComparatorCheck) {
<< s.ToString();
}
TEST(DBTest, CustomComparator) {
class NumberComparator : public Comparator {
public:
virtual const char* Name() const { return "test.NumberComparator"; }
virtual int Compare(const Slice& a, const Slice& b) const {
return (strtol(a.ToString().c_str(), NULL, 0) -
strtol(b.ToString().c_str(), NULL, 0));
}
virtual void FindShortestSeparator(std::string* s, const Slice& l) const {}
virtual void FindShortSuccessor(std::string* key) const {}
};
NumberComparator cmp;
Options new_options;
new_options.create_if_missing = true;
new_options.comparator = &cmp;
DestroyAndReopen(&new_options);
ASSERT_OK(Put("10", "ten"));
ASSERT_OK(Put("0x14", "twenty"));
for (int i = 0; i < 2; i++) {
ASSERT_EQ("ten", Get("10"));
ASSERT_EQ("ten", Get("0xa"));
ASSERT_EQ("twenty", Get("20"));
ASSERT_EQ("twenty", Get("0x14"));
Compact("0", "9999");
fprintf(stderr, "ss\n%s\n", DumpSSTableList().c_str());
}
}
TEST(DBTest, ManualCompaction) {
ASSERT_EQ(config::kMaxMemCompactLevel, 2)
<< "Need to update this test to match kMaxMemCompactLevel";
@ -1207,7 +1305,7 @@ static void MTThreadBody(void* arg) {
fprintf(stderr, "... stopping thread %d after %d ops\n", t->id, int(counter));
}
}
} // namespace
TEST(DBTest, MultiThreaded) {
// Initialize state
@ -1525,7 +1623,7 @@ void BM_LogAndApply(int iters, int num_base_files) {
buf, iters, us, ((float)us) / iters);
}
}
} // namespace leveldb
int main(int argc, char** argv) {
if (argc > 1 && std::string(argv[1]) == "--benchmark") {

+ 1
- 1
db/dbformat.cc Datei anzeigen

@ -115,4 +115,4 @@ LookupKey::LookupKey(const Slice& user_key, SequenceNumber s) {
end_ = dst;
}
}
} // namespace leveldb

+ 2
- 2
db/dbformat.h Datei anzeigen

@ -37,7 +37,7 @@ static const int kL0_StopWritesTrigger = 12;
// space if the same key space is being repeatedly overwritten.
static const int kMaxMemCompactLevel = 2;
}
} // namespace config
class InternalKey;
@ -210,6 +210,6 @@ inline LookupKey::~LookupKey() {
if (start_ != space_) delete[] start_;
}
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_DB_FORMAT_H_

+ 1
- 1
db/dbformat_test.cc Datei anzeigen

@ -105,7 +105,7 @@ TEST(FormatTest, InternalKeyShortestSuccessor) {
ShortSuccessor(IKey("\xff\xff", 100, kTypeValue)));
}
}
} // namespace leveldb
int main(int argc, char** argv) {
return leveldb::test::RunAllTests();

+ 1
- 1
db/filename.cc Datei anzeigen

@ -132,4 +132,4 @@ Status SetCurrentFile(Env* env, const std::string& dbname,
return s;
}
}
} // namespace leveldb

+ 1
- 1
db/filename.h Datei anzeigen

@ -75,6 +75,6 @@ extern Status SetCurrentFile(Env* env, const std::string& dbname,
uint64_t descriptor_number);
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_DB_FILENAME_H_

+ 1
- 1
db/filename_test.cc Datei anzeigen

@ -115,7 +115,7 @@ TEST(FileNameTest, Construction) {
ASSERT_EQ(kTempFile, type);
}
}
} // namespace leveldb
int main(int argc, char** argv) {
return leveldb::test::RunAllTests();

+ 2
- 2
db/log_format.h Datei anzeigen

@ -29,7 +29,7 @@ static const int kBlockSize = 32768;
// Header is checksum (4 bytes), type (1 byte), length (2 bytes).
static const int kHeaderSize = 4 + 1 + 2;
}
}
} // namespace log
} // namespace leveldb
#endif // STORAGE_LEVELDB_DB_LOG_FORMAT_H_

+ 2
- 2
db/log_reader.cc Datei anzeigen

@ -255,5 +255,5 @@ unsigned int Reader::ReadPhysicalRecord(Slice* result) {
}
}
}
}
} // namespace log
} // namespace leveldb

+ 2
- 2
db/log_reader.h Datei anzeigen

@ -102,7 +102,7 @@ class Reader {
void operator=(const Reader&);
};
}
}
} // namespace log
} // namespace leveldb
#endif // STORAGE_LEVELDB_DB_LOG_READER_H_

+ 2
- 2
db/log_test.cc Datei anzeigen

@ -492,8 +492,8 @@ TEST(LogTest, ReadPastEnd) {
CheckOffsetPastEndReturnsNoRecords(5);
}
}
}
} // namespace log
} // namespace leveldb
int main(int argc, char** argv) {
return leveldb::test::RunAllTests();

+ 2
- 2
db/log_writer.cc Datei anzeigen

@ -99,5 +99,5 @@ Status Writer::EmitPhysicalRecord(RecordType t, const char* ptr, size_t n) {
return s;
}
}
}
} // namespace log
} // namespace leveldb

+ 2
- 2
db/log_writer.h Datei anzeigen

@ -42,7 +42,7 @@ class Writer {
void operator=(const Writer&);
};
}
}
} // namespace log
} // namespace leveldb
#endif // STORAGE_LEVELDB_DB_LOG_WRITER_H_

+ 1
- 1
db/memtable.cc Datei anzeigen

@ -142,4 +142,4 @@ bool MemTable::Get(const LookupKey& key, std::string* value, Status* s) {
return false;
}
}
} // namespace leveldb

+ 1
- 1
db/memtable.h Datei anzeigen

@ -86,6 +86,6 @@ class MemTable {
void operator=(const MemTable&);
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_DB_MEMTABLE_H_

+ 2
- 2
db/repair.cc Datei anzeigen

@ -377,11 +377,11 @@ class Repairer {
fname.c_str(), s.ToString().c_str());
}
};
}
} // namespace
Status RepairDB(const std::string& dbname, const Options& options) {
Repairer repairer(dbname, options);
return repairer.Run();
}
}
} // namespace leveldb

+ 1
- 1
db/skiplist.h Datei anzeigen

@ -375,4 +375,4 @@ bool SkipList::Contains(const Key& key) const {
}
}
}
} // namespace leveldb

+ 1
- 1
db/skiplist_test.cc Datei anzeigen

@ -371,7 +371,7 @@ TEST(SkipTest, Concurrent3) { RunConcurrent(3); }
TEST(SkipTest, Concurrent4) { RunConcurrent(4); }
TEST(SkipTest, Concurrent5) { RunConcurrent(5); }
}
} // namespace leveldb
int main(int argc, char** argv) {
return leveldb::test::RunAllTests();

+ 1
- 1
db/snapshot.h Datei anzeigen

@ -61,6 +61,6 @@ class SnapshotList {
SnapshotImpl list_;
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_DB_SNAPSHOT_H_

+ 1
- 1
db/table_cache.cc Datei anzeigen

@ -92,4 +92,4 @@ void TableCache::Evict(uint64_t file_number) {
cache_->Erase(Slice(buf, sizeof(buf)));
}
}
} // namespace leveldb

+ 1
- 1
db/table_cache.h Datei anzeigen

@ -45,6 +45,6 @@ class TableCache {
Cache* cache_;
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_DB_TABLE_CACHE_H_

+ 1
- 1
db/version_edit.cc Datei anzeigen

@ -263,4 +263,4 @@ std::string VersionEdit::DebugString() const {
return r;
}
}
} // namespace leveldb

+ 1
- 1
db/version_edit.h Datei anzeigen

@ -102,6 +102,6 @@ class VersionEdit {
std::vector< std::pair<int, FileMetaData> > new_files_;
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_DB_VERSION_EDIT_H_

+ 1
- 1
db/version_edit_test.cc Datei anzeigen

@ -39,7 +39,7 @@ TEST(VersionEditTest, EncodeDecode) {
TestEncodeDecode(edit);
}
}
} // namespace leveldb
int main(int argc, char** argv) {
return leveldb::test::RunAllTests();

+ 25
- 11
db/version_set.cc Datei anzeigen

@ -61,7 +61,7 @@ std::string IntSetToString(const std::set& s) {
result += "}";
return result;
}
}
} // namespace
Version::~Version() {
assert(refs_ == 0);
@ -253,7 +253,8 @@ void Version::AddIterators(const ReadOptions& options,
// If "*iter" points at a value or deletion for user_key, store
// either the value, or a NotFound error and return true.
// Else return false.
static bool GetValue(Iterator* iter, const Slice& user_key,
static bool GetValue(const Comparator* cmp,
Iterator* iter, const Slice& user_key,
std::string* value,
Status* s) {
if (!iter->Valid()) {
@ -264,7 +265,7 @@ static bool GetValue(Iterator* iter, const Slice& user_key,
*s = Status::Corruption("corrupted key for ", user_key);
return true;
}
if (parsed_key.user_key != user_key) {
if (cmp->Compare(parsed_key.user_key, user_key) != 0) {
return false;
}
switch (parsed_key.type) {
@ -360,7 +361,7 @@ Status Version::Get(const ReadOptions& options,
f->number,
f->file_size);
iter->Seek(ikey);
const bool done = GetValue(iter, user_key, value, &s);
const bool done = GetValue(ucmp, iter, user_key, value, &s);
if (!iter->status().ok()) {
s = iter->status();
delete iter;
@ -450,16 +451,29 @@ void Version::GetOverlappingInputs(
user_end = end->user_key();
}
const Comparator* user_cmp = vset_->icmp_.user_comparator();
for (size_t i = 0; i < files_[level].size(); i++) {
FileMetaData* f = files_[level][i];
if (begin != NULL &&
user_cmp->Compare(f->largest.user_key(), user_begin) < 0) {
for (size_t i = 0; i < files_[level].size(); ) {
FileMetaData* f = files_[level][i++];
const Slice file_start = f->smallest.user_key();
const Slice file_limit = f->largest.user_key();
if (begin != NULL && user_cmp->Compare(file_limit, user_begin) < 0) {
// "f" is completely before specified range; skip it
} else if (end != NULL &&
user_cmp->Compare(f->smallest.user_key(), user_end) > 0) {
} else if (end != NULL && user_cmp->Compare(file_start, user_end) > 0) {
// "f" is completely after specified range; skip it
} else {
inputs->push_back(f);
if (level == 0) {
// Level-0 files may overlap each other. So check if the newly
// added file has expanded the range. If so, restart search.
if (begin != NULL && user_cmp->Compare(file_start, user_begin) < 0) {
user_begin = file_start;
inputs->clear();
i = 0;
} else if (end != NULL && user_cmp->Compare(file_limit, user_end) > 0) {
user_end = file_limit;
inputs->clear();
i = 0;
}
}
}
}
}
@ -1369,4 +1383,4 @@ void Compaction::ReleaseInputs() {
}
}
}
} // namespace leveldb

+ 1
- 1
db/version_set.h Datei anzeigen

@ -365,6 +365,6 @@ class Compaction {
size_t level_ptrs_[config::kNumLevels];
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_DB_VERSION_SET_H_

+ 1
- 1
db/version_set_test.cc Datei anzeigen

@ -172,7 +172,7 @@ TEST(FindFileTest, OverlappingFiles) {
ASSERT_TRUE(Overlaps("600", "700"));
}
}
} // namespace leveldb
int main(int argc, char** argv) {
return leveldb::test::RunAllTests();

+ 2
- 2
db/write_batch.cc Datei anzeigen

@ -120,7 +120,7 @@ class MemTableInserter : public WriteBatch::Handler {
sequence_++;
}
};
}
} // namespace
Status WriteBatchInternal::InsertInto(const WriteBatch* b,
MemTable* memtable) {
@ -135,4 +135,4 @@ void WriteBatchInternal::SetContents(WriteBatch* b, const Slice& contents) {
b->rep_.assign(contents.data(), contents.size());
}
}
} // namespace leveldb

+ 1
- 1
db/write_batch_internal.h Datei anzeigen

@ -41,7 +41,7 @@ class WriteBatchInternal {
static Status InsertInto(const WriteBatch* batch, MemTable* memtable);
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_DB_WRITE_BATCH_INTERNAL_H_

+ 1
- 1
db/write_batch_test.cc Datei anzeigen

@ -82,7 +82,7 @@ TEST(WriteBatchTest, Corruption) {
PrintContents(&batch));
}
}
} // namespace leveldb
int main(int argc, char** argv) {
return leveldb::test::RunAllTests();

+ 2
- 2
doc/bench/db_bench_sqlite3.cc Datei anzeigen

@ -155,7 +155,7 @@ static Slice TrimSpace(Slice s) {
return Slice(s.data() + start, limit - start);
}
}
} // namespace
class Benchmark {
private:
@ -652,7 +652,7 @@ class Benchmark {
};
}
} // namespace leveldb
int main(int argc, char** argv) {
for (int i = 1; i < argc; i++) {

+ 2
- 2
doc/bench/db_bench_tree_db.cc Datei anzeigen

@ -124,7 +124,7 @@ static Slice TrimSpace(Slice s) {
return Slice(s.data() + start, limit - start);
}
}
} // namespace
class Benchmark {
private:
@ -467,7 +467,7 @@ class Benchmark {
}
};
}
} // namespace leveldb
int main(int argc, char** argv) {
for (int i = 1; i < argc; i++) {

+ 2
- 2
helpers/memenv/memenv.cc Datei anzeigen

@ -365,10 +365,10 @@ class InMemoryEnv : public EnvWrapper {
FileSystem file_map_; // Protected by mutex_.
};
}
} // namespace
Env* NewMemEnv(Env* base_env) {
return new InMemoryEnv(base_env);
}
}
} // namespace leveldb

+ 1
- 1
helpers/memenv/memenv.h Datei anzeigen

@ -15,6 +15,6 @@ class Env;
// *base_env must remain live while the result is in use.
Env* NewMemEnv(Env* base_env);
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_HELPERS_MEMENV_MEMENV_H_

+ 1
- 1
helpers/memenv/memenv_test.cc Datei anzeigen

@ -225,7 +225,7 @@ TEST(MemEnvTest, DBTest) {
delete db;
}
}
} // namespace leveldb
int main(int argc, char** argv) {
return leveldb::test::RunAllTests();

+ 1
- 1
include/leveldb/cache.h Datei anzeigen

@ -94,6 +94,6 @@ class Cache {
void operator=(const Cache&);
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_UTIL_CACHE_H_

+ 1
- 1
include/leveldb/comparator.h Datei anzeigen

@ -58,6 +58,6 @@ class Comparator {
// must not be deleted.
extern const Comparator* BytewiseComparator();
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_INCLUDE_COMPARATOR_H_

+ 1
- 1
include/leveldb/db.h Datei anzeigen

@ -155,6 +155,6 @@ Status DestroyDB(const std::string& name, const Options& options);
// on a database that contains important information.
Status RepairDB(const std::string& dbname, const Options& options);
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_INCLUDE_DB_H_

+ 1
- 1
include/leveldb/env.h Datei anzeigen

@ -318,6 +318,6 @@ class EnvWrapper : public Env {
Env* target_;
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_INCLUDE_ENV_H_

+ 1
- 1
include/leveldb/iterator.h Datei anzeigen

@ -95,6 +95,6 @@ extern Iterator* NewEmptyIterator();
// Return an empty iterator with the specified status.
extern Iterator* NewErrorIterator(const Status& status);
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_INCLUDE_ITERATOR_H_

+ 1
- 1
include/leveldb/options.h Datei anzeigen

@ -182,6 +182,6 @@ struct WriteOptions {
}
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_INCLUDE_OPTIONS_H_

+ 1
- 1
include/leveldb/slice.h Datei anzeigen

@ -103,7 +103,7 @@ inline int Slice::compare(const Slice& b) const {
return r;
}
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_INCLUDE_SLICE_H_

+ 1
- 1
include/leveldb/status.h Datei anzeigen

@ -95,6 +95,6 @@ inline void Status::operator=(const Status& s) {
}
}
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_INCLUDE_STATUS_H_

+ 1
- 1
include/leveldb/table.h Datei anzeigen

@ -65,6 +65,6 @@ class Table {
void operator=(const Table&);
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_INCLUDE_TABLE_H_

+ 1
- 1
include/leveldb/table_builder.h Datei anzeigen

@ -86,6 +86,6 @@ class TableBuilder {
void operator=(const TableBuilder&);
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_INCLUDE_TABLE_BUILDER_H_

+ 1
- 1
include/leveldb/write_batch.h Datei anzeigen

@ -59,6 +59,6 @@ class WriteBatch {
// Intentionally copyable
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_INCLUDE_WRITE_BATCH_H_

+ 2
- 2
port/atomic_pointer.h Datei anzeigen

@ -138,7 +138,7 @@ class AtomicPointer {
#undef ARCH_CPU_X86_FAMILY
#undef ARCH_CPU_ARM_FAMILY
} // namespace leveldb::port
} // namespace leveldb
} // namespace port
} // namespace leveldb
#endif // PORT_ATOMIC_POINTER_H_

+ 2
- 2
port/port_android.cc Datei anzeigen

@ -60,5 +60,5 @@ void CondVar::SignalAll() {
PthreadCall("broadcast", pthread_cond_broadcast(&cv_));
}
}
}
} // namespace port
} // namespace leveldb

+ 2
- 2
port/port_android.h Datei anzeigen

@ -150,7 +150,7 @@ inline bool GetHeapProfile(void (*func)(void*, const char*, int), void* arg) {
return false;
}
}
}
} // namespace port
} // namespace leveldb
#endif // STORAGE_LEVELDB_PORT_PORT_ANDROID_H_

+ 2
- 2
port/port_example.h Datei anzeigen

@ -119,7 +119,7 @@ extern bool Snappy_Uncompress(const char* input_data, size_t input_length,
// The concatenation of all "data[0,n-1]" fragments is the heap profile.
extern bool GetHeapProfile(void (*func)(void*, const char*, int), void* arg);
}
}
} // namespace port
} // namespace leveldb
#endif // STORAGE_LEVELDB_PORT_PORT_EXAMPLE_H_

+ 2
- 2
port/port_posix.cc Datei anzeigen

@ -46,5 +46,5 @@ void CondVar::SignalAll() {
PthreadCall("broadcast", pthread_cond_broadcast(&cv_));
}
}
}
} // namespace port
} // namespace leveldb

+ 1
- 1
table/block.cc Datei anzeigen

@ -260,4 +260,4 @@ Iterator* Block::NewIterator(const Comparator* cmp) {
}
}
}
} // namespace leveldb

+ 1
- 1
table/block.h Datei anzeigen

@ -38,6 +38,6 @@ class Block {
class Iter;
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_TABLE_BLOCK_H_

+ 1
- 1
table/block_builder.cc Datei anzeigen

@ -106,4 +106,4 @@ void BlockBuilder::Add(const Slice& key, const Slice& value) {
counter_++;
}
}
} // namespace leveldb

+ 1
- 1
table/block_builder.h Datei anzeigen

@ -52,6 +52,6 @@ class BlockBuilder {
void operator=(const BlockBuilder&);
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_TABLE_BLOCK_BUILDER_H_

+ 1
- 1
table/format.cc Datei anzeigen

@ -132,4 +132,4 @@ Status ReadBlock(RandomAccessFile* file,
return Status::OK();
}
}
} // namespace leveldb

+ 1
- 1
table/format.h Datei anzeigen

@ -98,6 +98,6 @@ inline BlockHandle::BlockHandle()
size_(~static_cast<uint64_t>(0)) {
}
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_TABLE_FORMAT_H_

+ 2
- 2
table/iterator.cc Datei anzeigen

@ -54,7 +54,7 @@ class EmptyIterator : public Iterator {
private:
Status status_;
};
}
} // namespace
Iterator* NewEmptyIterator() {
return new EmptyIterator(Status::OK());
@ -64,4 +64,4 @@ Iterator* NewErrorIterator(const Status& status) {
return new EmptyIterator(status);
}
}
} // namespace leveldb

+ 2
- 2
table/merger.cc Datei anzeigen

@ -181,7 +181,7 @@ void MergingIterator::FindLargest() {
}
current_ = largest;
}
}
} // namespace
Iterator* NewMergingIterator(const Comparator* cmp, Iterator** list, int n) {
assert(n >= 0);
@ -194,4 +194,4 @@ Iterator* NewMergingIterator(const Comparator* cmp, Iterator** list, int n) {
}
}
}
} // namespace leveldb

+ 1
- 1
table/merger.h Datei anzeigen

@ -21,6 +21,6 @@ class Iterator;
extern Iterator* NewMergingIterator(
const Comparator* comparator, Iterator** children, int n);
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_TABLE_MERGER_H_

+ 1
- 1
table/table.cc Datei anzeigen

@ -172,4 +172,4 @@ uint64_t Table::ApproximateOffsetOf(const Slice& key) const {
return result;
}
}
} // namespace leveldb

+ 1
- 1
table/table_builder.cc Datei anzeigen

@ -224,4 +224,4 @@ uint64_t TableBuilder::FileSize() const {
return rep_->offset;
}
}
} // namespace leveldb

+ 3
- 3
table/table_test.cc Datei anzeigen

@ -60,7 +60,7 @@ class ReverseKeyComparator : public Comparator {
*key = Reverse(s);
}
};
}
} // namespace
static ReverseKeyComparator reverse_key_comparator;
static void Increment(const Comparator* cmp, std::string* key) {
@ -85,7 +85,7 @@ struct STLLessThan {
return cmp->Compare(Slice(a), Slice(b)) < 0;
}
};
}
} // namespace
class StringSink: public WritableFile {
public:
@ -847,7 +847,7 @@ TEST(TableTest, ApproximateOffsetOfCompressed) {
ASSERT_TRUE(Between(c.ApproximateOffsetOf("xyz"), 4000, 6000));
}
}
} // namespace leveldb
int main(int argc, char** argv) {
return leveldb::test::RunAllTests();

+ 2
- 2
table/two_level_iterator.cc Datei anzeigen

@ -169,7 +169,7 @@ void TwoLevelIterator::InitDataBlock() {
}
}
}
} // namespace
Iterator* NewTwoLevelIterator(
Iterator* index_iter,
@ -179,4 +179,4 @@ Iterator* NewTwoLevelIterator(
return new TwoLevelIterator(index_iter, block_function, arg, options);
}
}
} // namespace leveldb

+ 1
- 1
table/two_level_iterator.h Datei anzeigen

@ -29,6 +29,6 @@ extern Iterator* NewTwoLevelIterator(
void* arg,
const ReadOptions& options);
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_TABLE_TWO_LEVEL_ITERATOR_H_

+ 1
- 1
util/arena.cc Datei anzeigen

@ -65,4 +65,4 @@ char* Arena::AllocateNewBlock(size_t block_bytes) {
return result;
}
}
} // namespace leveldb

+ 1
- 1
util/arena.h Datei anzeigen

@ -63,6 +63,6 @@ inline char* Arena::Allocate(size_t bytes) {
return AllocateFallback(bytes);
}
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_UTIL_ARENA_H_

+ 1
- 1
util/arena_test.cc Datei anzeigen

@ -61,7 +61,7 @@ TEST(ArenaTest, Simple) {
}
}
}
} // namespace leveldb
int main(int argc, char** argv) {
return leveldb::test::RunAllTests();

+ 1
- 1
util/cache.cc Datei anzeigen

@ -325,4 +325,4 @@ Cache* NewLRUCache(size_t capacity) {
return new ShardedLRUCache(capacity);
}
}
} // namespace leveldb

+ 1
- 1
util/cache_test.cc Datei anzeigen

@ -179,7 +179,7 @@ TEST(CacheTest, NewId) {
ASSERT_NE(a, b);
}
}
} // namespace leveldb
int main(int argc, char** argv) {
return leveldb::test::RunAllTests();

+ 1
- 1
util/coding.cc Datei anzeigen

@ -191,4 +191,4 @@ bool GetLengthPrefixedSlice(Slice* input, Slice* result) {
}
}
}
} // namespace leveldb

+ 1
- 1
util/coding.h Datei anzeigen

@ -99,6 +99,6 @@ inline const char* GetVarint32Ptr(const char* p,
return GetVarint32PtrFallback(p, limit, value);
}
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_UTIL_CODING_H_

+ 1
- 1
util/coding_test.cc Datei anzeigen

@ -166,7 +166,7 @@ TEST(Coding, Strings) {
ASSERT_EQ("", input.ToString());
}
}
} // namespace leveldb
int main(int argc, char** argv) {
return leveldb::test::RunAllTests();

+ 2
- 2
util/comparator.cc Datei anzeigen

@ -63,11 +63,11 @@ class BytewiseComparatorImpl : public Comparator {
// *key is a run of 0xffs. Leave it alone.
}
};
}
} // namespace
static const BytewiseComparatorImpl bytewise;
const Comparator* BytewiseComparator() {
return &bytewise;
}
}
} // namespace leveldb

+ 2
- 2
util/crc32c.cc Datei anzeigen

@ -328,5 +328,5 @@ uint32_t Extend(uint32_t crc, const char* buf, size_t size) {
return l ^ 0xffffffffu;
}
}
}
} // namespace crc32c
} // namespace leveldb

+ 2
- 2
util/crc32c.h Datei anzeigen

@ -39,7 +39,7 @@ inline uint32_t Unmask(uint32_t masked_crc) {
return ((rot >> 17) | (rot << 15));
}
}
}
} // namespace crc32c
} // namespace leveldb
#endif // STORAGE_LEVELDB_UTIL_CRC32C_H_

+ 2
- 2
util/crc32c_test.cc Datei anzeigen

@ -64,8 +64,8 @@ TEST(CRC, Mask) {
ASSERT_EQ(crc, Unmask(Unmask(Mask(Mask(crc)))));
}
}
}
} // namespace crc32c
} // namespace leveldb
int main(int argc, char** argv) {
return leveldb::test::RunAllTests();

+ 1
- 1
util/env.cc Datei anzeigen

@ -79,4 +79,4 @@ Status ReadFileToString(Env* env, const std::string& fname, std::string* data) {
EnvWrapper::~EnvWrapper() {
}
}
} // namespace leveldb

+ 2
- 2
util/env_posix.cc Datei anzeigen

@ -553,7 +553,7 @@ void PosixEnv::StartThread(void (*function)(void* arg), void* arg) {
pthread_create(&t, NULL, &StartThreadWrapper, state));
}
}
} // namespace
static pthread_once_t once = PTHREAD_ONCE_INIT;
static Env* default_env;
@ -564,4 +564,4 @@ Env* Env::Default() {
return default_env;
}
}
} // namespace leveldb

+ 1
- 1
util/env_test.cc Datei anzeigen

@ -95,7 +95,7 @@ TEST(EnvPosixTest, StartThread) {
ASSERT_EQ(state.val, 3);
}
}
} // namespace leveldb
int main(int argc, char** argv) {
return leveldb::test::RunAllTests();

+ 1
- 1
util/hash.cc Datei anzeigen

@ -42,4 +42,4 @@ uint32_t Hash(const char* data, size_t n, uint32_t seed) {
}
}
} // namespace leveldb

+ 1
- 1
util/histogram.cc Datei anzeigen

@ -136,4 +136,4 @@ std::string Histogram::ToString() const {
return r;
}
}
} // namespace leveldb

+ 1
- 1
util/histogram.h Datei anzeigen

@ -37,6 +37,6 @@ class Histogram {
double StandardDeviation() const;
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_UTIL_HISTOGRAM_H_

+ 1
- 1
util/logging.cc Datei anzeigen

@ -78,4 +78,4 @@ bool ConsumeDecimalNumber(Slice* in, uint64_t* val) {
return (digits > 0);
}
}
} // namespace leveldb

+ 1
- 1
util/logging.h Datei anzeigen

@ -42,6 +42,6 @@ extern bool ConsumeChar(Slice* in, char c);
// unspecified state.
extern bool ConsumeDecimalNumber(Slice* in, uint64_t* val);
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_UTIL_LOGGING_H_

+ 1
- 1
util/mutexlock.h Datei anzeigen

@ -33,7 +33,7 @@ class MutexLock {
void operator=(const MutexLock&);
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_UTIL_MUTEXLOCK_H_

+ 1
- 1
util/options.cc Datei anzeigen

@ -25,4 +25,4 @@ Options::Options()
}
}
} // namespace leveldb

+ 1
- 1
util/posix_logger.h Datei anzeigen

@ -93,6 +93,6 @@ class PosixLogger : public Logger {
}
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_UTIL_POSIX_LOGGER_H_

+ 1
- 1
util/random.h Datei anzeigen

@ -54,6 +54,6 @@ class Random {
}
};
}
} // namespace leveldb
#endif // STORAGE_LEVELDB_UTIL_RANDOM_H_

+ 1
- 1
util/status.cc Datei anzeigen

@ -72,4 +72,4 @@ std::string Status::ToString() const {
}
}
}
} // namespace leveldb

+ 2
- 2
util/testharness.cc Datei anzeigen

@ -73,5 +73,5 @@ int RandomSeed() {
return result;
}
}
}
} // namespace test
} // namespace leveldb

+ 2
- 2
util/testharness.h Datei anzeigen

@ -132,7 +132,7 @@ void TCONCAT(_Test_,name)::_Run()
extern bool RegisterTest(const char* base, const char* name, void (*func)());
}
}
} // namespace test
} // namespace leveldb
#endif // STORAGE_LEVELDB_UTIL_TESTHARNESS_H_

Einige Dateien werden nicht angezeigt, da zu viele Dateien in diesem Diff geändert wurden.

Laden…
Abbrechen
Speichern