Do not issue extra GetFileSize() calls when loading BackupMeta.

main
Robert 10 years ago
parent caa1fd0e0e
commit a8c5564a9d
  1. 12
      utilities/backupable/backupable_db.cc

@ -185,6 +185,13 @@ class BackupEngineImpl : public BackupEngine {
return files_.empty(); return files_.empty();
} }
const FileInfo* GetFile(const std::string& filename) const {
auto it = file_infos_->find(filename);
if (it == file_infos_->end())
return nullptr;
return &it->second;
}
const std::vector<std::string>& GetFiles() { const std::vector<std::string>& GetFiles() {
return files_; return files_;
} }
@ -1181,10 +1188,15 @@ Status BackupEngineImpl::BackupMeta::LoadFromFile(
std::string filename = GetSliceUntil(&line, ' ').ToString(); std::string filename = GetSliceUntil(&line, ' ').ToString();
uint64_t size; uint64_t size;
const FileInfo* file_info = GetFile(filename);
if (file_info != nullptr) {
size = file_info->size;
} else {
s = env_->GetFileSize(backup_dir + "/" + filename, &size); s = env_->GetFileSize(backup_dir + "/" + filename, &size);
if (!s.ok()) { if (!s.ok()) {
return s; return s;
} }
}
if (line.empty()) { if (line.empty()) {
return Status::Corruption("File checksum is missing"); return Status::Corruption("File checksum is missing");

Loading…
Cancel
Save