mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-04 09:18:36 +03:00
report: select: add help for creating selections
The "<lvm command> -S/--select help" shows help (including list of fields to match against): ...field list here including the field type name... Selection operands ------------------ field - Reporting field. number - Non-negative integer value. size - Floating point value with units specified. string - Characters quoted by ' or " or unquoted. string list - Strings enclosed by [ ] and elements delimited by either "all items must match" or "at least one item must match" operator. regular expression - Characters quoted by ' or " or unquoted. Selection operators ------------------- Comparison operators: =~ - Matching regular expression. !~ - Not matching regular expression. = - Equal to. != - Not equal to. >= - Greater than or equal to. > - Greater than <= - Less than or equal to. < - Less than. Logical and grouping operators: && - All fields must match , - All fields must match || - At least one field must match # - At least one field must match ! - Logical negation ( - Left parenthesis ) - Right parenthesis [ - List start ] - List end
This commit is contained in:
parent
03a3f6078d
commit
6d667adeea
@ -475,7 +475,7 @@ void dm_report_field_set_value(struct dm_report_field *field, const void *value,
|
|||||||
/*
|
/*
|
||||||
* show help message
|
* show help message
|
||||||
*/
|
*/
|
||||||
static void _display_fields(struct dm_report *rh)
|
static void _display_fields(struct dm_report *rh, int display_all_fields_item)
|
||||||
{
|
{
|
||||||
uint32_t f;
|
uint32_t f;
|
||||||
const struct dm_report_object_type *type;
|
const struct dm_report_object_type *type;
|
||||||
@ -503,9 +503,11 @@ static void _display_fields(struct dm_report *rh)
|
|||||||
log_warn("%*.*s", (int) strlen(desc) + 7,
|
log_warn("%*.*s", (int) strlen(desc) + 7,
|
||||||
(int) strlen(desc) + 7,
|
(int) strlen(desc) + 7,
|
||||||
"-------------------------------------------------------------------------------");
|
"-------------------------------------------------------------------------------");
|
||||||
log_warn(" %sall%-*s - %s", type->prefix,
|
if (display_all_fields_item) {
|
||||||
(int) (id_len - 3 - strlen(type->prefix)), "",
|
log_warn(" %sall%-*s - %s", type->prefix,
|
||||||
"All fields in this section.");
|
(int) (id_len - 3 - strlen(type->prefix)), "",
|
||||||
|
"All fields in this section.");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* FIXME Add line-wrapping at terminal width (or 80 cols) */
|
/* FIXME Add line-wrapping at terminal width (or 80 cols) */
|
||||||
@ -768,7 +770,7 @@ static int _parse_fields(struct dm_report *rh, const char *format,
|
|||||||
we++;
|
we++;
|
||||||
|
|
||||||
if (!_field_match(rh, ws, (size_t) (we - ws), report_type_only)) {
|
if (!_field_match(rh, ws, (size_t) (we - ws), report_type_only)) {
|
||||||
_display_fields(rh);
|
_display_fields(rh, 1);
|
||||||
log_warn(" ");
|
log_warn(" ");
|
||||||
if (strcasecmp(ws, DM_REPORT_FIELD_RESERVED_NAME_HELP) &&
|
if (strcasecmp(ws, DM_REPORT_FIELD_RESERVED_NAME_HELP) &&
|
||||||
strcmp(ws, DM_REPORT_FIELD_RESERVED_NAME_HELP_ALT))
|
strcmp(ws, DM_REPORT_FIELD_RESERVED_NAME_HELP_ALT))
|
||||||
@ -798,7 +800,7 @@ static int _parse_keys(struct dm_report *rh, const char *keys,
|
|||||||
while (*we && *we != ',')
|
while (*we && *we != ',')
|
||||||
we++;
|
we++;
|
||||||
if (!_key_match(rh, ws, (size_t) (we - ws), report_type_only)) {
|
if (!_key_match(rh, ws, (size_t) (we - ws), report_type_only)) {
|
||||||
_display_fields(rh);
|
_display_fields(rh, 1);
|
||||||
log_warn(" ");
|
log_warn(" ");
|
||||||
if (strcasecmp(ws, DM_REPORT_FIELD_RESERVED_NAME_HELP) &&
|
if (strcasecmp(ws, DM_REPORT_FIELD_RESERVED_NAME_HELP) &&
|
||||||
strcmp(ws, DM_REPORT_FIELD_RESERVED_NAME_HELP_ALT))
|
strcmp(ws, DM_REPORT_FIELD_RESERVED_NAME_HELP_ALT))
|
||||||
@ -1835,6 +1837,34 @@ static struct selection_node *_alloc_selection_node(struct dm_pool *mem, uint32_
|
|||||||
return sn;
|
return sn;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void _display_selection_help(struct dm_report *rh)
|
||||||
|
{
|
||||||
|
struct op_def *t;
|
||||||
|
|
||||||
|
log_warn("Selection operands");
|
||||||
|
log_warn("------------------");
|
||||||
|
log_warn(" field - Reporting field.");
|
||||||
|
log_warn(" number - Non-negative integer value.");
|
||||||
|
log_warn(" size - Floating point value with units, 'm' unit used by default if not specified.");
|
||||||
|
log_warn(" string - Characters quoted by \' or \" or unquoted.");
|
||||||
|
log_warn(" string list - Strings enclosed by [ ] and elements delimited by either");
|
||||||
|
log_warn(" \"all items must match\" or \"at least one item must match\" operator.");
|
||||||
|
log_warn(" regular expression - Characters quoted by \' or \" or unquoted.");
|
||||||
|
log_warn(" ");
|
||||||
|
log_warn("Selection operators");
|
||||||
|
log_warn("-------------------");
|
||||||
|
log_warn(" Comparison operators:");
|
||||||
|
t = _op_cmp;
|
||||||
|
for (; t->string; t++)
|
||||||
|
log_warn(" %4s - %s", t->string, t->desc);
|
||||||
|
log_warn(" ");
|
||||||
|
log_warn(" Logical and grouping operators:");
|
||||||
|
t = _op_log;
|
||||||
|
for (; t->string; t++)
|
||||||
|
log_warn(" %4s - %s", t->string, t->desc);
|
||||||
|
log_warn(" ");
|
||||||
|
}
|
||||||
|
|
||||||
static char _sel_syntax_error_at_msg[] = "Selection syntax error at '%s'.";
|
static char _sel_syntax_error_at_msg[] = "Selection syntax error at '%s'.";
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1884,6 +1914,8 @@ static struct selection_node *_parse_selection(struct dm_report *rh,
|
|||||||
c = we[0];
|
c = we[0];
|
||||||
tmp = (char *) we;
|
tmp = (char *) we;
|
||||||
tmp[0] = '\0';
|
tmp[0] = '\0';
|
||||||
|
_display_fields(rh, 0);
|
||||||
|
log_warn(" ");
|
||||||
log_error("Unrecognised selection field: %s", ws);
|
log_error("Unrecognised selection field: %s", ws);
|
||||||
tmp[0] = c;
|
tmp[0] = c;
|
||||||
goto bad;
|
goto bad;
|
||||||
@ -1893,10 +1925,12 @@ static struct selection_node *_parse_selection(struct dm_report *rh,
|
|||||||
|
|
||||||
/* comparison operator */
|
/* comparison operator */
|
||||||
if (!(flags = _tok_op_cmp(we, &last))) {
|
if (!(flags = _tok_op_cmp(we, &last))) {
|
||||||
|
_display_selection_help(rh);
|
||||||
log_error("Unrecognised comparison operator: %s", we);
|
log_error("Unrecognised comparison operator: %s", we);
|
||||||
goto bad;
|
goto bad;
|
||||||
}
|
}
|
||||||
if (!last) {
|
if (!last) {
|
||||||
|
_display_selection_help(rh);
|
||||||
log_error("Missing value after operator");
|
log_error("Missing value after operator");
|
||||||
goto bad;
|
goto bad;
|
||||||
}
|
}
|
||||||
@ -1905,6 +1939,7 @@ static struct selection_node *_parse_selection(struct dm_report *rh,
|
|||||||
if ((flags & FLD_CMP_NUMBER) &&
|
if ((flags & FLD_CMP_NUMBER) &&
|
||||||
(ft->flags != DM_REPORT_FIELD_TYPE_NUMBER) &&
|
(ft->flags != DM_REPORT_FIELD_TYPE_NUMBER) &&
|
||||||
(ft->flags != DM_REPORT_FIELD_TYPE_SIZE)) {
|
(ft->flags != DM_REPORT_FIELD_TYPE_SIZE)) {
|
||||||
|
_display_selection_help(rh);
|
||||||
log_error("Operator can be used only with numeric or size fields: %s", ws);
|
log_error("Operator can be used only with numeric or size fields: %s", ws);
|
||||||
goto bad;
|
goto bad;
|
||||||
}
|
}
|
||||||
@ -2084,6 +2119,15 @@ struct dm_report *dm_report_init_with_selection(uint32_t *report_types,
|
|||||||
return rh;
|
return rh;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!strcasecmp(selection, DM_REPORT_FIELD_RESERVED_NAME_HELP) ||
|
||||||
|
!strcmp(selection, DM_REPORT_FIELD_RESERVED_NAME_HELP_ALT)) {
|
||||||
|
_display_fields(rh, 0);
|
||||||
|
log_warn(" ");
|
||||||
|
_display_selection_help(rh);
|
||||||
|
dm_report_free(rh);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
if (!(root = _alloc_selection_node(rh->mem, SEL_OR)))
|
if (!(root = _alloc_selection_node(rh->mem, SEL_OR)))
|
||||||
return_0;
|
return_0;
|
||||||
|
|
||||||
|
@ -358,7 +358,10 @@ static int _report(struct cmd_context *cmd, int argc, char **argv,
|
|||||||
if ( (!strcasecmp(options, DM_REPORT_FIELD_RESERVED_NAME_HELP) ||
|
if ( (!strcasecmp(options, DM_REPORT_FIELD_RESERVED_NAME_HELP) ||
|
||||||
!strcmp(options, DM_REPORT_FIELD_RESERVED_NAME_HELP_ALT)) ||
|
!strcmp(options, DM_REPORT_FIELD_RESERVED_NAME_HELP_ALT)) ||
|
||||||
(!strcasecmp(keys, DM_REPORT_FIELD_RESERVED_NAME_HELP) ||
|
(!strcasecmp(keys, DM_REPORT_FIELD_RESERVED_NAME_HELP) ||
|
||||||
!strcmp(keys, DM_REPORT_FIELD_RESERVED_NAME_HELP_ALT)) )
|
!strcmp(keys, DM_REPORT_FIELD_RESERVED_NAME_HELP_ALT)) ||
|
||||||
|
(selection &&
|
||||||
|
(!strcasecmp(selection, DM_REPORT_FIELD_RESERVED_NAME_HELP) ||
|
||||||
|
!strcmp(selection, DM_REPORT_FIELD_RESERVED_NAME_HELP_ALT))) )
|
||||||
return r;
|
return r;
|
||||||
return_ECMD_FAILED;
|
return_ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user