cli: enhance printing to align tabular output properly and not to waste space
Until now we have used a static width defined for each column for tabular output. Even if this worked in most cases, it was not optimal, because by using too wide columns we wasted space, and in case of a too narrow column the alignment broke. So, we need to know the longest string in a column to be able to align columns in the tabular output. Thus, the printing has to be postponed till we have all data available, and can find the widest column. This value is then used for aligning while printing the data. Arrays of NmcOutputField (rows) are inserted into output_data array. When all data have been added, print_data() can be used to print the whole output_data array with proper alignment. A single row can be printed using print_required_fields(). Also, output flags are redone to better match the new output_data array. The flags are needed for every row (in tabular output); they are stored in the first field (NmcOutputField) for the whole row. Addapted set_val_str() and set_val_arr() to set value type (char * x char **). Added set_val_strc(), set_val_arrc() for const values that should not be freed. output_data takes ownership of the data added to it and takes care of freeing the memory. See e.g. https://bugzilla.gnome.org/show_bug.cgi?id=699503
This commit is contained in:
@@ -323,7 +323,7 @@ nmc_init (NmCli *nmc)
|
||||
nmc->mode_specified = FALSE;
|
||||
nmc->escape_values = TRUE;
|
||||
nmc->required_fields = NULL;
|
||||
nmc->allowed_fields = NULL;
|
||||
nmc->output_data = g_ptr_array_new_full (20, g_free);
|
||||
memset (&nmc->print_fields, '\0', sizeof (NmcPrintFields));
|
||||
nmc->nocheck_ver = FALSE;
|
||||
nmc->ask = FALSE;
|
||||
@@ -340,6 +340,8 @@ nmc_cleanup (NmCli *nmc)
|
||||
g_slist_free (nmc->system_connections);
|
||||
|
||||
g_free (nmc->required_fields);
|
||||
nmc_empty_output_fields (nmc);
|
||||
g_ptr_array_unref (nmc->output_data);
|
||||
if (nmc->print_fields.indices)
|
||||
g_array_free (nmc->print_fields.indices, TRUE);
|
||||
}
|
||||
|
Reference in New Issue
Block a user