[thin_delta] Clean up duplicated code
This commit is contained in:
parent
b42408ef41
commit
1d5b52b0dd
@ -22,47 +22,7 @@ using namespace thin_provisioning;
|
|||||||
|
|
||||||
//----------------------------------------------------------------
|
//----------------------------------------------------------------
|
||||||
|
|
||||||
namespace local {
|
namespace {
|
||||||
class application {
|
|
||||||
public:
|
|
||||||
application(string const &cmd)
|
|
||||||
: cmd_(cmd) {
|
|
||||||
}
|
|
||||||
|
|
||||||
void usage(ostream &out) {
|
|
||||||
out << "Usage: " << cmd_ << " [options] <device or file>\n"
|
|
||||||
<< "Options:\n"
|
|
||||||
<< " {--thin1, --snap1}\n"
|
|
||||||
<< " {--thin2, --snap2}\n"
|
|
||||||
<< " {-m, --metadata-snap} [block#]\n"
|
|
||||||
<< " {--verbose}\n"
|
|
||||||
<< " {-h|--help}\n"
|
|
||||||
<< " {-V|--version}" << endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
void die(string const &msg) {
|
|
||||||
cerr << msg << endl;
|
|
||||||
usage(cerr);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
uint64_t parse_int(string const &str, string const &desc) {
|
|
||||||
try {
|
|
||||||
return boost::lexical_cast<uint64_t>(str);
|
|
||||||
|
|
||||||
} catch (...) {
|
|
||||||
ostringstream out;
|
|
||||||
out << "Couldn't parse " << desc << ": '" << str << "'";
|
|
||||||
die(out.str());
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0; // never get here
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
string cmd_;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct flags {
|
struct flags {
|
||||||
flags()
|
flags()
|
||||||
: verbose(false),
|
: verbose(false),
|
||||||
@ -96,13 +56,6 @@ namespace local {
|
|||||||
uint64_t vbegin_, dbegin_, len_;
|
uint64_t vbegin_, dbegin_, len_;
|
||||||
};
|
};
|
||||||
|
|
||||||
ostream &operator <<(ostream &out, mapping const &m) {
|
|
||||||
out << "mapping[vbegin = " << m.vbegin_
|
|
||||||
<< ", dbegin = " << m.dbegin_
|
|
||||||
<< ", len = " << m.len_ << "]";
|
|
||||||
return out;
|
|
||||||
}
|
|
||||||
|
|
||||||
//--------------------------------
|
//--------------------------------
|
||||||
|
|
||||||
template <typename Container>
|
template <typename Container>
|
||||||
@ -540,7 +493,7 @@ namespace local {
|
|||||||
out << "</diff>\n";
|
out << "</diff>\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
void delta_(application &app, flags const &fs) {
|
void delta_(flags const &fs) {
|
||||||
mapping_recorder mr1;
|
mapping_recorder mr1;
|
||||||
mapping_recorder mr2;
|
mapping_recorder mr2;
|
||||||
damage_visitor damage_v;
|
damage_visitor damage_v;
|
||||||
@ -558,7 +511,7 @@ namespace local {
|
|||||||
if (!snap1_root) {
|
if (!snap1_root) {
|
||||||
ostringstream out;
|
ostringstream out;
|
||||||
out << "Unable to find mapping tree for snap1 (" << *fs.snap1 << ")";
|
out << "Unable to find mapping tree for snap1 (" << *fs.snap1 << ")";
|
||||||
app.die(out.str());
|
throw std::runtime_error(out.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
single_mapping_tree snap1(*md->tm_, *snap1_root,
|
single_mapping_tree snap1(*md->tm_, *snap1_root,
|
||||||
@ -570,7 +523,7 @@ namespace local {
|
|||||||
if (!snap2_root) {
|
if (!snap2_root) {
|
||||||
ostringstream out;
|
ostringstream out;
|
||||||
out << "Unable to find mapping tree for snap2 (" << *fs.snap2 << ")";
|
out << "Unable to find mapping tree for snap2 (" << *fs.snap2 << ")";
|
||||||
app.die(out.str());
|
throw std::runtime_error(out.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
single_mapping_tree snap2(*md->tm_, *snap2_root,
|
single_mapping_tree snap2(*md->tm_, *snap2_root,
|
||||||
@ -607,12 +560,12 @@ namespace local {
|
|||||||
end_superblock(is);
|
end_superblock(is);
|
||||||
}
|
}
|
||||||
|
|
||||||
int delta(application &app, flags const &fs) {
|
int delta(flags const &fs) {
|
||||||
try {
|
try {
|
||||||
delta_(app, fs);
|
delta_(fs);
|
||||||
} catch (exception const &e) {
|
} catch (exception const &e) {
|
||||||
app.die(e.what());
|
cerr << e.what() << endl;
|
||||||
return 1; // never get here
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -631,27 +584,31 @@ thin_delta_cmd::thin_delta_cmd()
|
|||||||
void
|
void
|
||||||
thin_delta_cmd::usage(std::ostream &out) const
|
thin_delta_cmd::usage(std::ostream &out) const
|
||||||
{
|
{
|
||||||
// FIXME: finish
|
out << "Usage: " << get_name() << " [options] <device or file>\n"
|
||||||
|
<< "Options:\n"
|
||||||
|
<< " {--thin1, --snap1}\n"
|
||||||
|
<< " {--thin2, --snap2}\n"
|
||||||
|
<< " {-m, --metadata-snap} [block#]\n"
|
||||||
|
<< " {--verbose}\n"
|
||||||
|
<< " {-h|--help}\n"
|
||||||
|
<< " {-V|--version}" << endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
thin_delta_cmd::run(int argc, char **argv)
|
thin_delta_cmd::run(int argc, char **argv)
|
||||||
{
|
{
|
||||||
using namespace local;
|
|
||||||
|
|
||||||
int c;
|
int c;
|
||||||
flags fs;
|
flags fs;
|
||||||
local::application app(basename(argv[0]));
|
|
||||||
|
|
||||||
char const shortopts[] = "hVm::";
|
char const shortopts[] = "hVm::";
|
||||||
option const longopts[] = {
|
option const longopts[] = {
|
||||||
{ "help", no_argument, NULL, 'h' },
|
{ "help", no_argument, NULL, 'h' },
|
||||||
|
{ "metadata-snap", optional_argument, NULL, 'm' },
|
||||||
{ "version", no_argument, NULL, 'V' },
|
{ "version", no_argument, NULL, 'V' },
|
||||||
{ "thin1", required_argument, NULL, 1 },
|
{ "thin1", required_argument, NULL, 1 },
|
||||||
{ "snap1", required_argument, NULL, 1 },
|
{ "snap1", required_argument, NULL, 1 },
|
||||||
{ "thin2", required_argument, NULL, 2 },
|
{ "thin2", required_argument, NULL, 2 },
|
||||||
{ "snap2", required_argument, NULL, 2 },
|
{ "snap2", required_argument, NULL, 2 },
|
||||||
{ "metadata-snap", optional_argument, NULL, 'm' },
|
|
||||||
{ "verbose", no_argument, NULL, 4 },
|
{ "verbose", no_argument, NULL, 4 },
|
||||||
{ NULL, no_argument, NULL, 0 }
|
{ NULL, no_argument, NULL, 0 }
|
||||||
};
|
};
|
||||||
@ -659,25 +616,25 @@ thin_delta_cmd::run(int argc, char **argv)
|
|||||||
while ((c = getopt_long(argc, argv, shortopts, longopts, NULL)) != -1) {
|
while ((c = getopt_long(argc, argv, shortopts, longopts, NULL)) != -1) {
|
||||||
switch (c) {
|
switch (c) {
|
||||||
case 'h':
|
case 'h':
|
||||||
app.usage(cout);
|
usage(cout);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
case 'm':
|
||||||
|
fs.use_metadata_snap = true;
|
||||||
|
if (optarg)
|
||||||
|
fs.metadata_snap = parse_uint64(optarg, "metadata snapshot block");
|
||||||
|
break;
|
||||||
|
|
||||||
case 'V':
|
case 'V':
|
||||||
cout << THIN_PROVISIONING_TOOLS_VERSION << endl;
|
cout << THIN_PROVISIONING_TOOLS_VERSION << endl;
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case 1:
|
case 1:
|
||||||
fs.snap1 = app.parse_int(optarg, "thin id 1");
|
fs.snap1 = parse_uint64(optarg, "thin id 1");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 2:
|
case 2:
|
||||||
fs.snap2 = app.parse_int(optarg, "thin id 2");
|
fs.snap2 = parse_uint64(optarg, "thin id 2");
|
||||||
break;
|
|
||||||
|
|
||||||
case 'm':
|
|
||||||
fs.use_metadata_snap = true;
|
|
||||||
if (optarg)
|
|
||||||
fs.metadata_snap = app.parse_int(optarg, "metadata snapshot block");
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
@ -685,23 +642,23 @@ thin_delta_cmd::run(int argc, char **argv)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
app.usage(cerr);
|
usage(cerr);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (argc == optind)
|
if (argc == optind)
|
||||||
app.die("No input device provided.");
|
die("No input device provided.");
|
||||||
else
|
else
|
||||||
fs.dev = argv[optind];
|
fs.dev = argv[optind];
|
||||||
|
|
||||||
if (!fs.snap1)
|
if (!fs.snap1)
|
||||||
app.die("--snap1 not specified.");
|
die("--snap1 not specified.");
|
||||||
|
|
||||||
if (!fs.snap2)
|
if (!fs.snap2)
|
||||||
app.die("--snap2 not specified.");
|
die("--snap2 not specified.");
|
||||||
|
|
||||||
return delta(app, fs);
|
return delta(fs);
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------
|
//----------------------------------------------------------------
|
||||||
|
Loading…
Reference in New Issue
Block a user