libabigail/tools/binilint.cc
Dodji Seketeli 74b9337efc Implement the abigail::ini::config abstraction
* include/abg-ini.h (config::config): Add an overload that take a
	path and sections.
	(config::{get,set}_sections): New accessors.
	(read_sections): Rename the previous read_config() functions into
	these.
	(read_config): Add these function declarations to really act on
	instances of abigail::ini::config.
	(write_section): Rename the previous write_config functions into
	these.
	(write_config): Add these function declarations to really act on
	instances of abigail::ini::config.
	* src/abg-ini.cc (class config::priv): Implement this.
	(config::{config, ~config, get_path, set_path, get_sections,
	set_sections}): Define these new methods.
	(read_sections): Rename the former read_config into this.
	(read_config): Add this function definitions to really act on
	instances of abigail::ini::config.
	(write_sections): Rename the former write_config into this.
	(write_config):: Add this function definitions to really act on
	instances of abigail::ini::config.
	* tools/binilint.cc (main): Adjust.

Signed-off-by: Dodji Seketeli <dodji@redhat.com>
2014-10-13 17:44:43 +02:00

136 lines
3.4 KiB
C++

// -*- 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 <http://www.gnu.org/licenses/>.
// 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 <cstring>
#include <iostream>
#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] <ini file>\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;
}