summaryrefslogtreecommitdiff
path: root/test/cli.h
blob: ffcd272fc5dbcd0d268d87b153185fce7ff1354c (plain)
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
/*
 * SPDX-License-Identifier: ISC
 *
 * Copyright (C) 2021-2022 Michael Drake <tlsa@netsurf-browser.org>
 */

/**
 * \file
 * \brief Command line argument handling API.
 */

#ifndef _PELTAR_CLI_H_
#define _PELTAR_CLI_H_

#include <stdint.h>
#include <stdbool.h>

/**
 * Helper to get element count for an array,
 *
 * \param[in]  _a  Array to get number of elements for.
 */
#define CLI_ARRAY_LEN(_a) ((sizeof(_a))/(sizeof(*(_a))))

/**
 * CLI argument type.
 */
enum cli_arg_type {
	CLI_CMD,    /**< A sub-command. Must match long argument name. */
	CLI_BOOL,   /**< Has no value; presence of flag indicates true. */
	CLI_INT,    /**< Has signed integer value. */
	CLI_UINT,   /**< Has unsigned integer value. */
	CLI_ENUM,   /**< Has enumeration value. */
	CLI_STRING, /**< Has string value. */
};

/** Enum value descriptor. */
struct cli_str_val {
	const char *str; /**< String for the enum value name. */
	int64_t val;     /**< The value for this string. */
	const char *d;   /**< Description of this value for help output. */
};

/** Enum data. */
struct cli_enum {
	const struct cli_str_val *desc; /**< Array describing enum values. */
	int64_t *e; /**< Location to store \ref CLI_ENUM value. */
};

/**
 * Client description for a command line argument.
 */
struct cli_table_entry {
	const char *l; /**< Long argument name. */
	const char  s; /**< Short flag name. (Non-positional arguments.) */
	bool p; /**< Whether the argument is a positional argument. */
	bool no_pos; /**< When present, no positional arguments are required. */
	enum cli_arg_type t; /**< Argument type. */
	union {
		bool *b;        /**< Location to store \ref CLI_BOOL value. */
		int64_t *i;     /**< Location to store \ref CLI_INT value. */
		uint64_t *u;    /**< Location to store \ref CLI_UINT value. */
		const char **s; /**< Location to store \ref CLI_STRING value. */
		struct cli_enum e; /**< \ref CLI_ENUM value details. */
	} v; /**< Where to store type-specific values. */
	const char *d; /**< Description of this argument for help output. */
};

/**
 * Client command line interface specification.
 */
struct cli_table {
	const struct cli_table_entry *entries;
	size_t count;
	size_t min_positional;
	const char *d; /**< Description of this application for help output. */
};

/**
 * Parse the command line arguments.
 *
 * \param[in]  cli   Client command line interface specification.
 * \param[in]  argc  Number of command line arguments.
 * \param[in]  argv  String vector containing command line arguments.
 * \return true on success, false on error.
 */
bool cli_parse(const struct cli_table *cli, int argc, const char **argv);

/**
 * Print usage and help output.
 *
 * Note: Assumes non-Unicode. (One byte per character.)
 *
 * \param[in]  cli        Client command line interface specification.
 * \param[in]  prog_name  Program name.
 */
void cli_help(const struct cli_table *cli, const char *prog_name);

#endif