12#include "../Option.hpp"
27 other->required(required_);
28 other->ignore_case(ignore_case_);
29 other->ignore_underscore(ignore_underscore_);
30 other->configurable(configurable_);
31 other->disable_flag_override(disable_flag_override_);
32 other->delimiter(delimiter_);
33 other->always_capture_default(always_capture_default_);
34 other->multi_option_policy(multi_option_policy_);
35 other->callback_priority(callback_priority_);
46 }
else if(value == detail::expected_max_vector_size) {
61 value_min = -value_min;
65 value_max = detail::expected_max_vector_size;
67 if(value_max < value_min) {
79 validator->non_modifying();
87 auto vp = std::make_shared<Validator>(std::move(validator));
88 if(!validator_name.empty()) {
89 vp->name(validator_name);
97 std::string validator_description,
98 std::string validator_name) {
100 auto vp = std::make_shared<Validator>(
101 std::move(validator_func), std::move(validator_description), std::move(validator_name));
114 auto vp = std::make_shared<Validator>(std::move(validator));
115 if(!transform_name.empty()) {
116 vp->name(transform_name);
123 std::string transform_description,
124 std::string transform_name) {
125 auto vp = std::make_shared<Validator>(
126 [transform_func](std::string &val) {
127 val = transform_func(val);
128 return std::string{};
130 std::move(transform_description),
131 std::move(transform_name));
138 auto vp = std::make_shared<Validator>(
139 [func](std::string &inout) {
141 return std::string{};
150 if(validator_name == validator->get_name()) {
151 return validator.get();
154 if((validator_name.empty()) && (!
validators_.empty())) {
157 throw OptionNotFound(std::string{
"Validator "} + validator_name +
" Not Found");
162 if(index >= 0 && index <
static_cast<int>(
validators_.size())) {
169 auto iterator = std::find(std::begin(
needs_), std::end(
needs_), opt);
171 if(iterator == std::end(
needs_)) {
206 auto *parent =
static_cast<T *
>(
parent_);
207 for(
const Option_p &opt : parent->options_) {
208 if(opt.get() ==
this) {
211 const auto &omatch = opt->matching_name(*
this);
212 if(!omatch.empty()) {
227 auto *parent =
static_cast<T *
>(
parent_);
228 for(
const Option_p &opt : parent->options_) {
229 if(opt.get() ==
this) {
232 const auto &omatch = opt->matching_name(*
this);
233 if(!omatch.empty()) {
235 throw OptionAlreadyAdded(
"adding ignore underscore caused a name conflict with " + omatch);
257CLI11_NODISCARD CLI11_INLINE std::string
258Option::get_name(
bool positional,
bool all_options,
bool disable_default_flag_values)
const {
264 std::vector<std::string> name_list;
268 name_list.push_back(
pname_);
271 for(
const std::string &sname :
snames_) {
272 name_list.push_back(
"-" + sname);
273 if(!disable_default_flag_values &&
check_fname(sname)) {
278 for(
const std::string &lname :
lnames_) {
279 name_list.push_back(
"--" + lname);
280 if(!disable_default_flag_values &&
check_fname(lname)) {
285 for(
const std::string &sname :
snames_)
286 name_list.push_back(
"-" + sname);
288 for(
const std::string &lname :
lnames_)
289 name_list.push_back(
"--" + lname);
292 return detail::join(name_list);
301 return std::string(2,
'-') +
lnames_[0];
305 return std::string(1,
'-') +
snames_[0];
312 bool used_default_str =
false;
314 used_default_str =
true;
329 if(send_results.empty()) {
332 bool local_result =
callback_(send_results);
333 if(used_default_str) {
345 static const std::string estring;
347 for(
const std::string &sname :
snames_) {
353 for(
const std::string &lname :
lnames_) {
356 if(lname.size() == 1 && bothConfigurable) {
366 if(bothConfigurable && other.
snames_.empty() && other.
fnames_.empty() && !other.
pname_.empty()) {
372 for(
const std::string &sname : other.
snames_)
375 for(
const std::string &lname : other.
lnames_)
384 if(name.length() > 2 && name[0] ==
'-' && name[1] ==
'-')
386 if(name.length() > 1 && name.front() ==
'-')
389 std::string local_pname =
pname_;
390 std::string local_name = name;
392 local_pname = detail::remove_underscore(local_pname);
393 local_name = detail::remove_underscore(local_name);
396 local_pname = detail::to_lower(local_pname);
397 local_name = detail::to_lower(local_name);
399 if(local_name == local_pname) {
412 std::string input_value)
const {
413 static const std::string trueString{
"true"};
414 static const std::string falseString{
"false"};
415 static const std::string emptyString{
"{}"};
418 if(!((input_value.empty()) || (input_value == emptyString))) {
420 if(default_ind >= 0) {
426 throw(ArgumentMismatch::FlagOverride(name));
429 if(input_value != trueString) {
430 throw(ArgumentMismatch::FlagOverride(name));
436 if((input_value.empty()) || (input_value == emptyString)) {
447 auto val = detail::to_flag_value(input_value);
452 return (val == 1) ? falseString : (val == (-1) ? trueString : std::to_string(-val));
458 _add_result(std::move(s),
results_);
464 results_added = _add_result(std::move(s),
results_);
472 _add_result(std::move(str),
results_);
482 _validate_results(res);
486 _reduce_results(extra, res);
488 res = std::move(extra);
496 if(option_type_size < 0) {
515 if(option_type_size_min < 0 || option_type_size_max < 0) {
518 option_type_size_min = (std::abs)(option_type_size_min);
519 option_type_size_max = (std::abs)(option_type_size_max);
522 if(option_type_size_min > option_type_size_max) {
542 std::string vtype = validator->get_description();
544 full_type_name +=
":" + vtype;
548 return full_type_name;
551CLI11_INLINE
void Option::_validate_results(results_t &res)
const {
563 for(std::string &result : res) {
568 auto err_msg = _validate(result, (index >= 0) ? (index %
type_size_max_) : index);
570 throw ValidationError(
get_name(), err_msg);
581 for(std::string &result : res) {
582 auto err_msg = _validate(result, index);
585 throw ValidationError(
get_name(), err_msg);
591CLI11_INLINE
void Option::_reduce_results(results_t &out,
const results_t &original)
const {
599 case MultiOptionPolicy::TakeAll:
601 case MultiOptionPolicy::TakeLast: {
603 std::size_t trim_size = std::min<std::size_t>(
605 if(original.size() != trim_size) {
606 out.assign(original.end() -
static_cast<results_t::difference_type
>(trim_size), original.end());
609 case MultiOptionPolicy::Reverse: {
611 std::size_t trim_size = std::min<std::size_t>(
613 if(original.size() != trim_size || trim_size > 1) {
614 out.assign(original.end() -
static_cast<results_t::difference_type
>(trim_size), original.end());
616 std::reverse(out.begin(), out.end());
618 case MultiOptionPolicy::TakeFirst: {
619 std::size_t trim_size = std::min<std::size_t>(
621 if(original.size() != trim_size) {
622 out.assign(original.begin(), original.begin() +
static_cast<results_t::difference_type
>(trim_size));
625 case MultiOptionPolicy::Join:
627 out.push_back(detail::join(original, std::string(1, (
delimiter_ ==
'\0') ?
'\n' :
delimiter_)));
630 case MultiOptionPolicy::Sum:
631 out.push_back(detail::sum_string_vector(original));
633 case MultiOptionPolicy::Throw:
643 if(original.size() < num_min) {
644 throw ArgumentMismatch::AtLeast(
get_name(),
static_cast<int>(num_min), original.size());
646 if(original.size() > num_max) {
647 if(original.size() == 2 && num_max == 1 && original[1] ==
"%%" && original[0] ==
"{}") {
652 throw ArgumentMismatch::AtMost(
get_name(),
static_cast<int>(num_max), original.size());
662 out.emplace_back(
"{}");
663 out.emplace_back(
"%%");
666 out.emplace_back(
"%%");
670CLI11_INLINE std::string Option::_validate(std::string &result,
int index)
const {
677 auto v = vali->get_application_index();
678 if(v == -1 || v == index) {
680 err_msg = (*vali)(result);
681 }
catch(
const ValidationError &err) {
682 err_msg = err.what();
692CLI11_INLINE
int Option::_add_result(std::string &&result, std::vector<std::string> &res)
const {
693 int result_count = 0;
697 if(result.size() >= 4 && result[0] ==
'[' && result[1] ==
'[' && result.back() ==
']' &&
698 (*(result.end() - 2) ==
']')) {
700 std::string nstrs{
'['};
701 bool duplicated{
true};
702 for(std::size_t ii = 2; ii < result.size() - 2; ii += 2) {
703 if(result[ii] == result[ii + 1]) {
704 nstrs.push_back(result[ii]);
711 nstrs.push_back(
']');
712 res.push_back(std::move(nstrs));
719 result.front() ==
'[' &&
720 result.back() ==
']') {
723 result.erase(result.begin());
724 bool skipSection{
false};
725 for(
auto &var : CLI::detail::split_up(result,
',')) {
727 result_count += _add_result(std::move(var), res);
735 res.push_back(std::move(result));
738 if((result.find_first_of(
delimiter_) != std::string::npos)) {
739 for(
const auto &var : CLI::detail::split(result,
delimiter_)) {
746 res.push_back(std::move(result));
Thrown when conversion call back fails, such as when an int fails to coerce to a string.
Definition Error.hpp:205
Thrown when an option is set to conflicting values (non-vector and multi args, for example)
Definition Error.hpp:96
Thrown when an option already exists.
Definition Error.hpp:144
MultiOptionPolicy multi_option_policy_
Definition Option.hpp:97
bool ignore_case_
Definition Option.hpp:79
bool configurable_
Definition Option.hpp:85
bool disable_flag_override_
Definition Option.hpp:88
bool required_
Definition Option.hpp:76
char delimiter_
Definition Option.hpp:91
bool ignore_underscore_
Definition Option.hpp:82
CLI11_NODISCARD const std::string & get_group() const
Definition Option.hpp:134
void copy_to(T *other) const
Copy the contents to another similar class (one based on OptionBase)
Definition Option_inl.hpp:25
Definition Option.hpp:259
Option * type_size(int option_type_size)
Set a custom option size.
Definition Option_inl.hpp:495
Option * expected(int value)
Set the number of expected arguments.
Definition Option_inl.hpp:38
Option * check(Validator_p validator)
Adds a shared validator.
Definition Option_inl.hpp:78
std::string default_str_
A human readable default value, either manually set, captured, or captured by default.
Definition Option.hpp:294
CLI11_NODISCARD bool check_name(const std::string &name) const
Check a name. Requires "-" or "--" for short / long, supports positional name.
Definition Option_inl.hpp:382
std::function< std::string()> type_name_
Definition Option.hpp:302
@ reduced
a subset of results has been generated
@ callback_run
the callback has been executed
@ validated
the results have been validated
@ parsing
The option is currently collecting parsed results.
option_state current_option_state_
Whether the callback has run (needed for INI parsing)
Definition Option.hpp:357
int type_size_min_
The minimum number of arguments an option should be expecting.
Definition Option.hpp:315
CLI11_NODISCARD results_t reduced_results() const
Get a copy of the results.
Definition Option_inl.hpp:477
CLI11_NODISCARD std::string get_type_name() const
Get the full typename for this option.
Definition Option_inl.hpp:538
CLI11_NODISCARD bool check_fname(std::string name) const
Requires "--" to be removed from string.
Definition Option.hpp:693
std::string pname_
A positional name.
Definition Option.hpp:281
int expected_min_
The minimum number of expected values.
Definition Option.hpp:318
Option * transform(Validator_p validator)
Adds a shared Validator.
Definition Option_inl.hpp:107
Option * ignore_case(bool value=true)
Definition Option_inl.hpp:203
std::set< Option * > needs_
A list of options that are required with this option.
Definition Option.hpp:326
void run_callback()
Process the callback.
Definition Option_inl.hpp:311
CLI11_NODISCARD std::string get_name(bool positional=false, bool all_options=false, bool disable_default_flag_values=false) const
Gets a comma separated list of names. Will include / prefer the positional name if positional is true...
Definition Option_inl.hpp:258
CLI11_NODISCARD bool check_sname(std::string name) const
Requires "-" to be removed from string.
Definition Option.hpp:683
bool flag_like_
Specify that the option should act like a flag vs regular option.
Definition Option.hpp:361
std::set< Option * > excludes_
A list of options that are excluded with this option.
Definition Option.hpp:329
bool force_callback_
flag indicating that the option should force the callback regardless if any results present
Definition Option.hpp:369
std::vector< std::string > fnames_
a list of flag names with specified default values;
Definition Option.hpp:278
CLI11_NODISCARD int get_items_expected_min() const
The total min number of expected string values to be used.
Definition Option.hpp:617
CLI11_NODISCARD const std::string & matching_name(const Option &other) const
If options share any of the same names, find it.
Definition Option_inl.hpp:344
CLI11_NODISCARD bool check_lname(std::string name) const
Requires "--" to be removed from string.
Definition Option.hpp:688
CLI11_NODISCARD int get_items_expected_max() const
Get the maximum number of items expected to be returned and used for the callback.
Definition Option.hpp:620
std::vector< std::string > snames_
A list of the short names (-a) without the leading dashes.
Definition Option.hpp:268
results_t proc_results_
results after reduction
Definition Option.hpp:348
bool remove_excludes(Option *opt)
Remove needs link from an option. Returns true if the option really was in the needs list.
Definition Option_inl.hpp:193
Option * multi_option_policy(MultiOptionPolicy value=MultiOptionPolicy::Throw)
Take the last argument if given multiple times (or another policy)
Definition Option_inl.hpp:244
std::vector< Validator_p > validators_
A list of Validators to run on each value parsed.
Definition Option.hpp:323
Option * excludes(Option *opt)
Sets excluded options.
Definition Option_inl.hpp:178
App * parent_
link back up to the parent App for fallthrough
Definition Option.hpp:336
int expected_max_
The maximum number of expected values.
Definition Option.hpp:320
CLI11_NODISCARD std::string get_flag_value(const std::string &name, std::string input_value) const
Definition Option_inl.hpp:411
CLI11_NODISCARD int get_items_expected() const
The total min number of expected string values to be used.
Definition Option.hpp:625
bool inject_separator_
flag indicating a separator needs to be injected after each argument call
Definition Option.hpp:365
Validator * get_validator(const std::string &validator_name="")
Get a named Validator.
Definition Option_inl.hpp:148
callback_t callback_
Options store a callback to do all the work.
Definition Option.hpp:339
CLI11_NODISCARD bool empty() const
True if the option was not passed.
Definition Option.hpp:392
CLI11_NODISCARD int get_expected_max() const
The max number of times the option expects to be included.
Definition Option.hpp:614
CLI11_NODISCARD int get_type_size() const
The number of arguments the option expects.
Definition Option.hpp:562
std::string envname_
If given, check the environment for this option.
Definition Option.hpp:284
Option * ignore_underscore(bool value=true)
Definition Option_inl.hpp:223
std::vector< std::pair< std::string, std::string > > default_flag_values_
Definition Option.hpp:275
int type_size_max_
Definition Option.hpp:313
bool allow_extra_args_
Specify that extra args beyond type_size_max should be allowed.
Definition Option.hpp:359
std::vector< std::string > lnames_
A list of the long names (--long) without the leading dashes.
Definition Option.hpp:271
Option * add_result(std::string s)
Puts a result at the end.
Definition Option_inl.hpp:457
bool remove_needs(Option *opt)
Remove needs link from an option. Returns true if the option really was in the needs list.
Definition Option_inl.hpp:168
Option * each(const std::function< void(std::string)> &func)
Adds a user supplied function to run on each item passed in (communicate though lambda capture)
Definition Option_inl.hpp:137
results_t results_
complete Results of parsing
Definition Option.hpp:346
Thrown when counting a nonexistent option.
Definition Error.hpp:351
Some validators that are provided.
Definition Validators.hpp:54
Validator & non_modifying(bool no_modify=true)
Specify whether the Validator can be modifying or not.
Definition Validators.hpp:139