X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Foutput%2Fhtml.c;h=9e7f567a27274866efda6d67fddef2ca74082d3c;hb=18e3610ace8a5286d301e2f8ebd62bb579b2ea96;hp=82478d189bdd8dd44f87e87023287532b2c6e515;hpb=bf3af6fb69dc94a6b3010e11e5d359e9e4abd5ba;p=pspp diff --git a/src/output/html.c b/src/output/html.c index 82478d189b..9e7f567a27 100644 --- a/src/output/html.c +++ b/src/output/html.c @@ -373,26 +373,87 @@ put_border (FILE *file, int n_borders, int style, const char *border_name) style == TAL_1 ? "thin solid" : "double"); } +static void +put_tfoot (struct html_driver *html, const struct table *t, bool *tfoot) +{ + if (!*tfoot) + { + fprintf (html->file, "", table_nc (t)); + *tfoot = true; + } + else + fputs ("\n
", html->file); +} + static void html_output_table (struct html_driver *html, const struct table_item *item) { const struct table *t = table_item_get_table (item); + const char *title = table_item_get_title (item); const char *caption = table_item_get_caption (item); - int x, y; + int footnote_idx = 0; + bool tfoot = false; + int y; - fputs ("\n", html->file); + fputs ("
", html->file); - if (caption != NULL) + if (caption) { - fputs (" \n", html->file); + + if (title != NULL) + { + fputs (" \n", html->file); } for (y = 0; y < table_nr (t); y++) { + int x; + fputs (" \n", html->file); - for (x = 0; x < table_nc (t); x++) + for (x = 0; x < table_nc (t); ) { const struct cell_contents *c; struct table_cell cell; @@ -467,6 +528,7 @@ html_output_table (struct html_driver *html, const struct table_item *item) if (c->text) { const char *s = c->text; + int i; if (c->options & TAB_EMPH) fputs ("", html->file); @@ -483,6 +545,22 @@ html_output_table (struct html_driver *html, const struct table_item *item) } if (c->options & TAB_EMPH) fputs ("", html->file); + + if (c->n_footnotes > 0) + { + fputs ("", html->file); + for (i = 0; i < c->n_footnotes; i++) + { + char marker[16]; + + if (i > 0) + putc (',', html->file); + str_format_26adic (++footnote_idx, false, + marker, sizeof marker); + fputs (marker, html->file); + } + fputs ("", html->file); + } } else html_output_table (html, c->table); @@ -491,6 +569,7 @@ html_output_table (struct html_driver *html, const struct table_item *item) /* Output or . */ fprintf (html->file, "\n", tag); + x = cell.d[TABLE_HORZ][1]; table_cell_free (&cell); } fputs (" \n", html->file);
", html->file); + put_tfoot (html, t, &tfoot); escape_string (html->file, caption, strlen (caption), " ", "
"); + } + footnote_idx = 0; + for (y = 0; y < table_nr (t); y++) + { + int x; + + for (x = 0; x < table_nc (t); ) + { + const struct cell_contents *c; + struct table_cell cell; + + table_get_cell (t, x, y, &cell); + if (y != cell.d[TABLE_VERT][0]) + continue; + + for (c = cell.contents; c < &cell.contents[cell.n_contents]; c++) + { + int i; + + for (i = 0; i < c->n_footnotes; i++) + { + char marker[16]; + + put_tfoot (html, t, &tfoot); + str_format_26adic (++footnote_idx, false, marker, sizeof marker); + fprintf (html->file, "%s ", marker); + escape_string (html->file, c->footnotes[i], + strlen (c->footnotes[i]), " ", "
"); + } + } + x = cell.d[TABLE_HORZ][1]; + table_cell_free (&cell); + } + } + if (tfoot) + fputs ("\n", html->file); + footnote_idx = 0; + + fputs ("
", html->file); + escape_string (html->file, title, strlen (title), " ", "
"); fputs ("