argparse documentation Help

Getting started

argparse provides User-Defined Attributes (UDA) that can be used to annotate struct members that are part of command line interface.

Without User-Defined Attributes

Using UDAs is not required and if a struct has no UDAs then all data members are treated as named command line arguments:

import argparse; // If struct has no UDA then all members are named arguments struct Example { // Basic data types are supported: // '--name' argument string name; // '--number' argument int number; // '--boolean' argument bool boolean; // Argument can have default value if it's not specified in command line // '--unused' argument string unused = "some default value"; // Enums are supported enum Enum { unset, foo, boo } // '--choice' argument Enum choice; // Use array to store multiple values // '--array' argument int[] array; // Callback with no args (flag) // '--callback' argument void callback() {} // Callback with single value // '--callback1' argument void callback1(string value) { assert(value == "cb-value"); } // Callback with zero or more values // '--callback2' argument void callback2(string[] value) { assert(value == ["cb-v1","cb-v2"]); } } // This mixin defines standard main function that parses command line and calls the provided function: mixin CLI!Example.main!((args) { // 'args' has 'Example' type static assert(is(typeof(args) == Example)); // do whatever you need import std.stdio: writeln; args.writeln; return 0; });

Running the program above with -h argument will have the following output:

Hello world example

With User-Defined Attributes

Although UDA-less approach is useful as a starting point, it's not enough for real command line tool:

import argparse; struct Example { // Positional arguments are required by default @PositionalArgument(0) string name; // Named arguments can be attributed in bulk (parentheses can be omitted) @NamedArgument { // '--number' argument int number; // '--boolean' argument bool boolean; // Argument can have default value if it's not specified in command line // '--unused' argument string unused = "some default value"; } // Enums are also supported enum Enum { unset, foo, boo } // '--choice' argument @NamedArgument Enum choice; // Named argument can have specific or multiple names @NamedArgument("apple","appl") int apple; @NamedArgument("b","banana","ban") int banana; } // This mixin defines standard main function that parses command line and calls the provided function: mixin CLI!Example.main!((args) { // 'args' has 'Example' type static assert(is(typeof(args) == Example)); // do whatever you need import std.stdio: writeln; args.writeln; return 0; });

Running the program above with -h argument will have the following output:

Hello world example
Last modified: 09 January 2025