Argument dependencies
Mutually exclusive arguments
Mutually exclusive arguments (i.e., those that can’t be used together) can be declared using MutuallyExclusive()
UDA:
import argparse;
struct T
{
@MutuallyExclusive()
{
string a;
string b;
}
}
T t;
// One of them or no argument is allowed
assert(CLI!T.parseArgs(t, ["-a","a"]));
assert(CLI!T.parseArgs(t, ["-b","b"]));
assert(CLI!T.parseArgs(t, []));
// Both arguments or no argument is not allowed
assert(!CLI!T.parseArgs(t, ["-a","a","-b","b"]));
Set of mutually exclusive arguments can be marked as required in order to require exactly one of the arguments:
import argparse;
struct T
{
@(MutuallyExclusive.Required)
{
string a;
string b;
}
}
T t;
// Either argument is allowed
assert(CLI!T.parseArgs(t, ["-a","a"]));
assert(CLI!T.parseArgs(t, ["-b","b"]));
// Both or no arguments are not allowed
assert(!CLI!T.parseArgs(t, ["-a","a","-b","b"]));
assert(!CLI!T.parseArgs(t, []));
Mutually required arguments
Mutually required arguments (i.e., those that require other arguments) can be declared using RequiredTogether()
UDA:
import argparse;
struct T
{
@RequiredTogether()
{
string a;
string b;
}
}
T t;
// Both or no argument is allowed
assert(CLI!T.parseArgs(t, ["-a","a","-b","b"]));
assert(CLI!T.parseArgs(t, []));
// Only one argument is not allowed
assert(!CLI!T.parseArgs(t, ["-a","a"]));
assert(!CLI!T.parseArgs(t, ["-b","b"]));
Set of mutually required arguments can be marked as required in order to require all arguments:
import argparse;
struct T
{
@(RequiredTogether.Required)
{
string a;
string b;
}
}
T t;
// Both arguments are allowed
assert(CLI!T.parseArgs(t, ["-a","a","-b","b"]));
// Single argument or no argument is not allowed
assert(!CLI!T.parseArgs(t, ["-a","a"]));
assert(!CLI!T.parseArgs(t, ["-b","b"]));
assert(!CLI!T.parseArgs(t, []));
Last modified: 09 January 2025