mirror of
git://sourceware.org/git/libabigail.git
synced 2025-01-11 11:59:32 +00:00
74b9337efc
* 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>
136 lines
3.4 KiB
C++
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;
|
|
}
|