/usr/include/BALL/FORMAT/commandlineParser.h is in libball1.4-dev 1.4.3~beta1-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 | #ifndef BALL_FORMAT_COMMANDLINEPARSER_H
#define BALL_FORMAT_COMMANDLINEPARSER_H
#ifndef BALL_DATATYPE_OPTIONS_H
# include <BALL/DATATYPE/options.h>
#endif
#ifndef BALL_DATATYPE_STRING_H
# include <BALL/DATATYPE/string.h>
#endif
#ifndef BALL_FORMAT_PARAMFILE_H
# include <BALL/FORMAT/paramFile.h>
#endif
#include <map>
#include <set>
namespace BALL
{
/** Class for parsing parameters specified on the command line.\n
Register the parameters and flags of your tool with registerParameter(),
resp. registerFlag() and have the command-line parsed with parse().
After this, you can retrieve the values of all parameters with get().\n
In addition to this, you can also register a tool-manual text, define
restrictions on parameters and register file-formats that are supported
for in- or output-files.\n
If the parameter '-write_par somefilename.xml' is given to the program,
an xml-based parameter-file will be automatically written, containing the
specification the tool, all its parameters and all parameter values used
on the commend-line.\n
If the parameter '-par somefilename.xml' is used, such a file can be read,
so that the parameter-values stored in it will be used.
However, if, although this is not necessary, parameters (other than -par)
are specified on the command-line, their values will automatically overload
those stored in the xml-file.
The parameter '-env' allows to differentiate between command line ('cmdline')
behaviour and special adaptions to workflow systems like galaxy or knime.
*/
class BALL_EXPORT CommandlineParser
{
public:
CommandlineParser(String tool_name, String tool_description, String tool_version, String build_date, String category="");
/** Set the text to be displayed as mini-manual when starting the tool, containing a few sentences describing what the tool should be good for ... */
void setToolManual(const String& manual);
static const String NOT_FOUND;
static const list<String> EMTPY_LIST;
// - CLI switch
// - description
// - parameter type
// - required
// - default value
// - hidden in galaxy
void registerParameter(String name, String description, ParameterType type, bool mandatory = false, String default_value = "", bool hidden = false);
void registerFlag(String name, String description, bool default_gui_value = false, bool hidden = false);
void registerAdvancedParameters(Options& options);
// exclude parameter from showing in help mode e.g. galaxy specific multi-output parameter
void setParameterAsAdvanced(String name);
/** Register the minimal and maximal allowed value for a numerical parameter. */
void setParameterRestrictions(String par_name, double min_value, double max_value);
/** Register the allowed values for a string-parameter. */
void setParameterRestrictions(String par_name, list<String>& allowed_values);
/** In case of output-files, this functions allows to specify the name
of an input-parameter, whose format should be used for the given
output-parameter. \n
Note, that this function will only have an effect on the creation of
config-files for workflow-systems (Galaxy, Knime, etc.) and not for
the command-line interface, where the user will directly specify
output-filenames.
*/
void setOutputFormatSource(String output_parname, String input_parname);
/** Register the supported formats for input-/output-files.
@param supported_formats supported file-formats separated by commas
*/
void setSupportedFormats(String par_name, String supported_formats);
/** Parse all parameters found in the command line
*/
void parse(int argc, char* argv[]);
/** Copies names and values of all advanced parameters to the given Options object.
*/
void copyAdvancedParametersToOptions(Options& options);
/** Returns the value for a given parameter name. \n
Example: For "-o outfile.sdf", CommandlineParser::get("o") will return
"outfile.sdf".
*/
const String& get(String name);
/** Find out whether a the parameter or flag has been specified on the command-line.
*/
bool has(String name);
/** Returns a parameter-list for a given parameter name. \n
Example: For "-i infile1.sdf infile2.sdf", CommandlineParser::getList("i")
will return a vector containing 'infile1.sdf' and infile2.sdf'. */
const list<String>& getList(String name);
/** Print information about about all registered parameters.\n
If 'parameter_names' is specified, only information those parameters is shown.
*/
void printHelp(const std::set<String>& parameter_names = std::set<String>(), bool show_manual = true);
void printToolInfo();
const String& getStartTime();
/** Get the exact command with which the tool was started on the command-line.
*/
const String& getStartCommand();
private:
void replaceEscapedCharacters_(String& parameter_value);
void checkAndRegisterParameter(String name, String description, ParameterType type, bool mandatory = false, String default_value = "", bool perform_check = true, bool hidden=false);
void checkAndRegisterFlag(String name, String description, bool default_gui_value = false, bool perform_check = true, bool hidden=false);
void validateRegisteredFilesHaveFormats();
/** Throws an exception if the given parameter name is not allowed to be used. */
void checkParameterName(const String& name, const bool perform_check = true);
/** blacklisted param names */
std::set<String> reserved_params_;
/** map escaped characters to the original characters */
std::list<std::pair<String, String> > escaped_chars_;
std::map<String, list<String> > parameter_map_;
std::map<String, ParameterDescription> registered_parameters_;
std::map<String, ParameterDescription> registered_flags_;
typedef std::map<String, ParameterDescription>::iterator MapIterator;
std::list<MapIterator> original_parameter_order_;
std::list<MapIterator> original_flag_order_;
Size max_parname_length_;
Size max_flagname_length_;
String tool_name_;
String tool_description_;
String tool_version_;
String build_date_;
String hostname_;
String start_time_;
String tool_manual_;
String start_command_;
String tool_category_;
};
}
#endif // BALL_FORMAT_COMMANDLINEPARSER_H
|