mirror of
https://github.com/rkd77/elinks.git
synced 2025-01-03 14:57:44 -05:00
[tables] Uncompilable code
This commit is contained in:
parent
9b93936564
commit
74b84d688f
@ -51,4 +51,86 @@
|
|||||||
void
|
void
|
||||||
tags_format_table(struct source_renderer *renderer, void *no)
|
tags_format_table(struct source_renderer *renderer, void *no)
|
||||||
{
|
{
|
||||||
|
struct html_context *html_context = renderer->html_context;
|
||||||
|
struct part *part = html_context->part;
|
||||||
|
struct table *table;
|
||||||
|
struct node *node, *new_node;
|
||||||
|
struct html_element *state;
|
||||||
|
int indent, margins;
|
||||||
|
|
||||||
|
html_context->table_level++;
|
||||||
|
|
||||||
|
table = tags_parse_table(no, (part->document || part->box.x), html_context);
|
||||||
|
if (!table) goto ret0;
|
||||||
|
|
||||||
|
table->part = part;
|
||||||
|
|
||||||
|
/* XXX: This tag soup handling needs to be done outside the create
|
||||||
|
* parser state. Something to do with link numbering. */
|
||||||
|
/* It needs to be done _before_ processing the actual table, too.
|
||||||
|
* Otherwise i.e. <form> tags between <table> and <tr> are broken. */
|
||||||
|
tags_draw_table_bad_html(html_context, table);
|
||||||
|
|
||||||
|
state = init_html_parser_state(html_context, ELEMENT_DONT_KILL,
|
||||||
|
ALIGN_LEFT, 0, 0);
|
||||||
|
|
||||||
|
margins = /*par_elformat.blockquote_level + */par_elformat.leftmargin + par_elformat.rightmargin;
|
||||||
|
if (get_table_cellpadding(html_context, table)) goto ret2;
|
||||||
|
|
||||||
|
distribute_table_widths(table);
|
||||||
|
|
||||||
|
if (!part->document && part->box.x == 1) {
|
||||||
|
int total_width = table->real_width + margins;
|
||||||
|
|
||||||
|
int_bounds(&total_width, table->real_width, par_elformat.width);
|
||||||
|
int_lower_bound(&part->box.width, total_width);
|
||||||
|
part->cy += table->real_height;
|
||||||
|
|
||||||
|
goto ret2;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef HTML_TABLE_2ND_PASS
|
||||||
|
check_table_widths(html_context, table);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
get_table_heights(html_context, table);
|
||||||
|
|
||||||
|
if (!part->document) {
|
||||||
|
int_lower_bound(&part->box.width, table->real_width + margins);
|
||||||
|
part->cy += table->real_height;
|
||||||
|
goto ret2;
|
||||||
|
}
|
||||||
|
|
||||||
|
node = part->document->nodes.next;
|
||||||
|
node->box.height = part->box.y - node->box.y + part->cy;
|
||||||
|
|
||||||
|
indent = get_table_indent(html_context, table);
|
||||||
|
|
||||||
|
/* FIXME: See bug 432. It should be possible to align the caption at
|
||||||
|
* the top, bottom or the sides. */
|
||||||
|
draw_table_caption(html_context, table, indent + part->box.x, part->box.y + part->cy);
|
||||||
|
draw_table_cells(table, indent, part->cy, html_context);
|
||||||
|
draw_table_frames(table, indent, part->cy, html_context);
|
||||||
|
|
||||||
|
part->cy += table->real_height;
|
||||||
|
part->cx = -1;
|
||||||
|
|
||||||
|
new_node = mem_alloc(sizeof(*new_node));
|
||||||
|
if (new_node) {
|
||||||
|
set_box(&new_node->box, node->box.x, part->box.y + part->cy,
|
||||||
|
node->box.width, 0);
|
||||||
|
add_to_list(part->document->nodes, new_node);
|
||||||
|
}
|
||||||
|
|
||||||
|
ret2:
|
||||||
|
part->link_num = table->link_num;
|
||||||
|
int_lower_bound(&part->box.height, part->cy);
|
||||||
|
html_context->part = part; /* Might've changed in draw_table_cells(). */
|
||||||
|
done_html_parser_state(html_context, state);
|
||||||
|
|
||||||
|
free_table(table);
|
||||||
|
|
||||||
|
ret0:
|
||||||
|
html_context->table_level--;
|
||||||
|
if (!html_context->table_level) free_table_cache();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user