At the moment, there are multiple copies of "get_image_or_snap_spec".
For this reason, we're moving it to Utils.cc so that all backends may
re-use it, also benefiting from the recent pool related fix.
We are also renaming parse_options to append_options_as_args and
changing its type to void
Signed-off-by: Stefan Chivu <schivu@cloudbasesolutions.com>
return 0;
}
+int get_image_or_snap_spec(const po::variables_map &vm, std::string *spec) {
+ size_t arg_index = 0;
+ std::string pool_name;
+ std::string nspace_name;
+ std::string image_name;
+ std::string snap_name;
+ int r = get_pool_image_snapshot_names(
+ vm, at::ARGUMENT_MODIFIER_NONE, &arg_index, &pool_name, &nspace_name,
+ &image_name, &snap_name, true, SNAPSHOT_PRESENCE_PERMITTED,
+ SPEC_VALIDATION_NONE);
+ if (r < 0) {
+ return r;
+ }
+
+ if (pool_name.empty()) {
+ // connect to the cluster to get the default pool
+ librados::Rados rados;
+ r = init_rados(&rados);
+ if (r < 0) {
+ return r;
+ }
+
+ normalize_pool_name(&pool_name);
+ }
+
+ spec->append(pool_name);
+ spec->append("/");
+ if (!nspace_name.empty()) {
+ spec->append(nspace_name);
+ spec->append("/");
+ }
+ spec->append(image_name);
+ if (!snap_name.empty()) {
+ spec->append("@");
+ spec->append(snap_name);
+ }
+
+ return 0;
+}
+
+void append_options_as_args(const std::vector<std::string> &options,
+ std::vector<std::string> *args) {
+ for (auto &opts : options) {
+ std::vector<std::string> args_;
+ boost::split(args_, opts, boost::is_any_of(","));
+ for (auto &o : args_) {
+ args->push_back("--" + o);
+ }
+ }
+}
+
int get_pool_image_snapshot_names(const po::variables_map &vm,
at::ArgumentModifier mod,
size_t *spec_arg_index,
void normalize_pool_name(std::string* pool_name);
std::string get_default_pool_name();
+int get_image_or_snap_spec(const boost::program_options::variables_map &vm,
+ std::string *spec);
+
+void append_options_as_args(const std::vector<std::string> &options,
+ std::vector<std::string> *args);
+
int get_pool_and_namespace_names(
const boost::program_options::variables_map &vm, bool validate_pool_name,
std::string* pool_name, std::string* namespace_name, size_t *arg_index);
return 0;
}
-
-int get_image_or_snap_spec(const po::variables_map &vm, std::string *spec) {
- size_t arg_index = 0;
- std::string pool_name;
- std::string nspace_name;
- std::string image_name;
- std::string snap_name;
- int r = utils::get_pool_image_snapshot_names(
- vm, at::ARGUMENT_MODIFIER_NONE, &arg_index, &pool_name, &nspace_name,
- &image_name, &snap_name, true,
- utils::SNAPSHOT_PRESENCE_PERMITTED, utils::SPEC_VALIDATION_NONE);
- if (r < 0) {
- return r;
- }
-
- if (pool_name.empty()) {
- // connect to the cluster to get the default pool
- librados::Rados rados;
- r = utils::init_rados(&rados);
- if (r < 0) {
- return r;
- }
-
- utils::normalize_pool_name(&pool_name);
- }
-
- spec->append(pool_name);
- spec->append("/");
- if (!nspace_name.empty()) {
- spec->append(nspace_name);
- spec->append("/");
- }
- spec->append(image_name);
- if (!snap_name.empty()) {
- spec->append("@");
- spec->append(snap_name);
- }
-
- return 0;
-}
-
-int parse_options(const std::vector<std::string> &options,
- std::vector<std::string> *args) {
- for (auto &opts : options) {
- std::vector<std::string> args_;
- boost::split(args_, opts, boost::is_any_of(","));
- for (auto &o : args_) {
- args->push_back("--" + o);
- }
- }
-
- return 0;
-}
#endif
int execute_list(const po::variables_map &vm,
args.push_back("map");
std::string img;
- int r = get_image_or_snap_spec(vm, &img);
+ int r = utils::get_image_or_snap_spec(vm, &img);
if (r < 0) {
return r;
}
}
if (vm.count("options")) {
- r = parse_options(vm["options"].as<std::vector<std::string>>(), &args);
- if (r < 0) {
- return r;
- }
+ utils::append_options_as_args(vm["options"].as<std::vector<std::string>>(),
+ &args);
}
return call_ggate_cmd(vm, args, ceph_global_init_args);
std::string image_name;
if (device_name.empty()) {
- int r = get_image_or_snap_spec(vm, &image_name);
+ int r = utils::get_image_or_snap_spec(vm, &image_name);
if (r < 0) {
return r;
}
args.push_back(device_name.empty() ? image_name : device_name);
if (vm.count("options")) {
- int r = parse_options(vm["options"].as<std::vector<std::string>>(), &args);
- if (r < 0) {
- return r;
- }
+ utils::append_options_as_args(vm["options"].as<std::vector<std::string>>(),
+ &args);
}
return call_ggate_cmd(vm, args, ceph_global_init_args);
#endif
}
-#if !defined(__FreeBSD__) && !defined(_WIN32)
-int get_image_or_snap_spec(const po::variables_map &vm, std::string *spec) {
- size_t arg_index = 0;
- std::string pool_name;
- std::string nspace_name;
- std::string image_name;
- std::string snap_name;
- int r = utils::get_pool_image_snapshot_names(
- vm, at::ARGUMENT_MODIFIER_NONE, &arg_index, &pool_name, &nspace_name,
- &image_name, &snap_name, true, utils::SNAPSHOT_PRESENCE_PERMITTED,
- utils::SPEC_VALIDATION_NONE);
- if (r < 0) {
- return r;
- }
-
- if (pool_name.empty()) {
- // connect to the cluster to get the default pool
- librados::Rados rados;
- r = utils::init_rados(&rados);
- if (r < 0) {
- return r;
- }
-
- utils::normalize_pool_name(&pool_name);
- }
-
- spec->append(pool_name);
- spec->append("/");
- if (!nspace_name.empty()) {
- spec->append(nspace_name);
- spec->append("/");
- }
- spec->append(image_name);
- if (!snap_name.empty()) {
- spec->append("@");
- spec->append(snap_name);
- }
-
- return 0;
-}
-
-int parse_options(const std::vector<std::string> &options,
- std::vector<std::string> *args) {
- for (auto &opts : options) {
- std::vector<std::string> args_;
- boost::split(args_, opts, boost::is_any_of(","));
- for (auto &o : args_) {
- args->push_back("--" + o);
- }
- }
-
- return 0;
-}
-#endif
-
int execute_list(const po::variables_map &vm,
const std::vector<std::string> &ceph_global_init_args) {
#if defined(__FreeBSD__) || defined(_WIN32)
args.push_back("attach");
std::string img;
- int r = get_image_or_snap_spec(vm, &img);
+ int r = utils::get_image_or_snap_spec(vm, &img);
if (r < 0) {
return r;
}
}
if (vm.count("options")) {
- r = parse_options(vm["options"].as<std::vector<std::string>>(), &args);
- if (r < 0) {
- return r;
- }
+ utils::append_options_as_args(vm["options"].as<std::vector<std::string>>(),
+ &args);
}
return call_nbd_cmd(vm, args, ceph_global_init_args);
std::string image_name;
if (device_name.empty()) {
- int r = get_image_or_snap_spec(vm, &image_name);
+ int r = utils::get_image_or_snap_spec(vm, &image_name);
if (r < 0) {
return r;
}
args.push_back(device_name.empty() ? image_name : device_name);
if (vm.count("options")) {
- int r = parse_options(vm["options"].as<std::vector<std::string>>(), &args);
- if (r < 0) {
- return r;
- }
+ utils::append_options_as_args(vm["options"].as<std::vector<std::string>>(),
+ &args);
}
return call_nbd_cmd(vm, args, ceph_global_init_args);
args.push_back("map");
std::string img;
- int r = get_image_or_snap_spec(vm, &img);
+ int r = utils::get_image_or_snap_spec(vm, &img);
if (r < 0) {
return r;
}
}
if (vm.count("options")) {
- r = parse_options(vm["options"].as<std::vector<std::string>>(), &args);
- if (r < 0) {
- return r;
- }
+ utils::append_options_as_args(vm["options"].as<std::vector<std::string>>(),
+ &args);
}
return call_nbd_cmd(vm, args, ceph_global_init_args);
std::string image_name;
if (device_name.empty()) {
- int r = get_image_or_snap_spec(vm, &image_name);
+ int r = utils::get_image_or_snap_spec(vm, &image_name);
if (r < 0) {
return r;
}
args.push_back(device_name.empty() ? image_name : device_name);
if (vm.count("options")) {
- int r = parse_options(vm["options"].as<std::vector<std::string>>(), &args);
- if (r < 0) {
- return r;
- }
+ utils::append_options_as_args(vm["options"].as<std::vector<std::string>>(),
+ &args);
}
return call_nbd_cmd(vm, args, ceph_global_init_args);
return 0;
}
-
-int get_image_or_snap_spec(const po::variables_map &vm, std::string *spec) {
- size_t arg_index = 0;
- std::string pool_name;
- std::string nspace_name;
- std::string image_name;
- std::string snap_name;
- int r = utils::get_pool_image_snapshot_names(
- vm, at::ARGUMENT_MODIFIER_NONE, &arg_index, &pool_name, &nspace_name,
- &image_name, &snap_name, true, utils::SNAPSHOT_PRESENCE_PERMITTED,
- utils::SPEC_VALIDATION_NONE);
- if (r < 0) {
- return r;
- }
-
- if (!pool_name.empty()) {
- spec->append(pool_name);
- spec->append("/");
- }
- if (!nspace_name.empty()) {
- spec->append(nspace_name);
- spec->append("/");
- }
- spec->append(image_name);
- if (!snap_name.empty()) {
- spec->append("@");
- spec->append(snap_name);
- }
-
- return 0;
-}
-
-int parse_options(const std::vector<std::string> &options,
- std::vector<std::string> *args) {
- for (auto &opts : options) {
- std::vector<std::string> args_;
- boost::split(args_, opts, boost::is_any_of(","));
- for (auto &o : args_) {
- args->push_back("--" + o);
- }
- }
-
- return 0;
-}
#endif
int execute_list(const po::variables_map &vm,
args.push_back("map");
std::string img;
- int r = get_image_or_snap_spec(vm, &img);
+ int r = utils::get_image_or_snap_spec(vm, &img);
if (r < 0) {
return r;
}
}
if (vm.count("options")) {
- r = parse_options(vm["options"].as<std::vector<std::string>>(), &args);
- if (r < 0) {
- return r;
- }
+ utils::append_options_as_args(vm["options"].as<std::vector<std::string>>(),
+ &args);
}
return call_wnbd_cmd(vm, args, ceph_global_init_args);
std::string image_name;
if (device_name.empty()) {
- int r = get_image_or_snap_spec(vm, &image_name);
+ int r = utils::get_image_or_snap_spec(vm, &image_name);
if (r < 0) {
return r;
}
args.push_back(device_name.empty() ? image_name : device_name);
if (vm.count("options")) {
- int r = parse_options(vm["options"].as<std::vector<std::string>>(), &args);
- if (r < 0) {
- return r;
- }
+ utils::append_options_as_args(vm["options"].as<std::vector<std::string>>(),
+ &args);
}
return call_wnbd_cmd(vm, args, ceph_global_init_args);