1*b0d29bc4SBrooks Davis// Copyright 2010 The Kyua Authors. 2*b0d29bc4SBrooks Davis// All rights reserved. 3*b0d29bc4SBrooks Davis// 4*b0d29bc4SBrooks Davis// Redistribution and use in source and binary forms, with or without 5*b0d29bc4SBrooks Davis// modification, are permitted provided that the following conditions are 6*b0d29bc4SBrooks Davis// met: 7*b0d29bc4SBrooks Davis// 8*b0d29bc4SBrooks Davis// * Redistributions of source code must retain the above copyright 9*b0d29bc4SBrooks Davis// notice, this list of conditions and the following disclaimer. 10*b0d29bc4SBrooks Davis// * Redistributions in binary form must reproduce the above copyright 11*b0d29bc4SBrooks Davis// notice, this list of conditions and the following disclaimer in the 12*b0d29bc4SBrooks Davis// documentation and/or other materials provided with the distribution. 13*b0d29bc4SBrooks Davis// * Neither the name of Google Inc. nor the names of its contributors 14*b0d29bc4SBrooks Davis// may be used to endorse or promote products derived from this software 15*b0d29bc4SBrooks Davis// without specific prior written permission. 16*b0d29bc4SBrooks Davis// 17*b0d29bc4SBrooks Davis// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 18*b0d29bc4SBrooks Davis// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 19*b0d29bc4SBrooks Davis// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 20*b0d29bc4SBrooks Davis// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 21*b0d29bc4SBrooks Davis// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 22*b0d29bc4SBrooks Davis// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 23*b0d29bc4SBrooks Davis// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 24*b0d29bc4SBrooks Davis// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 25*b0d29bc4SBrooks Davis// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 26*b0d29bc4SBrooks Davis// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 27*b0d29bc4SBrooks Davis// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 28*b0d29bc4SBrooks Davis 29*b0d29bc4SBrooks Davis#if !defined(UTILS_CMDLINE_BASE_COMMAND_IPP) 30*b0d29bc4SBrooks Davis#define UTILS_CMDLINE_BASE_COMMAND_IPP 31*b0d29bc4SBrooks Davis 32*b0d29bc4SBrooks Davis#include "utils/cmdline/base_command.hpp" 33*b0d29bc4SBrooks Davis 34*b0d29bc4SBrooks Davis 35*b0d29bc4SBrooks Davisnamespace utils { 36*b0d29bc4SBrooks Davisnamespace cmdline { 37*b0d29bc4SBrooks Davis 38*b0d29bc4SBrooks Davis 39*b0d29bc4SBrooks Davis/// Adds an option to the command. 40*b0d29bc4SBrooks Davis/// 41*b0d29bc4SBrooks Davis/// This is to be called from the constructor of the subclass that implements 42*b0d29bc4SBrooks Davis/// the command. 43*b0d29bc4SBrooks Davis/// 44*b0d29bc4SBrooks Davis/// \param option_ The option to add. 45*b0d29bc4SBrooks Davistemplate< typename Option > 46*b0d29bc4SBrooks Davisvoid 47*b0d29bc4SBrooks Daviscommand_proto::add_option(const Option& option_) 48*b0d29bc4SBrooks Davis{ 49*b0d29bc4SBrooks Davis add_option_ptr(new Option(option_)); 50*b0d29bc4SBrooks Davis} 51*b0d29bc4SBrooks Davis 52*b0d29bc4SBrooks Davis 53*b0d29bc4SBrooks Davis/// Creates a new command. 54*b0d29bc4SBrooks Davis/// 55*b0d29bc4SBrooks Davis/// \param name_ The name of the command. Must be unique within the context of 56*b0d29bc4SBrooks Davis/// a program and have no spaces. 57*b0d29bc4SBrooks Davis/// \param arg_list_ A textual description of the arguments received by the 58*b0d29bc4SBrooks Davis/// command. May be empty. 59*b0d29bc4SBrooks Davis/// \param min_args_ The minimum number of arguments required by the command. 60*b0d29bc4SBrooks Davis/// \param max_args_ The maximum number of arguments required by the command. 61*b0d29bc4SBrooks Davis/// -1 means infinity. 62*b0d29bc4SBrooks Davis/// \param short_description_ A description of the purpose of the command. 63*b0d29bc4SBrooks Davistemplate< typename Data > 64*b0d29bc4SBrooks Davisbase_command< Data >::base_command(const std::string& name_, 65*b0d29bc4SBrooks Davis const std::string& arg_list_, 66*b0d29bc4SBrooks Davis const int min_args_, 67*b0d29bc4SBrooks Davis const int max_args_, 68*b0d29bc4SBrooks Davis const std::string& short_description_) : 69*b0d29bc4SBrooks Davis command_proto(name_, arg_list_, min_args_, max_args_, short_description_) 70*b0d29bc4SBrooks Davis{ 71*b0d29bc4SBrooks Davis} 72*b0d29bc4SBrooks Davis 73*b0d29bc4SBrooks Davis 74*b0d29bc4SBrooks Davis/// Entry point for the command. 75*b0d29bc4SBrooks Davis/// 76*b0d29bc4SBrooks Davis/// This delegates execution to the run() abstract function after the command 77*b0d29bc4SBrooks Davis/// line provided in args has been parsed. 78*b0d29bc4SBrooks Davis/// 79*b0d29bc4SBrooks Davis/// If this function returns, the command is assumed to have been executed 80*b0d29bc4SBrooks Davis/// successfully. Any error must be reported by means of exceptions. 81*b0d29bc4SBrooks Davis/// 82*b0d29bc4SBrooks Davis/// \param ui Object to interact with the I/O of the command. The command must 83*b0d29bc4SBrooks Davis/// always use this object to write to stdout and stderr. 84*b0d29bc4SBrooks Davis/// \param args The command line passed to the command broken by word, which 85*b0d29bc4SBrooks Davis/// includes options and arguments. 86*b0d29bc4SBrooks Davis/// \param data An opaque data structure to pass to the run method. 87*b0d29bc4SBrooks Davis/// 88*b0d29bc4SBrooks Davis/// \return The exit code that the program has to return. 0 on success, some 89*b0d29bc4SBrooks Davis/// other value on error. 90*b0d29bc4SBrooks Davis/// \throw usage_error If args is invalid (i.e. if the options are mispecified 91*b0d29bc4SBrooks Davis/// or if the arguments are invalid). 92*b0d29bc4SBrooks Davistemplate< typename Data > 93*b0d29bc4SBrooks Davisint 94*b0d29bc4SBrooks Davisbase_command< Data >::main(ui* ui, const args_vector& args, const Data& data) 95*b0d29bc4SBrooks Davis{ 96*b0d29bc4SBrooks Davis return run(ui, parse_cmdline(args), data); 97*b0d29bc4SBrooks Davis} 98*b0d29bc4SBrooks Davis 99*b0d29bc4SBrooks Davis 100*b0d29bc4SBrooks Davis} // namespace cli 101*b0d29bc4SBrooks Davis} // namespace utils 102*b0d29bc4SBrooks Davis 103*b0d29bc4SBrooks Davis 104*b0d29bc4SBrooks Davis#endif // !defined(UTILS_CMDLINE_BASE_COMMAND_IPP) 105