// Copyright (C) 20011 Red Hat, Inc. All rights reserved.
//
// This file is part of the thin-provisioning-tools source.
//
// thin-provisioning-tools is free software: you can redistribute it
// and/or modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation, either version 3 of
// the License, or (at your option) any later version.
//
// thin-provisioning-tools is distributed in the hope that it will be
// useful, but WITHOUT ANY WARRANTY; without even the implied warranty
// of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License along
// with thin-provisioning-tools. If not, see
// .
#include "emitter.h"
#include "human_readable_format.h"
#include "metadata.h"
#include "restore_emitter.h"
#include "xml_format.h"
#include
#include
#include
using namespace persistent_data;
using namespace std;
using namespace thin_provisioning;
namespace po = boost::program_options;
//----------------------------------------------------------------
namespace {
void restore(string const &backup_file, string const &dev) {
// FIXME: hard coded
block_address const NR_BLOCKS = 100000;
metadata::ptr md(new metadata(dev, metadata::CREATE, 128, NR_BLOCKS));
emitter::ptr restorer = create_restore_emitter(md);
ifstream in(backup_file.c_str(), ifstream::in);
// FIXME:
//try {
parse_xml(in, restorer);
#if 0
} catch (...) {
in.close();
throw;
}
#endif
}
void usage(po::options_description const &desc) {
cerr << "Usage: thin_restore [options]" << endl << endl;
cerr << desc;
}
}
int main(int argc, char **argv)
{
po::options_description desc("Options");
desc.add_options()
("help", "Produce help message")
("input,i", po::value(), "Input file")
("output,o", po::value(), "Output file")
;
po::variables_map vm;
po::store(po::command_line_parser(argc, argv).options(desc).run(), vm);
po::notify(vm);
if (vm.count("help")) {
usage(desc);
return 0;
}
if (vm.count("input") != 1) {
cerr << "No input file provided." << endl;
usage(desc);
return 1;
}
if (vm.count("output") != 1) {
cerr << "No output file provided." << endl;
usage(desc);
return 1;
}
restore(vm["input"].as(),
vm["output"].as());
return 0;
}
//----------------------------------------------------------------