|
|
@ -82,6 +82,19 @@ const std::string LDBCommand::ARG_WRITE_BUFFER_SIZE = "write_buffer_size"; |
|
|
|
const std::string LDBCommand::ARG_FILE_SIZE = "file_size"; |
|
|
|
const std::string LDBCommand::ARG_FILE_SIZE = "file_size"; |
|
|
|
const std::string LDBCommand::ARG_CREATE_IF_MISSING = "create_if_missing"; |
|
|
|
const std::string LDBCommand::ARG_CREATE_IF_MISSING = "create_if_missing"; |
|
|
|
const std::string LDBCommand::ARG_NO_VALUE = "no_value"; |
|
|
|
const std::string LDBCommand::ARG_NO_VALUE = "no_value"; |
|
|
|
|
|
|
|
const std::string LDBCommand::ARG_ENABLE_BLOB_FILES = "enable_blob_files"; |
|
|
|
|
|
|
|
const std::string LDBCommand::ARG_MIN_BLOB_SIZE = "min_blob_size"; |
|
|
|
|
|
|
|
const std::string LDBCommand::ARG_BLOB_FILE_SIZE = "blob_file_size"; |
|
|
|
|
|
|
|
const std::string LDBCommand::ARG_BLOB_COMPRESSION_TYPE = |
|
|
|
|
|
|
|
"blob_compression_type"; |
|
|
|
|
|
|
|
const std::string LDBCommand::ARG_ENABLE_BLOB_GARBAGE_COLLECTION = |
|
|
|
|
|
|
|
"enable_blob_garbage_collection"; |
|
|
|
|
|
|
|
const std::string LDBCommand::ARG_BLOB_GARBAGE_COLLECTION_AGE_CUTOFF = |
|
|
|
|
|
|
|
"blob_garbage_collection_age_cutoff"; |
|
|
|
|
|
|
|
const std::string LDBCommand::ARG_BLOB_GARBAGE_COLLECTION_FORCE_THRESHOLD = |
|
|
|
|
|
|
|
"blob_garbage_collection_force_threshold"; |
|
|
|
|
|
|
|
const std::string LDBCommand::ARG_BLOB_COMPACTION_READAHEAD_SIZE = |
|
|
|
|
|
|
|
"blob_compaction_readahead_size"; |
|
|
|
|
|
|
|
|
|
|
|
const char* LDBCommand::DELIM = " ==> "; |
|
|
|
const char* LDBCommand::DELIM = " ==> "; |
|
|
|
|
|
|
|
|
|
|
@ -348,7 +361,7 @@ LDBCommand::LDBCommand(const std::map<std::string, std::string>& options, |
|
|
|
option_map_(options), |
|
|
|
option_map_(options), |
|
|
|
flags_(flags), |
|
|
|
flags_(flags), |
|
|
|
valid_cmd_line_options_(valid_cmd_line_options) { |
|
|
|
valid_cmd_line_options_(valid_cmd_line_options) { |
|
|
|
std::map<std::string, std::string>::const_iterator itr = options.find(ARG_DB); |
|
|
|
auto itr = options.find(ARG_DB); |
|
|
|
if (itr != options.end()) { |
|
|
|
if (itr != options.end()) { |
|
|
|
db_path_ = itr->second; |
|
|
|
db_path_ = itr->second; |
|
|
|
} |
|
|
|
} |
|
|
@ -383,6 +396,9 @@ LDBCommand::LDBCommand(const std::map<std::string, std::string>& options, |
|
|
|
try_load_options_ = IsFlagPresent(flags, ARG_TRY_LOAD_OPTIONS); |
|
|
|
try_load_options_ = IsFlagPresent(flags, ARG_TRY_LOAD_OPTIONS); |
|
|
|
force_consistency_checks_ = |
|
|
|
force_consistency_checks_ = |
|
|
|
!IsFlagPresent(flags, ARG_DISABLE_CONSISTENCY_CHECKS); |
|
|
|
!IsFlagPresent(flags, ARG_DISABLE_CONSISTENCY_CHECKS); |
|
|
|
|
|
|
|
enable_blob_files_ = IsFlagPresent(flags, ARG_ENABLE_BLOB_FILES); |
|
|
|
|
|
|
|
enable_blob_garbage_collection_ = |
|
|
|
|
|
|
|
IsFlagPresent(flags, ARG_ENABLE_BLOB_GARBAGE_COLLECTION); |
|
|
|
config_options_.ignore_unknown_options = |
|
|
|
config_options_.ignore_unknown_options = |
|
|
|
IsFlagPresent(flags, ARG_IGNORE_UNKNOWN_OPTIONS); |
|
|
|
IsFlagPresent(flags, ARG_IGNORE_UNKNOWN_OPTIONS); |
|
|
|
} |
|
|
|
} |
|
|
@ -508,12 +524,61 @@ std::vector<std::string> LDBCommand::BuildCmdLineOptions( |
|
|
|
ARG_FIX_PREFIX_LEN, |
|
|
|
ARG_FIX_PREFIX_LEN, |
|
|
|
ARG_TRY_LOAD_OPTIONS, |
|
|
|
ARG_TRY_LOAD_OPTIONS, |
|
|
|
ARG_DISABLE_CONSISTENCY_CHECKS, |
|
|
|
ARG_DISABLE_CONSISTENCY_CHECKS, |
|
|
|
|
|
|
|
ARG_ENABLE_BLOB_FILES, |
|
|
|
|
|
|
|
ARG_MIN_BLOB_SIZE, |
|
|
|
|
|
|
|
ARG_BLOB_FILE_SIZE, |
|
|
|
|
|
|
|
ARG_BLOB_COMPRESSION_TYPE, |
|
|
|
|
|
|
|
ARG_ENABLE_BLOB_GARBAGE_COLLECTION, |
|
|
|
|
|
|
|
ARG_BLOB_GARBAGE_COLLECTION_AGE_CUTOFF, |
|
|
|
|
|
|
|
ARG_BLOB_GARBAGE_COLLECTION_FORCE_THRESHOLD, |
|
|
|
|
|
|
|
ARG_BLOB_COMPACTION_READAHEAD_SIZE, |
|
|
|
ARG_IGNORE_UNKNOWN_OPTIONS, |
|
|
|
ARG_IGNORE_UNKNOWN_OPTIONS, |
|
|
|
ARG_CF_NAME}; |
|
|
|
ARG_CF_NAME}; |
|
|
|
ret.insert(ret.end(), options.begin(), options.end()); |
|
|
|
ret.insert(ret.end(), options.begin(), options.end()); |
|
|
|
return ret; |
|
|
|
return ret; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
* Parses the specific double option and fills in the value. |
|
|
|
|
|
|
|
* Returns true if the option is found. |
|
|
|
|
|
|
|
* Returns false if the option is not found or if there is an error parsing the |
|
|
|
|
|
|
|
* value. If there is an error, the specified exec_state is also |
|
|
|
|
|
|
|
* updated. |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
bool LDBCommand::ParseDoubleOption( |
|
|
|
|
|
|
|
const std::map<std::string, std::string>& /*options*/, |
|
|
|
|
|
|
|
const std::string& option, double& value, |
|
|
|
|
|
|
|
LDBCommandExecuteResult& exec_state) { |
|
|
|
|
|
|
|
auto itr = option_map_.find(option); |
|
|
|
|
|
|
|
if (itr != option_map_.end()) { |
|
|
|
|
|
|
|
#if defined(CYGWIN) |
|
|
|
|
|
|
|
char* str_end = nullptr; |
|
|
|
|
|
|
|
value = std::strtod(itr->second.c_str(), &str_end); |
|
|
|
|
|
|
|
if (str_end == itr->second.c_str()) { |
|
|
|
|
|
|
|
exec_state = |
|
|
|
|
|
|
|
LDBCommandExecuteResult::Failed(option + " has an invalid value."); |
|
|
|
|
|
|
|
} else if (errno == ERANGE) { |
|
|
|
|
|
|
|
exec_state = LDBCommandExecuteResult::Failed( |
|
|
|
|
|
|
|
option + " has a value out-of-range."); |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
return true; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
#else |
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
value = std::stod(itr->second); |
|
|
|
|
|
|
|
return true; |
|
|
|
|
|
|
|
} catch (const std::invalid_argument&) { |
|
|
|
|
|
|
|
exec_state = |
|
|
|
|
|
|
|
LDBCommandExecuteResult::Failed(option + " has an invalid value."); |
|
|
|
|
|
|
|
} catch (const std::out_of_range&) { |
|
|
|
|
|
|
|
exec_state = LDBCommandExecuteResult::Failed( |
|
|
|
|
|
|
|
option + " has a value out-of-range."); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
return false; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* Parses the specific integer option and fills in the value. |
|
|
|
* Parses the specific integer option and fills in the value. |
|
|
|
* Returns true if the option is found. |
|
|
|
* Returns true if the option is found. |
|
|
@ -525,15 +590,23 @@ bool LDBCommand::ParseIntOption( |
|
|
|
const std::map<std::string, std::string>& /*options*/, |
|
|
|
const std::map<std::string, std::string>& /*options*/, |
|
|
|
const std::string& option, int& value, |
|
|
|
const std::string& option, int& value, |
|
|
|
LDBCommandExecuteResult& exec_state) { |
|
|
|
LDBCommandExecuteResult& exec_state) { |
|
|
|
std::map<std::string, std::string>::const_iterator itr = |
|
|
|
auto itr = option_map_.find(option); |
|
|
|
option_map_.find(option); |
|
|
|
|
|
|
|
if (itr != option_map_.end()) { |
|
|
|
if (itr != option_map_.end()) { |
|
|
|
try { |
|
|
|
|
|
|
|
#if defined(CYGWIN) |
|
|
|
#if defined(CYGWIN) |
|
|
|
value = strtol(itr->second.c_str(), 0, 10); |
|
|
|
char* str_end = nullptr; |
|
|
|
|
|
|
|
value = strtol(itr->second.c_str(), &str_end, 10); |
|
|
|
|
|
|
|
if (str_end == itr->second.c_str()) { |
|
|
|
|
|
|
|
exec_state = |
|
|
|
|
|
|
|
LDBCommandExecuteResult::Failed(option + " has an invalid value."); |
|
|
|
|
|
|
|
} else if (errno == ERANGE) { |
|
|
|
|
|
|
|
exec_state = LDBCommandExecuteResult::Failed( |
|
|
|
|
|
|
|
option + " has a value out-of-range."); |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
return true; |
|
|
|
|
|
|
|
} |
|
|
|
#else |
|
|
|
#else |
|
|
|
|
|
|
|
try { |
|
|
|
value = std::stoi(itr->second); |
|
|
|
value = std::stoi(itr->second); |
|
|
|
#endif |
|
|
|
|
|
|
|
return true; |
|
|
|
return true; |
|
|
|
} catch (const std::invalid_argument&) { |
|
|
|
} catch (const std::invalid_argument&) { |
|
|
|
exec_state = |
|
|
|
exec_state = |
|
|
@ -542,6 +615,7 @@ bool LDBCommand::ParseIntOption( |
|
|
|
exec_state = LDBCommandExecuteResult::Failed( |
|
|
|
exec_state = LDBCommandExecuteResult::Failed( |
|
|
|
option + " has a value out-of-range."); |
|
|
|
option + " has a value out-of-range."); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
#endif |
|
|
|
} |
|
|
|
} |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
@ -562,6 +636,51 @@ bool LDBCommand::ParseStringOption( |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
* Parses the specified compression type and fills in the value. |
|
|
|
|
|
|
|
* Returns true if the compression type is found. |
|
|
|
|
|
|
|
* Returns false otherwise. |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
bool LDBCommand::ParseCompressionTypeOption( |
|
|
|
|
|
|
|
const std::map<std::string, std::string>& /*options*/, |
|
|
|
|
|
|
|
const std::string& option, CompressionType& value, |
|
|
|
|
|
|
|
LDBCommandExecuteResult& exec_state) { |
|
|
|
|
|
|
|
auto itr = option_map_.find(option); |
|
|
|
|
|
|
|
if (itr != option_map_.end()) { |
|
|
|
|
|
|
|
const std::string& comp = itr->second; |
|
|
|
|
|
|
|
if (comp == "no") { |
|
|
|
|
|
|
|
value = kNoCompression; |
|
|
|
|
|
|
|
return true; |
|
|
|
|
|
|
|
} else if (comp == "snappy") { |
|
|
|
|
|
|
|
value = kSnappyCompression; |
|
|
|
|
|
|
|
return true; |
|
|
|
|
|
|
|
} else if (comp == "zlib") { |
|
|
|
|
|
|
|
value = kZlibCompression; |
|
|
|
|
|
|
|
return true; |
|
|
|
|
|
|
|
} else if (comp == "bzip2") { |
|
|
|
|
|
|
|
value = kBZip2Compression; |
|
|
|
|
|
|
|
return true; |
|
|
|
|
|
|
|
} else if (comp == "lz4") { |
|
|
|
|
|
|
|
value = kLZ4Compression; |
|
|
|
|
|
|
|
return true; |
|
|
|
|
|
|
|
} else if (comp == "lz4hc") { |
|
|
|
|
|
|
|
value = kLZ4HCCompression; |
|
|
|
|
|
|
|
return true; |
|
|
|
|
|
|
|
} else if (comp == "xpress") { |
|
|
|
|
|
|
|
value = kXpressCompression; |
|
|
|
|
|
|
|
return true; |
|
|
|
|
|
|
|
} else if (comp == "zstd") { |
|
|
|
|
|
|
|
value = kZSTD; |
|
|
|
|
|
|
|
return true; |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
// Unknown compression.
|
|
|
|
|
|
|
|
exec_state = LDBCommandExecuteResult::Failed( |
|
|
|
|
|
|
|
"Unknown compression algorithm: " + comp); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
return false; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void LDBCommand::OverrideBaseOptions() { |
|
|
|
void LDBCommand::OverrideBaseOptions() { |
|
|
|
options_.create_if_missing = false; |
|
|
|
options_.create_if_missing = false; |
|
|
|
|
|
|
|
|
|
|
@ -614,35 +733,86 @@ void LDBCommand::OverrideBaseCFOptions(ColumnFamilyOptions* cf_opts) { |
|
|
|
cf_opts->table_factory.reset(NewBlockBasedTableFactory(table_options)); |
|
|
|
cf_opts->table_factory.reset(NewBlockBasedTableFactory(table_options)); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
cf_opts->enable_blob_files = enable_blob_files_; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
int min_blob_size; |
|
|
|
|
|
|
|
if (ParseIntOption(option_map_, ARG_MIN_BLOB_SIZE, min_blob_size, |
|
|
|
|
|
|
|
exec_state_)) { |
|
|
|
|
|
|
|
if (min_blob_size >= 0) { |
|
|
|
|
|
|
|
cf_opts->min_blob_size = min_blob_size; |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
exec_state_ = |
|
|
|
|
|
|
|
LDBCommandExecuteResult::Failed(ARG_MIN_BLOB_SIZE + " must be >= 0."); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
int blob_file_size; |
|
|
|
|
|
|
|
if (ParseIntOption(option_map_, ARG_BLOB_FILE_SIZE, blob_file_size, |
|
|
|
|
|
|
|
exec_state_)) { |
|
|
|
|
|
|
|
if (blob_file_size > 0) { |
|
|
|
|
|
|
|
cf_opts->blob_file_size = blob_file_size; |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
exec_state_ = |
|
|
|
|
|
|
|
LDBCommandExecuteResult::Failed(ARG_BLOB_FILE_SIZE + " must be > 0."); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
cf_opts->enable_blob_garbage_collection = enable_blob_garbage_collection_; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
double blob_garbage_collection_age_cutoff; |
|
|
|
|
|
|
|
if (ParseDoubleOption(option_map_, ARG_BLOB_GARBAGE_COLLECTION_AGE_CUTOFF, |
|
|
|
|
|
|
|
blob_garbage_collection_age_cutoff, exec_state_)) { |
|
|
|
|
|
|
|
if (blob_garbage_collection_age_cutoff >= 0 && |
|
|
|
|
|
|
|
blob_garbage_collection_age_cutoff <= 1) { |
|
|
|
|
|
|
|
cf_opts->blob_garbage_collection_age_cutoff = |
|
|
|
|
|
|
|
blob_garbage_collection_age_cutoff; |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
exec_state_ = LDBCommandExecuteResult::Failed( |
|
|
|
|
|
|
|
ARG_BLOB_GARBAGE_COLLECTION_AGE_CUTOFF + " must be >= 0 and <= 1."); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
double blob_garbage_collection_force_threshold; |
|
|
|
|
|
|
|
if (ParseDoubleOption(option_map_, |
|
|
|
|
|
|
|
ARG_BLOB_GARBAGE_COLLECTION_FORCE_THRESHOLD, |
|
|
|
|
|
|
|
blob_garbage_collection_force_threshold, exec_state_)) { |
|
|
|
|
|
|
|
if (blob_garbage_collection_force_threshold >= 0 && |
|
|
|
|
|
|
|
blob_garbage_collection_force_threshold <= 1) { |
|
|
|
|
|
|
|
cf_opts->blob_garbage_collection_force_threshold = |
|
|
|
|
|
|
|
blob_garbage_collection_force_threshold; |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
exec_state_ = LDBCommandExecuteResult::Failed( |
|
|
|
|
|
|
|
ARG_BLOB_GARBAGE_COLLECTION_FORCE_THRESHOLD + |
|
|
|
|
|
|
|
" must be >= 0 and <= 1."); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
int blob_compaction_readahead_size; |
|
|
|
|
|
|
|
if (ParseIntOption(option_map_, ARG_BLOB_COMPACTION_READAHEAD_SIZE, |
|
|
|
|
|
|
|
blob_compaction_readahead_size, exec_state_)) { |
|
|
|
|
|
|
|
if (blob_compaction_readahead_size > 0) { |
|
|
|
|
|
|
|
cf_opts->blob_compaction_readahead_size = blob_compaction_readahead_size; |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
exec_state_ = LDBCommandExecuteResult::Failed( |
|
|
|
|
|
|
|
ARG_BLOB_COMPACTION_READAHEAD_SIZE + " must be > 0."); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
auto itr = option_map_.find(ARG_AUTO_COMPACTION); |
|
|
|
auto itr = option_map_.find(ARG_AUTO_COMPACTION); |
|
|
|
if (itr != option_map_.end()) { |
|
|
|
if (itr != option_map_.end()) { |
|
|
|
cf_opts->disable_auto_compactions = !StringToBool(itr->second); |
|
|
|
cf_opts->disable_auto_compactions = !StringToBool(itr->second); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
itr = option_map_.find(ARG_COMPRESSION_TYPE); |
|
|
|
CompressionType compression_type; |
|
|
|
if (itr != option_map_.end()) { |
|
|
|
if (ParseCompressionTypeOption(option_map_, ARG_COMPRESSION_TYPE, |
|
|
|
std::string comp = itr->second; |
|
|
|
compression_type, exec_state_)) { |
|
|
|
if (comp == "no") { |
|
|
|
cf_opts->compression = compression_type; |
|
|
|
cf_opts->compression = kNoCompression; |
|
|
|
|
|
|
|
} else if (comp == "snappy") { |
|
|
|
|
|
|
|
cf_opts->compression = kSnappyCompression; |
|
|
|
|
|
|
|
} else if (comp == "zlib") { |
|
|
|
|
|
|
|
cf_opts->compression = kZlibCompression; |
|
|
|
|
|
|
|
} else if (comp == "bzip2") { |
|
|
|
|
|
|
|
cf_opts->compression = kBZip2Compression; |
|
|
|
|
|
|
|
} else if (comp == "lz4") { |
|
|
|
|
|
|
|
cf_opts->compression = kLZ4Compression; |
|
|
|
|
|
|
|
} else if (comp == "lz4hc") { |
|
|
|
|
|
|
|
cf_opts->compression = kLZ4HCCompression; |
|
|
|
|
|
|
|
} else if (comp == "xpress") { |
|
|
|
|
|
|
|
cf_opts->compression = kXpressCompression; |
|
|
|
|
|
|
|
} else if (comp == "zstd") { |
|
|
|
|
|
|
|
cf_opts->compression = kZSTD; |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
// Unknown compression.
|
|
|
|
|
|
|
|
exec_state_ = |
|
|
|
|
|
|
|
LDBCommandExecuteResult::Failed("Unknown compression level: " + comp); |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
CompressionType blob_compression_type; |
|
|
|
|
|
|
|
if (ParseCompressionTypeOption(option_map_, ARG_BLOB_COMPRESSION_TYPE, |
|
|
|
|
|
|
|
blob_compression_type, exec_state_)) { |
|
|
|
|
|
|
|
cf_opts->blob_compression_type = blob_compression_type; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
int compression_max_dict_bytes; |
|
|
|
int compression_max_dict_bytes; |
|
|
@ -793,9 +963,7 @@ bool LDBCommand::ParseKeyValue(const std::string& line, std::string* key, |
|
|
|
* appropriate error msg to stderr. |
|
|
|
* appropriate error msg to stderr. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
bool LDBCommand::ValidateCmdLineOptions() { |
|
|
|
bool LDBCommand::ValidateCmdLineOptions() { |
|
|
|
for (std::map<std::string, std::string>::const_iterator itr = |
|
|
|
for (auto itr = option_map_.begin(); itr != option_map_.end(); ++itr) { |
|
|
|
option_map_.begin(); |
|
|
|
|
|
|
|
itr != option_map_.end(); ++itr) { |
|
|
|
|
|
|
|
if (std::find(valid_cmd_line_options_.begin(), |
|
|
|
if (std::find(valid_cmd_line_options_.begin(), |
|
|
|
valid_cmd_line_options_.end(), |
|
|
|
valid_cmd_line_options_.end(), |
|
|
|
itr->first) == valid_cmd_line_options_.end()) { |
|
|
|
itr->first) == valid_cmd_line_options_.end()) { |
|
|
@ -884,7 +1052,7 @@ bool LDBCommand::IsValueHex(const std::map<std::string, std::string>& options, |
|
|
|
bool LDBCommand::ParseBooleanOption( |
|
|
|
bool LDBCommand::ParseBooleanOption( |
|
|
|
const std::map<std::string, std::string>& options, |
|
|
|
const std::map<std::string, std::string>& options, |
|
|
|
const std::string& option, bool default_val) { |
|
|
|
const std::string& option, bool default_val) { |
|
|
|
std::map<std::string, std::string>::const_iterator itr = options.find(option); |
|
|
|
auto itr = options.find(option); |
|
|
|
if (itr != options.end()) { |
|
|
|
if (itr != options.end()) { |
|
|
|
std::string option_val = itr->second; |
|
|
|
std::string option_val = itr->second; |
|
|
|
return StringToBool(itr->second); |
|
|
|
return StringToBool(itr->second); |
|
|
@ -914,8 +1082,7 @@ CompactorCommand::CompactorCommand( |
|
|
|
ARG_VALUE_HEX, ARG_TTL})), |
|
|
|
ARG_VALUE_HEX, ARG_TTL})), |
|
|
|
null_from_(true), |
|
|
|
null_from_(true), |
|
|
|
null_to_(true) { |
|
|
|
null_to_(true) { |
|
|
|
std::map<std::string, std::string>::const_iterator itr = |
|
|
|
auto itr = options.find(ARG_FROM); |
|
|
|
options.find(ARG_FROM); |
|
|
|
|
|
|
|
if (itr != options.end()) { |
|
|
|
if (itr != options.end()) { |
|
|
|
null_from_ = false; |
|
|
|
null_from_ = false; |
|
|
|
from_ = itr->second; |
|
|
|
from_ = itr->second; |
|
|
@ -1122,8 +1289,7 @@ ManifestDumpCommand::ManifestDumpCommand( |
|
|
|
verbose_ = IsFlagPresent(flags, ARG_VERBOSE); |
|
|
|
verbose_ = IsFlagPresent(flags, ARG_VERBOSE); |
|
|
|
json_ = IsFlagPresent(flags, ARG_JSON); |
|
|
|
json_ = IsFlagPresent(flags, ARG_JSON); |
|
|
|
|
|
|
|
|
|
|
|
std::map<std::string, std::string>::const_iterator itr = |
|
|
|
auto itr = options.find(ARG_PATH); |
|
|
|
options.find(ARG_PATH); |
|
|
|
|
|
|
|
if (itr != options.end()) { |
|
|
|
if (itr != options.end()) { |
|
|
|
path_ = itr->second; |
|
|
|
path_ = itr->second; |
|
|
|
if (path_.empty()) { |
|
|
|
if (path_.empty()) { |
|
|
@ -1264,8 +1430,7 @@ FileChecksumDumpCommand::FileChecksumDumpCommand( |
|
|
|
: LDBCommand(options, flags, false, |
|
|
|
: LDBCommand(options, flags, false, |
|
|
|
BuildCmdLineOptions({ARG_PATH, ARG_HEX})), |
|
|
|
BuildCmdLineOptions({ARG_PATH, ARG_HEX})), |
|
|
|
path_("") { |
|
|
|
path_("") { |
|
|
|
std::map<std::string, std::string>::const_iterator itr = |
|
|
|
auto itr = options.find(ARG_PATH); |
|
|
|
options.find(ARG_PATH); |
|
|
|
|
|
|
|
if (itr != options.end()) { |
|
|
|
if (itr != options.end()) { |
|
|
|
path_ = itr->second; |
|
|
|
path_ = itr->second; |
|
|
|
if (path_.empty()) { |
|
|
|
if (path_.empty()) { |
|
|
@ -1540,8 +1705,7 @@ InternalDumpCommand::InternalDumpCommand( |
|
|
|
has_to_ = ParseStringOption(options, ARG_TO, &to_); |
|
|
|
has_to_ = ParseStringOption(options, ARG_TO, &to_); |
|
|
|
|
|
|
|
|
|
|
|
ParseIntOption(options, ARG_MAX_KEYS, max_keys_, exec_state_); |
|
|
|
ParseIntOption(options, ARG_MAX_KEYS, max_keys_, exec_state_); |
|
|
|
std::map<std::string, std::string>::const_iterator itr = |
|
|
|
auto itr = options.find(ARG_COUNT_DELIM); |
|
|
|
options.find(ARG_COUNT_DELIM); |
|
|
|
|
|
|
|
if (itr != options.end()) { |
|
|
|
if (itr != options.end()) { |
|
|
|
delim_ = itr->second; |
|
|
|
delim_ = itr->second; |
|
|
|
count_delim_ = true; |
|
|
|
count_delim_ = true; |
|
|
@ -1676,8 +1840,7 @@ DBDumperCommand::DBDumperCommand( |
|
|
|
count_only_(false), |
|
|
|
count_only_(false), |
|
|
|
count_delim_(false), |
|
|
|
count_delim_(false), |
|
|
|
print_stats_(false) { |
|
|
|
print_stats_(false) { |
|
|
|
std::map<std::string, std::string>::const_iterator itr = |
|
|
|
auto itr = options.find(ARG_FROM); |
|
|
|
options.find(ARG_FROM); |
|
|
|
|
|
|
|
if (itr != options.end()) { |
|
|
|
if (itr != options.end()) { |
|
|
|
null_from_ = false; |
|
|
|
null_from_ = false; |
|
|
|
from_ = itr->second; |
|
|
|
from_ = itr->second; |
|
|
@ -2442,8 +2605,7 @@ WALDumperCommand::WALDumperCommand( |
|
|
|
is_write_committed_(false) { |
|
|
|
is_write_committed_(false) { |
|
|
|
wal_file_.clear(); |
|
|
|
wal_file_.clear(); |
|
|
|
|
|
|
|
|
|
|
|
std::map<std::string, std::string>::const_iterator itr = |
|
|
|
auto itr = options.find(ARG_WAL_FILE); |
|
|
|
options.find(ARG_WAL_FILE); |
|
|
|
|
|
|
|
if (itr != options.end()) { |
|
|
|
if (itr != options.end()) { |
|
|
|
wal_file_ = itr->second; |
|
|
|
wal_file_ = itr->second; |
|
|
|
} |
|
|
|
} |
|
|
@ -2662,8 +2824,7 @@ ScanCommand::ScanCommand(const std::vector<std::string>& /*params*/, |
|
|
|
end_key_specified_(false), |
|
|
|
end_key_specified_(false), |
|
|
|
max_keys_scanned_(-1), |
|
|
|
max_keys_scanned_(-1), |
|
|
|
no_value_(false) { |
|
|
|
no_value_(false) { |
|
|
|
std::map<std::string, std::string>::const_iterator itr = |
|
|
|
auto itr = options.find(ARG_FROM); |
|
|
|
options.find(ARG_FROM); |
|
|
|
|
|
|
|
if (itr != options.end()) { |
|
|
|
if (itr != options.end()) { |
|
|
|
start_key_ = itr->second; |
|
|
|
start_key_ = itr->second; |
|
|
|
if (is_key_hex_) { |
|
|
|
if (is_key_hex_) { |
|
|
@ -3750,8 +3911,7 @@ ListFileRangeDeletesCommand::ListFileRangeDeletesCommand( |
|
|
|
const std::map<std::string, std::string>& options, |
|
|
|
const std::map<std::string, std::string>& options, |
|
|
|
const std::vector<std::string>& flags) |
|
|
|
const std::vector<std::string>& flags) |
|
|
|
: LDBCommand(options, flags, true, BuildCmdLineOptions({ARG_MAX_KEYS})) { |
|
|
|
: LDBCommand(options, flags, true, BuildCmdLineOptions({ARG_MAX_KEYS})) { |
|
|
|
std::map<std::string, std::string>::const_iterator itr = |
|
|
|
auto itr = options.find(ARG_MAX_KEYS); |
|
|
|
options.find(ARG_MAX_KEYS); |
|
|
|
|
|
|
|
if (itr != options.end()) { |
|
|
|
if (itr != options.end()) { |
|
|
|
try { |
|
|
|
try { |
|
|
|
#if defined(CYGWIN) |
|
|
|
#if defined(CYGWIN) |
|
|
|