#include <stdint.h>
#include "output/table.h"
+struct pool;
struct string;
struct footnote
size_t idx;
char *content;
char *marker;
+ struct cell_style *style;
};
/* An item of contents within a table cell. */
struct cell_style
{
- struct cell_color fg, bg;
+ struct cell_color fg[2], bg[2];
+ int margin[TABLE_N_AXES][2];
+ char *font;
+ int font_size;
+ bool bold, italic, underline;
};
+#define CELL_STYLE_INITIALIZER \
+ { \
+ .fg = { [0] = CELL_COLOR_BLACK, [1] = CELL_COLOR_BLACK}, \
+ .bg = { [0] = CELL_COLOR_WHITE, [1] = CELL_COLOR_WHITE}, \
+ .margin = { [TABLE_HORZ][0] = 8, [TABLE_HORZ][1] = 11, \
+ [TABLE_VERT][0] = 1, [TABLE_VERT][1] = 1 }, \
+ .font = NULL, \
+ .font_size = 0, \
+ .bold = false, \
+ .italic = false, \
+ .underline = false, \
+ }
+
+struct cell_style *cell_style_clone (struct pool *, const struct cell_style *);
+void cell_style_free (struct cell_style *);
+
/* A cell in a table. */
struct table_cell
{
See table_get_rule() in table.c for a detailed explanation of the
meaning of AXIS and X and Y, including a diagram. */
int (*get_rule) (const struct table *table,
- enum table_axis axis, int x, int y);
+ enum table_axis axis, int x, int y,
+ struct cell_color *color);
/* This function is optional and most table classes will not implement it.
/* For use primarily by output drivers. */
void table_get_cell (const struct table *, int x, int y, struct table_cell *);
-int table_get_rule (const struct table *, enum table_axis, int x, int y);
+int table_get_rule (const struct table *, enum table_axis, int x, int y,
+ struct cell_color *);
size_t table_collect_footnotes (const struct table_item *,
const struct footnote ***);