From c155f3351a38e1f23d31db55d5221fe401bfb942 Mon Sep 17 00:00:00 2001 From: Francesco Giudici Date: Tue, 17 Jan 2017 14:20:56 +0100 Subject: nmcli: add -g[et-vars] as -t -f shortcut --- clients/cli/nmcli.c | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/clients/cli/nmcli.c b/clients/cli/nmcli.c index 1049b31da5..4e6f16de2f 100644 --- a/clients/cli/nmcli.c +++ b/clients/cli/nmcli.c @@ -176,6 +176,7 @@ usage (void) " -m[ode] tabular|multiline output mode\n" " -c[olors] auto|yes|no whether to use colors in output\n" " -f[ields] |all|common specify fields to output\n" + " -g[et-vars] |all|common shortcut for -m tabular -t -f \n" " -e[scape] yes|no escape columns separators in values\n" " -a[sk] ask for missing parameters\n" " -s[how-secrets] allow displaying passwords\n" @@ -231,7 +232,7 @@ process_command_line (NmCli *nmc, int argc, char **argv) if (argc == 1 && nmc->complete) { nmc_complete_strings (opt, "--terse", "--pretty", "--mode", "--colors", "--escape", "--fields", "--nocheck", "--ask", "--show-secrets", - "--wait", "--version", "--help", NULL); + "--get-vars", "--wait", "--version", "--help", NULL); } if (opt[1] == '-') { @@ -332,6 +333,21 @@ process_command_line (NmCli *nmc, int argc, char **argv) if (argc == 1 && nmc->complete) complete_fields (argv[0]); nmc->required_fields = g_strdup (argv[0]); + } else if (matches (opt, "-get-vars")) { + if (next_arg (&argc, &argv) != 0) { + g_string_printf (nmc->return_text, _("Error: fields for '%s' options are missing."), opt); + nmc->return_value = NMC_RESULT_ERROR_USER_INPUT; + return FALSE; + } + if (argc == 1 && nmc->complete) + complete_fields (argv[0]); + nmc->required_fields = g_strdup (argv[0]); + nmc->print_output = NMC_PRINT_TERSE; + /* We want fixed tabular mode here, but just set the mode specified and rely on the initialization + * in nmc_init: in this way we allow use of "-m multiline" to swap the output mode also if placed + * before the "-g " flag (-g may be still more practical and easy to remember than -t -f). + */ + nmc->mode_specified = TRUE; } else if (matches (opt, "-nocheck")) { /* ignore for backward compatibility */ } else if (matches (opt, "-ask")) { -- cgit v1.2.1