mirror of
https://github.com/kdave/btrfs-progs
synced 2025-01-09 15:30:22 +00:00
btrfs-progs: fix a regression that "property" with -t option doesn't work
"property" is considered as working without any options from the following commit. commit 176aeca9a148 ("btrfs-progs: add getopt stubs where needed") However, we can pass -t option to this command. * actual result ================================================== $ ./btrfs prop list -t f /btrfs btrfs property list: invalid option -- 't' usage: btrfs property list [-t <type>] <object> Lists available properties with their descriptions for the given object. Please see the help of 'btrfs property get' for a description of objects and object types. ================================================== * expected result ================================================== $ ./btrfs prop list -t f /btrfs label Set/get label of device. ================================================== Signed-off-by: Satoru Takeuchi <takeuchi_satoru@jp.fujitsu.com Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
parent
4b80569b58
commit
c742debab1
@ -294,10 +294,11 @@ out:
|
|||||||
static void parse_args(int argc, char **argv,
|
static void parse_args(int argc, char **argv,
|
||||||
const char * const *usage_str,
|
const char * const *usage_str,
|
||||||
int *types, char **object,
|
int *types, char **object,
|
||||||
char **name, char **value)
|
char **name, char **value, int min_nonopt_args)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
char *type_str = NULL;
|
char *type_str = NULL;
|
||||||
|
int max_nonopt_args = 0;
|
||||||
|
|
||||||
optind = 1;
|
optind = 1;
|
||||||
while (1) {
|
while (1) {
|
||||||
@ -314,6 +315,17 @@ static void parse_args(int argc, char **argv,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (object)
|
||||||
|
max_nonopt_args++;
|
||||||
|
if (name)
|
||||||
|
max_nonopt_args++;
|
||||||
|
if (value)
|
||||||
|
max_nonopt_args++;
|
||||||
|
|
||||||
|
if (check_argc_min(argc - optind, min_nonopt_args) ||
|
||||||
|
check_argc_max(argc - optind, max_nonopt_args))
|
||||||
|
usage(usage_str);
|
||||||
|
|
||||||
*types = 0;
|
*types = 0;
|
||||||
if (type_str) {
|
if (type_str) {
|
||||||
if (!strcmp(type_str, "s") || !strcmp(type_str, "subvol")) {
|
if (!strcmp(type_str, "s") || !strcmp(type_str, "subvol")) {
|
||||||
@ -379,13 +391,8 @@ static int cmd_property_get(int argc, char **argv)
|
|||||||
char *name = NULL;
|
char *name = NULL;
|
||||||
int types = 0;
|
int types = 0;
|
||||||
|
|
||||||
clean_args_no_options(argc, argv, cmd_property_get_usage);
|
|
||||||
|
|
||||||
if (check_argc_min(argc, 2) || check_argc_max(argc, 5))
|
|
||||||
usage(cmd_property_get_usage);
|
|
||||||
|
|
||||||
parse_args(argc, argv, cmd_property_get_usage, &types, &object, &name,
|
parse_args(argc, argv, cmd_property_get_usage, &types, &object, &name,
|
||||||
NULL);
|
NULL, 1);
|
||||||
if (!object) {
|
if (!object) {
|
||||||
error("invalid arguments");
|
error("invalid arguments");
|
||||||
usage(cmd_property_get_usage);
|
usage(cmd_property_get_usage);
|
||||||
@ -415,13 +422,8 @@ static int cmd_property_set(int argc, char **argv)
|
|||||||
char *value = NULL;
|
char *value = NULL;
|
||||||
int types = 0;
|
int types = 0;
|
||||||
|
|
||||||
clean_args_no_options(argc, argv, cmd_property_set_usage);
|
|
||||||
|
|
||||||
if (check_argc_min(argc, 4) || check_argc_max(argc, 6))
|
|
||||||
usage(cmd_property_set_usage);
|
|
||||||
|
|
||||||
parse_args(argc, argv, cmd_property_set_usage, &types,
|
parse_args(argc, argv, cmd_property_set_usage, &types,
|
||||||
&object, &name, &value);
|
&object, &name, &value, 3);
|
||||||
if (!object || !name || !value) {
|
if (!object || !name || !value) {
|
||||||
error("invalid arguments");
|
error("invalid arguments");
|
||||||
usage(cmd_property_set_usage);
|
usage(cmd_property_set_usage);
|
||||||
@ -446,13 +448,8 @@ static int cmd_property_list(int argc, char **argv)
|
|||||||
char *object = NULL;
|
char *object = NULL;
|
||||||
int types = 0;
|
int types = 0;
|
||||||
|
|
||||||
clean_args_no_options(argc, argv, cmd_property_list_usage);
|
|
||||||
|
|
||||||
if (check_argc_min(argc, 2) || check_argc_max(argc, 4))
|
|
||||||
usage(cmd_property_list_usage);
|
|
||||||
|
|
||||||
parse_args(argc, argv, cmd_property_list_usage,
|
parse_args(argc, argv, cmd_property_list_usage,
|
||||||
&types, &object, NULL, NULL);
|
&types, &object, NULL, NULL, 1);
|
||||||
if (!object) {
|
if (!object) {
|
||||||
error("invalid arguments");
|
error("invalid arguments");
|
||||||
usage(cmd_property_list_usage);
|
usage(cmd_property_list_usage);
|
||||||
|
Loading…
Reference in New Issue
Block a user