2017-01-25 15:35:00 +00:00
|
|
|
/*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public
|
|
|
|
* License v2 as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public
|
|
|
|
* License along with this program; if not, write to the
|
|
|
|
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
* Boston, MA 021110-1307, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __BTRFS_HELP_H__
|
|
|
|
#define __BTRFS_HELP_H__
|
|
|
|
|
2022-06-21 00:20:21 +00:00
|
|
|
/* User defined long options first option */
|
|
|
|
#define GETOPT_VAL_FIRST 256
|
2017-01-25 15:35:00 +00:00
|
|
|
|
2022-06-21 00:20:21 +00:00
|
|
|
#define GETOPT_VAL_SI 512
|
|
|
|
#define GETOPT_VAL_IEC 513
|
|
|
|
#define GETOPT_VAL_RAW 514
|
|
|
|
#define GETOPT_VAL_HUMAN_READABLE 515
|
|
|
|
#define GETOPT_VAL_KBYTES 516
|
|
|
|
#define GETOPT_VAL_MBYTES 517
|
|
|
|
#define GETOPT_VAL_GBYTES 518
|
|
|
|
#define GETOPT_VAL_TBYTES 519
|
|
|
|
|
|
|
|
#define GETOPT_VAL_HELP 520
|
2017-01-25 15:35:00 +00:00
|
|
|
|
|
|
|
#define ARGV0_BUF_SIZE PATH_MAX
|
|
|
|
|
|
|
|
#define HELPINFO_UNITS_LONG \
|
|
|
|
"--raw raw numbers in bytes", \
|
|
|
|
"--human-readable human friendly numbers, base 1024 (default)", \
|
|
|
|
"--iec use 1024 as a base (KiB, MiB, GiB, TiB)", \
|
|
|
|
"--si use 1000 as a base (kB, MB, GB, TB)", \
|
|
|
|
"--kbytes show sizes in KiB, or kB with --si", \
|
|
|
|
"--mbytes show sizes in MiB, or MB with --si", \
|
|
|
|
"--gbytes show sizes in GiB, or GB with --si", \
|
|
|
|
"--tbytes show sizes in TiB, or TB with --si"
|
|
|
|
|
|
|
|
#define HELPINFO_UNITS_SHORT_LONG \
|
|
|
|
"-b|--raw raw numbers in bytes", \
|
|
|
|
"-h|--human-readable", \
|
|
|
|
" human friendly numbers, base 1024 (default)", \
|
|
|
|
"-H human friendly numbers, base 1000", \
|
|
|
|
"--iec use 1024 as a base (KiB, MiB, GiB, TiB)", \
|
|
|
|
"--si use 1000 as a base (kB, MB, GB, TB)", \
|
|
|
|
"-k|--kbytes show sizes in KiB, or kB with --si", \
|
|
|
|
"-m|--mbytes show sizes in MiB, or MB with --si", \
|
|
|
|
"-g|--gbytes show sizes in GiB, or GB with --si", \
|
|
|
|
"-t|--tbytes show sizes in TiB, or TB with --si"
|
|
|
|
|
2019-06-21 14:11:07 +00:00
|
|
|
/*
|
|
|
|
* Special marker in the help strings that will preemptively insert the global
|
|
|
|
* options and then continue with the following text that possibly follows
|
|
|
|
* after the regular options
|
|
|
|
*/
|
2019-11-25 10:39:02 +00:00
|
|
|
#define HELPINFO_INSERT_GLOBALS "", \
|
|
|
|
"Global options:"
|
2019-11-25 10:39:03 +00:00
|
|
|
|
2019-11-25 10:39:02 +00:00
|
|
|
#define HELPINFO_INSERT_FORMAT "--format TYPE"
|
2019-06-21 14:11:07 +00:00
|
|
|
|
2019-11-25 10:39:03 +00:00
|
|
|
#define HELPINFO_INSERT_VERBOSE "-v|--verbose increase output verbosity"
|
|
|
|
#define HELPINFO_INSERT_QUIET "-q|--quiet print only errors"
|
|
|
|
|
2017-01-25 15:35:00 +00:00
|
|
|
struct cmd_struct;
|
|
|
|
struct cmd_group;
|
|
|
|
|
2018-03-06 02:29:30 +00:00
|
|
|
/*
|
|
|
|
* Descriptor of output format
|
|
|
|
*/
|
|
|
|
struct format_desc {
|
|
|
|
unsigned int value;
|
|
|
|
char name[8];
|
|
|
|
};
|
|
|
|
|
2019-06-21 14:14:09 +00:00
|
|
|
extern const struct format_desc output_formats[2];
|
2018-03-06 02:29:30 +00:00
|
|
|
|
|
|
|
const char *output_format_name(unsigned int value);
|
|
|
|
|
2019-03-01 19:47:00 +00:00
|
|
|
__attribute__((noreturn))
|
2018-03-07 02:54:38 +00:00
|
|
|
void usage_unknown_option(const struct cmd_struct *cmd, char **argv);
|
2019-03-01 19:47:00 +00:00
|
|
|
|
2017-09-23 19:08:43 +00:00
|
|
|
__attribute__((noreturn))
|
2018-03-07 02:54:38 +00:00
|
|
|
void usage(const struct cmd_struct *cmd);
|
2018-03-05 21:49:00 +00:00
|
|
|
void usage_command(const struct cmd_struct *cmd, bool full, bool err);
|
|
|
|
void usage_command_group(const struct cmd_group *grp, bool all, bool err);
|
2017-01-25 15:35:00 +00:00
|
|
|
void usage_command_group_short(const struct cmd_group *grp);
|
|
|
|
|
2017-09-23 19:08:43 +00:00
|
|
|
__attribute__((noreturn))
|
|
|
|
void help_unknown_token(const char *arg, const struct cmd_group *grp);
|
|
|
|
__attribute__((noreturn))
|
|
|
|
void help_ambiguous_token(const char *arg, const struct cmd_group *grp);
|
2017-01-25 15:35:00 +00:00
|
|
|
|
|
|
|
void help_command_group(const struct cmd_group *grp, int argc, char **argv);
|
|
|
|
|
|
|
|
int check_argc_exact(int nargs, int expected);
|
|
|
|
int check_argc_min(int nargs, int expected);
|
|
|
|
int check_argc_max(int nargs, int expected);
|
2018-03-07 02:42:01 +00:00
|
|
|
void clean_args_no_options(const struct cmd_struct *cmd,
|
|
|
|
int argc, char *argv[]);
|
|
|
|
void clean_args_no_options_relaxed(const struct cmd_struct *cmd,
|
|
|
|
int argc, char *argv[]);
|
2017-01-25 15:35:00 +00:00
|
|
|
|
|
|
|
void fixup_argv0(char **argv, const char *token);
|
|
|
|
void set_argv0(char **argv);
|
|
|
|
const char *get_argv0_buf(void);
|
|
|
|
|
|
|
|
#endif
|