xaizek / vifm (License: GPLv2+) (since 2018-12-07)
Vifm is a file manager with curses interface, which provides Vi[m]-like environment for managing objects within file systems, extended with some useful ideas from mutt.
<root> / src / ui / column_view.h (4f50cf497d13c48611993dafdee18b65ec145131) (5,332B) (mode 100644) [raw]
/* vifm
 * Copyright (C) 2012 xaizek.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
 */

#ifndef VIFM__UI__COLUMN_VIEW_H__
#define VIFM__UI__COLUMN_VIEW_H__

#include <stddef.h> /* size_t */

/* Special reserved column id for gap filling request. */
#define FILL_COLUMN_ID ~0

/* Type of text alignment within a column. */
typedef enum
{
	AT_LEFT,   /* Left alignment. */
	AT_RIGHT,  /* Right alignment. */
	AT_MIDDLE, /* Left alignment, if the text fits.  If the text is longer, make
	              sure the start and the end of field are always visible by
	              cutting the text in the middle. */
	AT_DYN     /* Left alignment, if the text fits if the text is longer, make
	              sure the end of field is always visible. */
}
AlignType;

/* Type of size units of a column. */
typedef enum
{
	ST_ABSOLUTE, /* Column width is specified in characters. */
	ST_PERCENT,  /* Column width is specified in percents of view width. */
	ST_AUTO      /* Column width is automatically determined. */
}
SizingType;

/* Type of text truncation if it doesn't fix in the column. */
typedef enum
{
	CT_TRUNCATE, /* Text is truncated. */
	CT_ELLIPSIS, /* Ellipsis are added. */
	CT_NONE      /* Text can pass column boundaries. */
}
CropType;

/* Opaque columns handle. */
typedef struct columns_t columns_t;

/* Structure containing column data passed to handlers. */
typedef struct format_info_t format_info_t;
struct format_info_t
{
	void *data;     /* User data passed to columns_format_line(). */
	int id;         /* Id of the column or FILL_COLUMN_ID (pseudo-column). */
	int real_id;    /* Id of the column that is being printed/filled. */
	int width;      /* Calculated width of the column. */
	int match_from; /* Start offset of the match, -1 for no match. */
	int match_to;   /* End offset of the mat, -1 for no match. */
};

/* A column callback function, which should fill the buf with column text. */
typedef void (*column_func)(void *data, size_t buf_len, char buf[],
		const format_info_t *info);

/* A callback function, for displaying column contents.  Alignment specifies
 * actual alignment of current column (AT_DYN won't appear here). */
typedef void (*column_line_print_func)(const char buf[], int offset,
		AlignType align, const char full_column[], const format_info_t *info);
/* A callback function that returns search match of the column via match_from
 * and match_to output parameters (no need to update them if there is no
 * match). */
typedef void (*column_line_match_func)(const char full_column[],
		const format_info_t *info, int *match_from, int *match_to);

/* Structure containing various column display properties. */
typedef struct
{
	char *literal;     /* Fixed contents of the column. */
	int column_id;     /* Unique id of existing column. */
	int full_width;    /* Full width of the column, units depend on size type. */
	int text_width;    /* Text width, ignored unless size type is ST_ABSOLUTE. */
	AlignType align;   /* Specifies type of text alignment. */
	SizingType sizing; /* Specifies type of sizing. */
	CropType cropping; /* Specifies type of text cropping. */
}
column_info_t;

/* Registers column print function (required to use this unit). */
void columns_set_line_print_func(column_line_print_func func);

/* Registers column match function (optional). */
void columns_set_line_match_func(column_line_match_func func);

/* Sets string to be used in place of ellipsis.  The argument is used directly,
 * no copy is made. */
void columns_set_ellipsis(const char ell[]);

/* Registers column func by its unique column_id.
 * Returns zero on success and non-zero otherwise. */
int columns_add_column_desc(int column_id, column_func func, void *data);

/* Unregisters all column functions. */
void columns_clear_column_descs(void);

/* Creates column view.  Returns NULL on error. */
columns_t * columns_create(void);

/* Frees previously allocated columns.  Passing in NULL is OK. */
void columns_free(columns_t *cols);

/* Adds one column to the cols as the most right one. Duplicates are
 * allowed. */
void columns_add_column(columns_t *cols, column_info_t info);

/* Clears list of columns of the cols. */
void columns_clear(columns_t *cols);

/* Performs actual formatting of columns. */
void columns_format_line(columns_t *cols, void *format_data,
		int max_line_width);

/* Checks if recalculation is needed.  Returns non-zero if so, otherwise zero is
 * returned. */
int columns_matches_width(const columns_t *cols, int max_width);

#endif /* VIFM__UI__COLUMN_VIEW_H__ */

/* vim: set tabstop=2 softtabstop=2 shiftwidth=2 noexpandtab cinoptions-=(0 : */
/* vim: set cinoptions+=t0 filetype=c : */
Hints

Before first commit, do not forget to setup your git environment:
git config --global user.name "your_name_here"
git config --global user.email "your@email_here"

Clone this repository using HTTP(S):
git clone https://code.reversed.top/user/xaizek/vifm

Clone this repository using ssh (do not forget to upload a key first):
git clone ssh://rocketgit@code.reversed.top/user/xaizek/vifm

You are allowed to anonymously push to this repository.
This means that your pushed commits will automatically be transformed into a pull request:
... clone the repository ...
... make some changes and some commits ...
git push origin master