xref: /src/contrib/kyua/cli/cmd_config.cpp (revision b0d29bc47dba79f6f38e67eabadfb4b32ffd9390)
108334c51SBrooks Davis // Copyright 2011 The Kyua Authors.
208334c51SBrooks Davis // All rights reserved.
308334c51SBrooks Davis //
408334c51SBrooks Davis // Redistribution and use in source and binary forms, with or without
508334c51SBrooks Davis // modification, are permitted provided that the following conditions are
608334c51SBrooks Davis // met:
708334c51SBrooks Davis //
808334c51SBrooks Davis // * Redistributions of source code must retain the above copyright
908334c51SBrooks Davis //   notice, this list of conditions and the following disclaimer.
1008334c51SBrooks Davis // * Redistributions in binary form must reproduce the above copyright
1108334c51SBrooks Davis //   notice, this list of conditions and the following disclaimer in the
1208334c51SBrooks Davis //   documentation and/or other materials provided with the distribution.
1308334c51SBrooks Davis // * Neither the name of Google Inc. nor the names of its contributors
1408334c51SBrooks Davis //   may be used to endorse or promote products derived from this software
1508334c51SBrooks Davis //   without specific prior written permission.
1608334c51SBrooks Davis //
1708334c51SBrooks Davis // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
1808334c51SBrooks Davis // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
1908334c51SBrooks Davis // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
2008334c51SBrooks Davis // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
2108334c51SBrooks Davis // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
2208334c51SBrooks Davis // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
2308334c51SBrooks Davis // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
2408334c51SBrooks Davis // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
2508334c51SBrooks Davis // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
2608334c51SBrooks Davis // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
2708334c51SBrooks Davis // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
2808334c51SBrooks Davis 
2908334c51SBrooks Davis #include "cli/cmd_config.hpp"
3008334c51SBrooks Davis 
3108334c51SBrooks Davis #include <cstdlib>
3208334c51SBrooks Davis 
3308334c51SBrooks Davis #include "cli/common.ipp"
3408334c51SBrooks Davis #include "utils/cmdline/parser.ipp"
3508334c51SBrooks Davis #include "utils/cmdline/ui.hpp"
3608334c51SBrooks Davis #include "utils/config/tree.ipp"
3708334c51SBrooks Davis #include "utils/format/macros.hpp"
3808334c51SBrooks Davis 
3908334c51SBrooks Davis namespace cmdline = utils::cmdline;
4008334c51SBrooks Davis namespace config = utils::config;
4108334c51SBrooks Davis 
4208334c51SBrooks Davis using cli::cmd_config;
4308334c51SBrooks Davis 
4408334c51SBrooks Davis 
4508334c51SBrooks Davis namespace {
4608334c51SBrooks Davis 
4708334c51SBrooks Davis 
4808334c51SBrooks Davis /// Prints all configuration variables.
4908334c51SBrooks Davis ///
5008334c51SBrooks Davis /// \param ui Object to interact with the I/O of the program.
5108334c51SBrooks Davis /// \param properties The key/value map representing all the configuration
5208334c51SBrooks Davis ///     variables.
5308334c51SBrooks Davis ///
5408334c51SBrooks Davis /// \return 0 for success.
5508334c51SBrooks Davis static int
print_all(cmdline::ui * ui,const config::properties_map & properties)5608334c51SBrooks Davis print_all(cmdline::ui* ui, const config::properties_map& properties)
5708334c51SBrooks Davis {
5808334c51SBrooks Davis     for (config::properties_map::const_iterator iter = properties.begin();
5908334c51SBrooks Davis          iter != properties.end(); iter++)
6008334c51SBrooks Davis         ui->out(F("%s = %s") % (*iter).first % (*iter).second);
6108334c51SBrooks Davis     return EXIT_SUCCESS;
6208334c51SBrooks Davis }
6308334c51SBrooks Davis 
6408334c51SBrooks Davis 
6508334c51SBrooks Davis /// Prints the configuration variables that the user requests.
6608334c51SBrooks Davis ///
6708334c51SBrooks Davis /// \param ui Object to interact with the I/O of the program.
6808334c51SBrooks Davis /// \param properties The key/value map representing all the configuration
6908334c51SBrooks Davis ///     variables.
7008334c51SBrooks Davis /// \param filters The names of the configuration variables to print.
7108334c51SBrooks Davis ///
7208334c51SBrooks Davis /// \return 0 if all specified filters are valid; 1 otherwise.
7308334c51SBrooks Davis static int
print_some(cmdline::ui * ui,const config::properties_map & properties,const cmdline::args_vector & filters)7408334c51SBrooks Davis print_some(cmdline::ui* ui, const config::properties_map& properties,
7508334c51SBrooks Davis            const cmdline::args_vector& filters)
7608334c51SBrooks Davis {
7708334c51SBrooks Davis     bool ok = true;
7808334c51SBrooks Davis 
7908334c51SBrooks Davis     for (cmdline::args_vector::const_iterator iter = filters.begin();
8008334c51SBrooks Davis          iter != filters.end(); iter++) {
8108334c51SBrooks Davis         const config::properties_map::const_iterator match =
8208334c51SBrooks Davis             properties.find(*iter);
8308334c51SBrooks Davis         if (match == properties.end()) {
8408334c51SBrooks Davis             cmdline::print_warning(ui, F("'%s' is not defined.") % *iter);
8508334c51SBrooks Davis             ok = false;
8608334c51SBrooks Davis         } else
8708334c51SBrooks Davis             ui->out(F("%s = %s") % (*match).first % (*match).second);
8808334c51SBrooks Davis     }
8908334c51SBrooks Davis 
9008334c51SBrooks Davis     return ok ? EXIT_SUCCESS : EXIT_FAILURE;
9108334c51SBrooks Davis }
9208334c51SBrooks Davis 
9308334c51SBrooks Davis 
9408334c51SBrooks Davis }  // anonymous namespace
9508334c51SBrooks Davis 
9608334c51SBrooks Davis 
9708334c51SBrooks Davis /// Default constructor for cmd_config.
cmd_config(void)9808334c51SBrooks Davis cmd_config::cmd_config(void) : cli_command(
9908334c51SBrooks Davis     "config", "[variable1 .. variableN]", 0, -1,
10008334c51SBrooks Davis     "Inspects the values of configuration variables")
10108334c51SBrooks Davis {
10208334c51SBrooks Davis }
10308334c51SBrooks Davis 
10408334c51SBrooks Davis 
10508334c51SBrooks Davis /// Entry point for the "config" subcommand.
10608334c51SBrooks Davis ///
10708334c51SBrooks Davis /// \param ui Object to interact with the I/O of the program.
10808334c51SBrooks Davis /// \param cmdline Representation of the command line to the subcommand.
10908334c51SBrooks Davis /// \param user_config The runtime configuration of the program.
11008334c51SBrooks Davis ///
11108334c51SBrooks Davis /// \return 0 if everything is OK, 1 if any of the necessary documents cannot be
11208334c51SBrooks Davis /// opened.
11308334c51SBrooks Davis int
run(cmdline::ui * ui,const cmdline::parsed_cmdline & cmdline,const config::tree & user_config)11408334c51SBrooks Davis cmd_config::run(cmdline::ui* ui, const cmdline::parsed_cmdline& cmdline,
11508334c51SBrooks Davis                const config::tree& user_config)
11608334c51SBrooks Davis {
11708334c51SBrooks Davis     const config::properties_map properties = user_config.all_properties();
11808334c51SBrooks Davis     if (cmdline.arguments().empty())
11908334c51SBrooks Davis         return print_all(ui, properties);
12008334c51SBrooks Davis     else
12108334c51SBrooks Davis         return print_some(ui, properties, cmdline.arguments());
12208334c51SBrooks Davis }
123