btrfs-progs: Add helpers functions to handle the printing of data in tabular format
This patch adds some functions to manage the printing of the data in
tabular format.
The function
struct string_table *table_create(int columns, int rows)
creates an (empty) table.
The functions
char *table_printf(struct string_table *tab, int column,
int row, char *fmt, ...)
char *table_vprintf(struct string_table *tab, int column,
int row, char *fmt, va_list ap)
populate the table with text. To align the text to the left, the text
shall be prefixed with '<', otherwise the text shall be prefixed by a
'>'. If the first character is a '=', the the text is replace by a
sequence of '=' to fill the column width.
The function
void table_free(struct string_table *)
frees all the data associated to the table.
The function
void table_dump(struct string_table *tab)
prints the table on stdout.
Signed-off-by: Goffredo Baroncelli <kreijack@inwind.it>
Signed-off-by: David Sterba <dsterba@suse.cz>
2014-02-13 19:19:21 +00:00
|
|
|
/*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public
|
|
|
|
* License v2 as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program 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
|
|
|
|
* General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public
|
|
|
|
* License along with this program; if not, write to the
|
|
|
|
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
* Boston, MA 021110-1307, USA.
|
|
|
|
*/
|
|
|
|
|
2015-01-21 16:49:26 +00:00
|
|
|
#ifndef __STRING_TABLE_H__
|
|
|
|
#define __STRING_TABLE_H__
|
btrfs-progs: Add helpers functions to handle the printing of data in tabular format
This patch adds some functions to manage the printing of the data in
tabular format.
The function
struct string_table *table_create(int columns, int rows)
creates an (empty) table.
The functions
char *table_printf(struct string_table *tab, int column,
int row, char *fmt, ...)
char *table_vprintf(struct string_table *tab, int column,
int row, char *fmt, va_list ap)
populate the table with text. To align the text to the left, the text
shall be prefixed with '<', otherwise the text shall be prefixed by a
'>'. If the first character is a '=', the the text is replace by a
sequence of '=' to fill the column width.
The function
void table_free(struct string_table *)
frees all the data associated to the table.
The function
void table_dump(struct string_table *tab)
prints the table on stdout.
Signed-off-by: Goffredo Baroncelli <kreijack@inwind.it>
Signed-off-by: David Sterba <dsterba@suse.cz>
2014-02-13 19:19:21 +00:00
|
|
|
|
2022-09-15 11:59:39 +00:00
|
|
|
#include <stdarg.h>
|
|
|
|
|
2022-11-28 18:50:57 +00:00
|
|
|
enum string_table_spacing {
|
|
|
|
STRING_TABLE_SPACING_1,
|
|
|
|
STRING_TABLE_SPACING_2,
|
|
|
|
};
|
|
|
|
|
btrfs-progs: Add helpers functions to handle the printing of data in tabular format
This patch adds some functions to manage the printing of the data in
tabular format.
The function
struct string_table *table_create(int columns, int rows)
creates an (empty) table.
The functions
char *table_printf(struct string_table *tab, int column,
int row, char *fmt, ...)
char *table_vprintf(struct string_table *tab, int column,
int row, char *fmt, va_list ap)
populate the table with text. To align the text to the left, the text
shall be prefixed with '<', otherwise the text shall be prefixed by a
'>'. If the first character is a '=', the the text is replace by a
sequence of '=' to fill the column width.
The function
void table_free(struct string_table *)
frees all the data associated to the table.
The function
void table_dump(struct string_table *tab)
prints the table on stdout.
Signed-off-by: Goffredo Baroncelli <kreijack@inwind.it>
Signed-off-by: David Sterba <dsterba@suse.cz>
2014-02-13 19:19:21 +00:00
|
|
|
struct string_table {
|
2022-11-28 18:50:57 +00:00
|
|
|
unsigned int ncols;
|
|
|
|
unsigned int nrows;
|
2022-11-30 14:29:53 +00:00
|
|
|
/* How many rows are header (names and separators). */
|
|
|
|
unsigned int hrows;
|
2022-11-28 18:50:57 +00:00
|
|
|
enum string_table_spacing spacing;
|
2015-11-02 23:46:52 +00:00
|
|
|
char *cells[];
|
btrfs-progs: Add helpers functions to handle the printing of data in tabular format
This patch adds some functions to manage the printing of the data in
tabular format.
The function
struct string_table *table_create(int columns, int rows)
creates an (empty) table.
The functions
char *table_printf(struct string_table *tab, int column,
int row, char *fmt, ...)
char *table_vprintf(struct string_table *tab, int column,
int row, char *fmt, va_list ap)
populate the table with text. To align the text to the left, the text
shall be prefixed with '<', otherwise the text shall be prefixed by a
'>'. If the first character is a '=', the the text is replace by a
sequence of '=' to fill the column width.
The function
void table_free(struct string_table *)
frees all the data associated to the table.
The function
void table_dump(struct string_table *tab)
prints the table on stdout.
Signed-off-by: Goffredo Baroncelli <kreijack@inwind.it>
Signed-off-by: David Sterba <dsterba@suse.cz>
2014-02-13 19:19:21 +00:00
|
|
|
};
|
|
|
|
|
2022-11-28 18:50:57 +00:00
|
|
|
struct string_table *table_create(unsigned int columns, unsigned int rows);
|
|
|
|
__attribute__ ((format (printf, 4, 0)))
|
|
|
|
char *table_printf(struct string_table *tab, unsigned int column, unsigned int row,
|
2016-09-29 13:12:35 +00:00
|
|
|
const char *fmt, ...);
|
2022-11-28 18:50:57 +00:00
|
|
|
char *table_vprintf(struct string_table *tab, unsigned int column, unsigned int row,
|
2016-09-29 13:12:35 +00:00
|
|
|
const char *fmt, va_list ap);
|
2022-11-28 18:50:57 +00:00
|
|
|
void table_free(struct string_table *tab);
|
btrfs-progs: Add helpers functions to handle the printing of data in tabular format
This patch adds some functions to manage the printing of the data in
tabular format.
The function
struct string_table *table_create(int columns, int rows)
creates an (empty) table.
The functions
char *table_printf(struct string_table *tab, int column,
int row, char *fmt, ...)
char *table_vprintf(struct string_table *tab, int column,
int row, char *fmt, va_list ap)
populate the table with text. To align the text to the left, the text
shall be prefixed with '<', otherwise the text shall be prefixed by a
'>'. If the first character is a '=', the the text is replace by a
sequence of '=' to fill the column width.
The function
void table_free(struct string_table *)
frees all the data associated to the table.
The function
void table_dump(struct string_table *tab)
prints the table on stdout.
Signed-off-by: Goffredo Baroncelli <kreijack@inwind.it>
Signed-off-by: David Sterba <dsterba@suse.cz>
2014-02-13 19:19:21 +00:00
|
|
|
|
2022-11-30 14:29:53 +00:00
|
|
|
void table_dump_range(struct string_table *tab, unsigned int from, unsigned int to);
|
|
|
|
|
|
|
|
static inline void table_dump(struct string_table *tab)
|
|
|
|
{
|
|
|
|
table_dump_range(tab, 0, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void table_dump_header(struct string_table *tab)
|
|
|
|
{
|
|
|
|
table_dump_range(tab, 0, tab->hrows);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void table_dump_body(struct string_table *tab)
|
|
|
|
{
|
|
|
|
table_dump_range(tab, tab->hrows, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
void table_clear_range(struct string_table *tab, unsigned int from, unsigned int to);
|
|
|
|
|
|
|
|
static inline void table_clear_header(struct string_table *tab)
|
|
|
|
{
|
|
|
|
table_clear_range(tab, 0, tab->hrows);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void table_clear_body(struct string_table *tab)
|
|
|
|
{
|
|
|
|
table_clear_range(tab, tab->hrows, 0);
|
|
|
|
}
|
|
|
|
|
btrfs-progs: Add helpers functions to handle the printing of data in tabular format
This patch adds some functions to manage the printing of the data in
tabular format.
The function
struct string_table *table_create(int columns, int rows)
creates an (empty) table.
The functions
char *table_printf(struct string_table *tab, int column,
int row, char *fmt, ...)
char *table_vprintf(struct string_table *tab, int column,
int row, char *fmt, va_list ap)
populate the table with text. To align the text to the left, the text
shall be prefixed with '<', otherwise the text shall be prefixed by a
'>'. If the first character is a '=', the the text is replace by a
sequence of '=' to fill the column width.
The function
void table_free(struct string_table *)
frees all the data associated to the table.
The function
void table_dump(struct string_table *tab)
prints the table on stdout.
Signed-off-by: Goffredo Baroncelli <kreijack@inwind.it>
Signed-off-by: David Sterba <dsterba@suse.cz>
2014-02-13 19:19:21 +00:00
|
|
|
#endif
|