1
0
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:
Peter Rajnoha 2014-05-29 09:42:14 +02:00
parent 03a3f6078d
commit 6d667adeea
2 changed files with 54 additions and 7 deletions

View File

@ -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,10 +503,12 @@ 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,
"-------------------------------------------------------------------------------"); "-------------------------------------------------------------------------------");
if (display_all_fields_item) {
log_warn(" %sall%-*s - %s", type->prefix, log_warn(" %sall%-*s - %s", type->prefix,
(int) (id_len - 3 - strlen(type->prefix)), "", (int) (id_len - 3 - strlen(type->prefix)), "",
"All fields in this section."); "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) */
log_warn(" %-*s - %s", (int) id_len, rh->fields[f].id, rh->fields[f].desc); log_warn(" %-*s - %s", (int) id_len, rh->fields[f].id, rh->fields[f].desc);
@ -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;

View File

@ -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;
} }