1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-04 09:18:36 +03:00

thin: read paramaters in front

Fill paramaters into lvconvert_params -
so we could use it independently on args()
This commit is contained in:
Zdenek Kabelac 2013-03-11 12:40:05 +01:00
parent 82eee72019
commit f572bf987e

View File

@ -18,9 +18,12 @@
#include "metadata.h" #include "metadata.h"
struct lvconvert_params { struct lvconvert_params {
int force;
int snapshot; int snapshot;
int merge; int merge;
int merge_mirror; int merge_mirror;
int thin;
int yes;
int zero; int zero;
const char *origin; const char *origin;
@ -97,12 +100,12 @@ static int _lvconvert_name_params(struct lvconvert_params *lp,
if (lp->pool_data_lv_name) { if (lp->pool_data_lv_name) {
if (*pargc) { if (*pargc) {
if (!arg_count(cmd, thin_ARG)) { if (!lp->thin) {
log_error("More then one logical volume name specified."); log_error("More then one logical volume name specified.");
return 0; return 0;
} }
} else { } else {
if (arg_count(cmd, thin_ARG)) { if (lp->thin) {
log_error("External thin volume name is missing."); log_error("External thin volume name is missing.");
return 0; return 0;
} }
@ -219,6 +222,9 @@ static int _read_params(struct lvconvert_params *lp, struct cmd_context *cmd,
return 0; return 0;
} }
if (arg_count(cmd, thin_ARG))
lp->thin = 1;
if (arg_count(cmd, thinpool_ARG)) { if (arg_count(cmd, thinpool_ARG)) {
if (arg_count(cmd, merge_ARG)) { if (arg_count(cmd, merge_ARG)) {
log_error("--thinpool and --merge are mutually exlusive."); log_error("--thinpool and --merge are mutually exlusive.");
@ -241,7 +247,7 @@ static int _read_params(struct lvconvert_params *lp, struct cmd_context *cmd,
return 0; return 0;
} }
lp->discards = (thin_discards_t) arg_uint_value(cmd, discards_ARG, THIN_DISCARDS_PASSDOWN); lp->discards = (thin_discards_t) arg_uint_value(cmd, discards_ARG, THIN_DISCARDS_PASSDOWN);
} else if (arg_count(cmd, thin_ARG)) { } else if (lp->thin) {
log_error("--thin is only valid with --thinpool."); log_error("--thin is only valid with --thinpool.");
return 0; return 0;
} else if (arg_count(cmd, discards_ARG)) { } else if (arg_count(cmd, discards_ARG)) {
@ -488,6 +494,9 @@ static int _read_params(struct lvconvert_params *lp, struct cmd_context *cmd,
return_0; return_0;
} }
lp->force = arg_count(cmd, force_ARG);
lp->yes = arg_count(cmd, yes_ARG);
if (activation() && lp->segtype && lp->segtype->ops->target_present && if (activation() && lp->segtype && lp->segtype->ops->target_present &&
!lp->segtype->ops->target_present(cmd, NULL, &lp->target_attr)) { !lp->segtype->ops->target_present(cmd, NULL, &lp->target_attr)) {
log_error("%s: Required device-mapper target(s) not " log_error("%s: Required device-mapper target(s) not "
@ -2001,7 +2010,7 @@ static int _lvconvert_thinpool(struct cmd_context *cmd,
return 0; return 0;
} }
if (arg_count(cmd, thin_ARG)) { if (lp->thin) {
external_lv = pool_lv; external_lv = pool_lv;
if (!(pool_lv = find_lv(external_lv->vg, lp->pool_data_lv_name))) { if (!(pool_lv = find_lv(external_lv->vg, lp->pool_data_lv_name))) {
log_error("Can't find pool LV %s/%s.", log_error("Can't find pool LV %s/%s.",
@ -2072,7 +2081,7 @@ static int _lvconvert_thinpool(struct cmd_context *cmd,
log_error("Aborting. Failed to deactivate thin metadata lv."); log_error("Aborting. Failed to deactivate thin metadata lv.");
return 0; return 0;
} }
if (!arg_count(cmd, yes_ARG) && if (!lp->yes &&
yes_no_prompt("Do you want to swap metadata of %s/%s pool with " yes_no_prompt("Do you want to swap metadata of %s/%s pool with "
"volume %s/%s? [y/n]: ", "volume %s/%s? [y/n]: ",
pool_lv->vg->name, pool_lv->name, pool_lv->vg->name, pool_lv->name,
@ -2093,7 +2102,7 @@ static int _lvconvert_thinpool(struct cmd_context *cmd,
if (!arg_count(cmd, chunksize_ARG)) if (!arg_count(cmd, chunksize_ARG))
lp->chunk_size = seg->chunk_size; lp->chunk_size = seg->chunk_size;
else if ((lp->chunk_size != seg->chunk_size) && else if ((lp->chunk_size != seg->chunk_size) &&
!arg_count(cmd, force_ARG) && !lp->force &&
yes_no_prompt("Do you really want to change chunk size %s to %s for %s/%s " yes_no_prompt("Do you really want to change chunk size %s to %s for %s/%s "
"pool volume? [y/n]: ", display_size(cmd, seg->chunk_size), "pool volume? [y/n]: ", display_size(cmd, seg->chunk_size),
display_size(cmd, lp->chunk_size), display_size(cmd, lp->chunk_size),