diff options
Diffstat (limited to 'tools/lib/subcmd')
| -rw-r--r-- | tools/lib/subcmd/pager.c | 11 | ||||
| -rw-r--r-- | tools/lib/subcmd/pager.h | 1 | ||||
| -rw-r--r-- | tools/lib/subcmd/parse-options.c | 19 | ||||
| -rw-r--r-- | tools/lib/subcmd/parse-options.h | 2 | 
4 files changed, 32 insertions, 1 deletions
| diff --git a/tools/lib/subcmd/pager.c b/tools/lib/subcmd/pager.c index 9997a8805a82..e3d47b59b14d 100644 --- a/tools/lib/subcmd/pager.c +++ b/tools/lib/subcmd/pager.c @@ -23,6 +23,13 @@ void pager_init(const char *pager_env)  	subcmd_config.pager_env = pager_env;  } +static const char *forced_pager; + +void force_pager(const char *pager) +{ +	forced_pager = pager; +} +  static void pager_preexec(void)  {  	/* @@ -66,7 +73,9 @@ void setup_pager(void)  	const char *pager = getenv(subcmd_config.pager_env);  	struct winsize sz; -	if (!isatty(1)) +	if (forced_pager) +		pager = forced_pager; +	if (!isatty(1) && !forced_pager)  		return;  	if (ioctl(1, TIOCGWINSZ, &sz) == 0)  		pager_columns = sz.ws_col; diff --git a/tools/lib/subcmd/pager.h b/tools/lib/subcmd/pager.h index f1a53cf29880..a818964693ab 100644 --- a/tools/lib/subcmd/pager.h +++ b/tools/lib/subcmd/pager.h @@ -7,5 +7,6 @@ extern void pager_init(const char *pager_env);  extern void setup_pager(void);  extern int pager_in_use(void);  extern int pager_get_columns(void); +extern void force_pager(const char *);  #endif /* __SUBCMD_PAGER_H */ diff --git a/tools/lib/subcmd/parse-options.c b/tools/lib/subcmd/parse-options.c index cb7154eccbdc..dbb9efbf718a 100644 --- a/tools/lib/subcmd/parse-options.c +++ b/tools/lib/subcmd/parse-options.c @@ -116,6 +116,7 @@ static int get_value(struct parse_opt_ctx_t *p,  		case OPTION_INTEGER:  		case OPTION_UINTEGER:  		case OPTION_LONG: +		case OPTION_ULONG:  		case OPTION_U64:  		default:  			break; @@ -166,6 +167,7 @@ static int get_value(struct parse_opt_ctx_t *p,  		case OPTION_INTEGER:  		case OPTION_UINTEGER:  		case OPTION_LONG: +		case OPTION_ULONG:  		case OPTION_U64:  		default:  			break; @@ -295,6 +297,22 @@ static int get_value(struct parse_opt_ctx_t *p,  			return opterror(opt, "expects a numerical value", flags);  		return 0; +	case OPTION_ULONG: +		if (unset) { +			*(unsigned long *)opt->value = 0; +			return 0; +		} +		if (opt->flags & PARSE_OPT_OPTARG && !p->opt) { +			*(unsigned long *)opt->value = opt->defval; +			return 0; +		} +		if (get_arg(p, opt, flags, &arg)) +			return -1; +		*(unsigned long *)opt->value = strtoul(arg, (char **)&s, 10); +		if (*s) +			return opterror(opt, "expects a numerical value", flags); +		return 0; +  	case OPTION_U64:  		if (unset) {  			*(u64 *)opt->value = 0; @@ -703,6 +721,7 @@ static void print_option_help(const struct option *opts, int full)  	case OPTION_ARGUMENT:  		break;  	case OPTION_LONG: +	case OPTION_ULONG:  	case OPTION_U64:  	case OPTION_INTEGER:  	case OPTION_UINTEGER: diff --git a/tools/lib/subcmd/parse-options.h b/tools/lib/subcmd/parse-options.h index 92fdbe1519f6..6ca2a8bfe716 100644 --- a/tools/lib/subcmd/parse-options.h +++ b/tools/lib/subcmd/parse-options.h @@ -25,6 +25,7 @@ enum parse_opt_type {  	OPTION_STRING,  	OPTION_INTEGER,  	OPTION_LONG, +	OPTION_ULONG,  	OPTION_CALLBACK,  	OPTION_U64,  	OPTION_UINTEGER, @@ -133,6 +134,7 @@ struct option {  #define OPT_INTEGER(s, l, v, h)     { .type = OPTION_INTEGER, .short_name = (s), .long_name = (l), .value = check_vtype(v, int *), .help = (h) }  #define OPT_UINTEGER(s, l, v, h)    { .type = OPTION_UINTEGER, .short_name = (s), .long_name = (l), .value = check_vtype(v, unsigned int *), .help = (h) }  #define OPT_LONG(s, l, v, h)        { .type = OPTION_LONG, .short_name = (s), .long_name = (l), .value = check_vtype(v, long *), .help = (h) } +#define OPT_ULONG(s, l, v, h)        { .type = OPTION_ULONG, .short_name = (s), .long_name = (l), .value = check_vtype(v, unsigned long *), .help = (h) }  #define OPT_U64(s, l, v, h)         { .type = OPTION_U64, .short_name = (s), .long_name = (l), .value = check_vtype(v, u64 *), .help = (h) }  #define OPT_STRING(s, l, v, a, h)   { .type = OPTION_STRING,  .short_name = (s), .long_name = (l), .value = check_vtype(v, const char **), .argh = (a), .help = (h) }  #define OPT_STRING_OPTARG(s, l, v, a, h, d) \ | 
