// -*- Mode: C++ -*-
//
// Copyright (C) 2013-2014 Red Hat, Inc.
//
// This file is part of the GNU Application Binary Interface Generic
// Analysis and Instrumentation Library (libabigail). This library is
// free software; you can redistribute it and/or modify it under the
// terms of the GNU Lesser General Public License as published by the
// Free Software Foundation; either version 3, or (at your option) any
// later version.
// This library 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 Lesser Public License for more details.
// You should have received a copy of the GNU Lesser General Public
// License along with this program; see the file COPYING-LGPLV3. If
// not, see .
// Author: Dodji Seketeli
/// @file
///
/// This is a tool that reads an ini file and, if it could read it OK,
/// prints it on its standard output. It's mainly meant to test the
/// abigail::ini::* functions, but one could also use it to make sure
/// that an ini file can be handled by the abigail::ini::* facilities
#include
#include
#include "abg-ini.h"
using std::cout;
using std::cerr;
using std::cin;
using std::string;
using std::ostream;
using abigail::ini::config;
using abigail::ini::config_sptr;
using abigail::ini::read_config;
using abigail::ini::write_config;
struct options
{
bool display_usage;
bool read_from_stdin;
bool no_out;
bool wrong_command_line_usage;
string path;
options ()
: display_usage(false),
read_from_stdin(false),
no_out(false),
wrong_command_line_usage(false)
{}
};
static void
display_usage(const string& prog_name, ostream& out)
{
out << "usage: " << prog_name << " [options] \n"
<< "where options can be:\n"
<< "--help display this help\n"
<< "--from-stdin read the input ini file from stdin\n"
<< "--noout do not output anything on stdout\n"
;
}
static bool
parse_command_line(int argc, char* argv[], options& opts)
{
if (argc == 1)
return false;
for (int i = 1; i < argc; ++i)
{
if (argv[i][0] != '-')
{
if (opts.path.empty())
opts.path = argv[i];
else
opts.wrong_command_line_usage = true;
}
else if (!strcmp(argv[i], "--help"))
opts.display_usage = true;
else if (!strcmp(argv[i], "--from-stdin"))
opts.read_from_stdin = true;
else if (!strcmp(argv[i], "--noout"))
opts.no_out = true;
else
return false;
}
return true;
}
int
main(int argc, char* argv[])
{
// First, parse the command line.
options opts;
if (argc == 1 || !parse_command_line(argc, argv, opts))
{
cerr << argv[0] << ": bad command usage\n"
<< "Try " << argv[0] << " --help for more information\n";
return 1;
}
// Then if we need to display the help, display it and get out.
if (opts.display_usage)
{
display_usage(argv[0], cout);
return 0;
}
// Otherwise, do the real work we are supposed to do after all.
// That real work is driven by the options the user set; these
// options are recorded in the opts variable.
config_sptr conf;
if (opts.read_from_stdin)
conf = read_config(cin);
else if (!opts.path.empty())
conf = read_config(opts.path);
if (conf && !opts.no_out)
write_config(*conf, std::cout);
return !conf;
}