forked from Mirrors/flatpak-builder
table printer: move to its own source files
This is a pretty standalone object, and it is nicer to have it in its own files. All users have been updated to include the new flatpak-table-printer.h header.tingping/wmclass
parent
1577c1a08e
commit
62b8ae2953
|
@ -31,6 +31,7 @@
|
|||
|
||||
#include "flatpak-builtins.h"
|
||||
#include "flatpak-utils.h"
|
||||
#include "flatpak-table-printer.h"
|
||||
|
||||
static gboolean opt_show_details;
|
||||
static gboolean opt_user;
|
||||
|
|
|
@ -31,6 +31,7 @@
|
|||
|
||||
#include "flatpak-builtins.h"
|
||||
#include "flatpak-utils.h"
|
||||
#include "flatpak-table-printer.h"
|
||||
|
||||
static gboolean opt_show_details;
|
||||
static gboolean opt_user;
|
||||
|
|
|
@ -31,6 +31,7 @@
|
|||
|
||||
#include "flatpak-builtins.h"
|
||||
#include "flatpak-utils.h"
|
||||
#include "flatpak-table-printer.h"
|
||||
|
||||
static gboolean opt_show_details;
|
||||
static gboolean opt_runtime;
|
||||
|
|
|
@ -31,6 +31,7 @@
|
|||
|
||||
#include "flatpak-builtins.h"
|
||||
#include "flatpak-utils.h"
|
||||
#include "flatpak-table-printer.h"
|
||||
|
||||
static void
|
||||
print_info (GVariant *summary)
|
||||
|
|
|
@ -39,6 +39,8 @@ libflatpak_common_la_SOURCES = \
|
|||
common/flatpak-portal-error.h \
|
||||
common/flatpak-utils.c \
|
||||
common/flatpak-utils.h \
|
||||
common/flatpak-table-printer.c \
|
||||
common/flatpak-table-printer.h \
|
||||
common/flatpak-chain-input-stream.c \
|
||||
common/flatpak-chain-input-stream.h \
|
||||
common/gvdb/gvdb-reader.h \
|
||||
|
|
|
@ -0,0 +1,211 @@
|
|||
/*
|
||||
* Copyright © 2014 Red Hat, Inc
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Lesser General Public
|
||||
* License as published by the Free Software Foundation; either
|
||||
* version 2.1 of the License, or (at your option) any later version.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
||||
*
|
||||
* Authors:
|
||||
* Alexander Larsson <alexl@redhat.com>
|
||||
*/
|
||||
|
||||
#include "config.h"
|
||||
|
||||
#include "flatpak-table-printer.h"
|
||||
|
||||
#include <string.h>
|
||||
#include <stdlib.h>
|
||||
#include <unistd.h>
|
||||
|
||||
|
||||
typedef struct {
|
||||
char *text;
|
||||
int align;
|
||||
} Cell;
|
||||
|
||||
static void
|
||||
free_cell (gpointer data)
|
||||
{
|
||||
Cell *cell = data;
|
||||
|
||||
g_free (cell->text);
|
||||
g_free (cell);
|
||||
}
|
||||
|
||||
struct FlatpakTablePrinter
|
||||
{
|
||||
GPtrArray *titles;
|
||||
GPtrArray *rows;
|
||||
GPtrArray *current;
|
||||
int n_columns;
|
||||
};
|
||||
|
||||
FlatpakTablePrinter *
|
||||
flatpak_table_printer_new (void)
|
||||
{
|
||||
FlatpakTablePrinter *printer = g_new0 (FlatpakTablePrinter, 1);
|
||||
|
||||
printer->titles = g_ptr_array_new_with_free_func (g_free);
|
||||
printer->rows = g_ptr_array_new_with_free_func ((GDestroyNotify) g_ptr_array_unref);
|
||||
printer->current = g_ptr_array_new_with_free_func (free_cell);
|
||||
|
||||
return printer;
|
||||
}
|
||||
|
||||
void
|
||||
flatpak_table_printer_free (FlatpakTablePrinter *printer)
|
||||
{
|
||||
g_ptr_array_free (printer->titles, TRUE);
|
||||
g_ptr_array_free (printer->rows, TRUE);
|
||||
g_ptr_array_free (printer->current, TRUE);
|
||||
g_free (printer);
|
||||
}
|
||||
|
||||
void
|
||||
flatpak_table_printer_set_column_title (FlatpakTablePrinter *printer,
|
||||
int column,
|
||||
const char *text)
|
||||
{
|
||||
g_ptr_array_insert (printer->titles, column, g_strdup (text));
|
||||
}
|
||||
|
||||
void
|
||||
flatpak_table_printer_add_aligned_column (FlatpakTablePrinter *printer,
|
||||
const char *text,
|
||||
int align)
|
||||
{
|
||||
Cell *cell = g_new (Cell, 1);
|
||||
cell->text = text ? g_strdup (text) : g_strdup ("");
|
||||
cell->align = align;
|
||||
g_ptr_array_add (printer->current, cell);
|
||||
}
|
||||
|
||||
void
|
||||
flatpak_table_printer_add_column (FlatpakTablePrinter *printer,
|
||||
const char *text)
|
||||
{
|
||||
flatpak_table_printer_add_aligned_column (printer, text, -1);
|
||||
}
|
||||
|
||||
void
|
||||
flatpak_table_printer_add_column_len (FlatpakTablePrinter *printer,
|
||||
const char *text,
|
||||
gsize len)
|
||||
{
|
||||
Cell *cell = g_new (Cell, 1);
|
||||
cell->text = text ? g_strndup (text, len) : g_strdup ("");
|
||||
cell->align = -1;
|
||||
g_ptr_array_add (printer->current, cell);
|
||||
}
|
||||
|
||||
void
|
||||
flatpak_table_printer_append_with_comma (FlatpakTablePrinter *printer,
|
||||
const char *text)
|
||||
{
|
||||
Cell *cell;
|
||||
char *new;
|
||||
|
||||
g_assert (printer->current->len > 0);
|
||||
|
||||
cell = g_ptr_array_index (printer->current, printer->current->len - 1);
|
||||
|
||||
if (cell->text[0] != 0)
|
||||
new = g_strconcat (cell->text, ",", text, NULL);
|
||||
else
|
||||
new = g_strdup (text);
|
||||
|
||||
g_free (cell->text);
|
||||
cell->text = new;
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
flatpak_table_printer_finish_row (FlatpakTablePrinter *printer)
|
||||
{
|
||||
if (printer->current->len == 0)
|
||||
return; /* Ignore empty rows */
|
||||
|
||||
printer->n_columns = MAX (printer->n_columns, printer->current->len);
|
||||
g_ptr_array_add (printer->rows, printer->current);
|
||||
printer->current = g_ptr_array_new_with_free_func (free_cell);
|
||||
}
|
||||
|
||||
void
|
||||
flatpak_table_printer_print (FlatpakTablePrinter *printer)
|
||||
{
|
||||
g_autofree int *widths = NULL;
|
||||
g_autofree int *lwidths = NULL;
|
||||
g_autofree int *rwidths = NULL;
|
||||
int i, j;
|
||||
|
||||
if (printer->current->len != 0)
|
||||
flatpak_table_printer_finish_row (printer);
|
||||
|
||||
widths = g_new0 (int, printer->n_columns);
|
||||
lwidths = g_new0 (int, printer->n_columns);
|
||||
rwidths = g_new0 (int, printer->n_columns);
|
||||
|
||||
for (i = 0; i < printer->titles->len; i++)
|
||||
{
|
||||
char *title = g_ptr_array_index (printer->titles, i);
|
||||
|
||||
if (title)
|
||||
widths[i] = MAX (widths[i], strlen (title));
|
||||
}
|
||||
|
||||
for (i = 0; i < printer->rows->len; i++)
|
||||
{
|
||||
GPtrArray *row = g_ptr_array_index (printer->rows, i);
|
||||
|
||||
for (j = 0; j < row->len; j++)
|
||||
{
|
||||
Cell *cell = g_ptr_array_index (row, j);
|
||||
int width;
|
||||
|
||||
width = strlen (cell->text);
|
||||
widths[j] = MAX (widths[j], width);
|
||||
if (cell->align >= 0)
|
||||
{
|
||||
lwidths[j] = MAX (lwidths[j], cell->align);
|
||||
rwidths[j] = MAX (rwidths[j], width - cell->align);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (isatty (STDOUT_FILENO) && printer->titles->len > 0)
|
||||
{
|
||||
g_print ("\x1b[1m"); /* bold on */
|
||||
for (i = 0; i < printer->titles->len; i++)
|
||||
{
|
||||
char *title = g_ptr_array_index (printer->titles, i);
|
||||
|
||||
g_print ("%s%-*s", (i == 0) ? "" : " ", widths[i], title);
|
||||
}
|
||||
g_print ("\x1b[0m"); /* bold off */
|
||||
g_print ("\n");
|
||||
}
|
||||
|
||||
for (i = 0; i < printer->rows->len; i++)
|
||||
{
|
||||
GPtrArray *row = g_ptr_array_index (printer->rows, i);
|
||||
|
||||
for (j = 0; j < row->len; j++)
|
||||
{
|
||||
Cell *cell = g_ptr_array_index (row, j);
|
||||
if (cell->align < 0)
|
||||
g_print ("%s%-*s", (j == 0) ? "" : " ", widths[j], cell->text);
|
||||
else
|
||||
g_print ("%s%*s%-*s", (j == 0) ? "" : " ", lwidths[j] - cell->align, "", widths[j] - (lwidths[j] - cell->align), cell->text);
|
||||
}
|
||||
g_print ("\n");
|
||||
}
|
||||
}
|
|
@ -0,0 +1,46 @@
|
|||
/*
|
||||
* Copyright © 2014 Red Hat, Inc
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Lesser General Public
|
||||
* License as published by the Free Software Foundation; either
|
||||
* version 2.1 of the License, or (at your option) any later version.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
||||
*
|
||||
* Authors:
|
||||
* Alexander Larsson <alexl@redhat.com>
|
||||
*/
|
||||
|
||||
#ifndef __FLATPAK_TABLE_PRINTER_H__
|
||||
#define __FLATPAK_TABLE_PRINTER_H__
|
||||
|
||||
#include <gio/gio.h>
|
||||
|
||||
typedef struct FlatpakTablePrinter FlatpakTablePrinter;
|
||||
|
||||
FlatpakTablePrinter *flatpak_table_printer_new (void);
|
||||
void flatpak_table_printer_free (FlatpakTablePrinter *printer);
|
||||
void flatpak_table_printer_set_column_title (FlatpakTablePrinter *printer,
|
||||
int column,
|
||||
const char *title);
|
||||
void flatpak_table_printer_add_column (FlatpakTablePrinter *printer,
|
||||
const char *text);
|
||||
void flatpak_table_printer_add_aligned_column (FlatpakTablePrinter *printer,
|
||||
const char *text,
|
||||
int align);
|
||||
void flatpak_table_printer_add_column_len (FlatpakTablePrinter *printer,
|
||||
const char *text,
|
||||
gsize len);
|
||||
void flatpak_table_printer_append_with_comma (FlatpakTablePrinter *printer,
|
||||
const char *text);
|
||||
void flatpak_table_printer_finish_row (FlatpakTablePrinter *printer);
|
||||
void flatpak_table_printer_print (FlatpakTablePrinter *printer);
|
||||
|
||||
#endif /* __FLATPAK_TABLE_PRINTER_H__ */
|
|
@ -1545,189 +1545,6 @@ flatpak_mkstempat (int dir_fd,
|
|||
return -1;
|
||||
}
|
||||
|
||||
typedef struct {
|
||||
char *text;
|
||||
int align;
|
||||
} Cell;
|
||||
|
||||
static void
|
||||
free_cell (gpointer data)
|
||||
{
|
||||
Cell *cell = data;
|
||||
|
||||
g_free (cell->text);
|
||||
g_free (cell);
|
||||
}
|
||||
|
||||
struct FlatpakTablePrinter
|
||||
{
|
||||
GPtrArray *titles;
|
||||
GPtrArray *rows;
|
||||
GPtrArray *current;
|
||||
int n_columns;
|
||||
};
|
||||
|
||||
FlatpakTablePrinter *
|
||||
flatpak_table_printer_new (void)
|
||||
{
|
||||
FlatpakTablePrinter *printer = g_new0 (FlatpakTablePrinter, 1);
|
||||
|
||||
printer->titles = g_ptr_array_new_with_free_func (g_free);
|
||||
printer->rows = g_ptr_array_new_with_free_func ((GDestroyNotify) g_ptr_array_unref);
|
||||
printer->current = g_ptr_array_new_with_free_func (free_cell);
|
||||
|
||||
return printer;
|
||||
}
|
||||
|
||||
void
|
||||
flatpak_table_printer_free (FlatpakTablePrinter *printer)
|
||||
{
|
||||
g_ptr_array_free (printer->titles, TRUE);
|
||||
g_ptr_array_free (printer->rows, TRUE);
|
||||
g_ptr_array_free (printer->current, TRUE);
|
||||
g_free (printer);
|
||||
}
|
||||
|
||||
void
|
||||
flatpak_table_printer_set_column_title (FlatpakTablePrinter *printer,
|
||||
int column,
|
||||
const char *text)
|
||||
{
|
||||
g_ptr_array_insert (printer->titles, column, g_strdup (text));
|
||||
}
|
||||
|
||||
void
|
||||
flatpak_table_printer_add_aligned_column (FlatpakTablePrinter *printer,
|
||||
const char *text,
|
||||
int align)
|
||||
{
|
||||
Cell *cell = g_new (Cell, 1);
|
||||
cell->text = text ? g_strdup (text) : g_strdup ("");
|
||||
cell->align = align;
|
||||
g_ptr_array_add (printer->current, cell);
|
||||
}
|
||||
|
||||
void
|
||||
flatpak_table_printer_add_column (FlatpakTablePrinter *printer,
|
||||
const char *text)
|
||||
{
|
||||
flatpak_table_printer_add_aligned_column (printer, text, -1);
|
||||
}
|
||||
|
||||
void
|
||||
flatpak_table_printer_add_column_len (FlatpakTablePrinter *printer,
|
||||
const char *text,
|
||||
gsize len)
|
||||
{
|
||||
Cell *cell = g_new (Cell, 1);
|
||||
cell->text = text ? g_strndup (text, len) : g_strdup ("");
|
||||
cell->align = -1;
|
||||
g_ptr_array_add (printer->current, cell);
|
||||
}
|
||||
|
||||
void
|
||||
flatpak_table_printer_append_with_comma (FlatpakTablePrinter *printer,
|
||||
const char *text)
|
||||
{
|
||||
Cell *cell;
|
||||
char *new;
|
||||
|
||||
g_assert (printer->current->len > 0);
|
||||
|
||||
cell = g_ptr_array_index (printer->current, printer->current->len - 1);
|
||||
|
||||
if (cell->text[0] != 0)
|
||||
new = g_strconcat (cell->text, ",", text, NULL);
|
||||
else
|
||||
new = g_strdup (text);
|
||||
|
||||
g_free (cell->text);
|
||||
cell->text = new;
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
flatpak_table_printer_finish_row (FlatpakTablePrinter *printer)
|
||||
{
|
||||
if (printer->current->len == 0)
|
||||
return; /* Ignore empty rows */
|
||||
|
||||
printer->n_columns = MAX (printer->n_columns, printer->current->len);
|
||||
g_ptr_array_add (printer->rows, printer->current);
|
||||
printer->current = g_ptr_array_new_with_free_func (free_cell);
|
||||
}
|
||||
|
||||
void
|
||||
flatpak_table_printer_print (FlatpakTablePrinter *printer)
|
||||
{
|
||||
g_autofree int *widths = NULL;
|
||||
g_autofree int *lwidths = NULL;
|
||||
g_autofree int *rwidths = NULL;
|
||||
int i, j;
|
||||
|
||||
if (printer->current->len != 0)
|
||||
flatpak_table_printer_finish_row (printer);
|
||||
|
||||
widths = g_new0 (int, printer->n_columns);
|
||||
lwidths = g_new0 (int, printer->n_columns);
|
||||
rwidths = g_new0 (int, printer->n_columns);
|
||||
|
||||
for (i = 0; i < printer->titles->len; i++)
|
||||
{
|
||||
char *title = g_ptr_array_index (printer->titles, i);
|
||||
|
||||
if (title)
|
||||
widths[i] = MAX (widths[i], strlen (title));
|
||||
}
|
||||
|
||||
for (i = 0; i < printer->rows->len; i++)
|
||||
{
|
||||
GPtrArray *row = g_ptr_array_index (printer->rows, i);
|
||||
|
||||
for (j = 0; j < row->len; j++)
|
||||
{
|
||||
Cell *cell = g_ptr_array_index (row, j);
|
||||
int width;
|
||||
|
||||
width = strlen (cell->text);
|
||||
widths[j] = MAX (widths[j], width);
|
||||
if (cell->align >= 0)
|
||||
{
|
||||
lwidths[j] = MAX (lwidths[j], cell->align);
|
||||
rwidths[j] = MAX (rwidths[j], width - cell->align);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (isatty (STDOUT_FILENO) && printer->titles->len > 0)
|
||||
{
|
||||
g_print ("\x1b[1m"); /* bold on */
|
||||
for (i = 0; i < printer->titles->len; i++)
|
||||
{
|
||||
char *title = g_ptr_array_index (printer->titles, i);
|
||||
|
||||
g_print ("%s%-*s", (i == 0) ? "" : " ", widths[i], title);
|
||||
}
|
||||
g_print ("\x1b[0m"); /* bold off */
|
||||
g_print ("\n");
|
||||
}
|
||||
|
||||
for (i = 0; i < printer->rows->len; i++)
|
||||
{
|
||||
GPtrArray *row = g_ptr_array_index (printer->rows, i);
|
||||
|
||||
for (j = 0; j < row->len; j++)
|
||||
{
|
||||
Cell *cell = g_ptr_array_index (row, j);
|
||||
if (cell->align < 0)
|
||||
g_print ("%s%-*s", (j == 0) ? "" : " ", widths[j], cell->text);
|
||||
else
|
||||
g_print ("%s%*s%-*s", (j == 0) ? "" : " ", lwidths[j] - cell->align, "", widths[j] - (lwidths[j] - cell->align), cell->text);
|
||||
}
|
||||
g_print ("\n");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
static GHashTable *app_ids;
|
||||
|
||||
|
|
|
@ -274,27 +274,6 @@ gint flatpak_mkstempat (int dir_fd,
|
|||
int flags,
|
||||
int mode);
|
||||
|
||||
|
||||
typedef struct FlatpakTablePrinter FlatpakTablePrinter;
|
||||
|
||||
FlatpakTablePrinter *flatpak_table_printer_new (void);
|
||||
void flatpak_table_printer_free (FlatpakTablePrinter *printer);
|
||||
void flatpak_table_printer_set_column_title (FlatpakTablePrinter *printer,
|
||||
int column,
|
||||
const char *title);
|
||||
void flatpak_table_printer_add_column (FlatpakTablePrinter *printer,
|
||||
const char *text);
|
||||
void flatpak_table_printer_add_aligned_column (FlatpakTablePrinter *printer,
|
||||
const char *text,
|
||||
int align);
|
||||
void flatpak_table_printer_add_column_len (FlatpakTablePrinter *printer,
|
||||
const char *text,
|
||||
gsize len);
|
||||
void flatpak_table_printer_append_with_comma (FlatpakTablePrinter *printer,
|
||||
const char *text);
|
||||
void flatpak_table_printer_finish_row (FlatpakTablePrinter *printer);
|
||||
void flatpak_table_printer_print (FlatpakTablePrinter *printer);
|
||||
|
||||
gboolean flatpak_repo_set_title (OstreeRepo *repo,
|
||||
const char *title,
|
||||
GError **error);
|
||||
|
|
Loading…
Reference in New Issue