mirror of
https://github.com/rkd77/elinks.git
synced 2024-12-04 14:46:47 -05:00
[xhtml] code is compilable, but likely non-functional
This commit is contained in:
parent
e3852637ff
commit
ba3af06b40
@ -83,6 +83,10 @@ struct html_context {
|
||||
unsigned int has_link_lines:1;
|
||||
unsigned int was_body:1; /* For META refresh inside <body>. */
|
||||
unsigned int was_body_background:1; /* For <HTML> with style. */
|
||||
unsigned int skip_html:1;
|
||||
unsigned int skip_select:1;
|
||||
unsigned int support_css:1;
|
||||
unsigned int skip_textarea:1;
|
||||
|
||||
/* For html/parser.c, html/renderer.c */
|
||||
int margin;
|
||||
@ -90,6 +94,8 @@ struct html_context {
|
||||
/* For parser/forms.c: */
|
||||
char *startf;
|
||||
|
||||
int ff;
|
||||
|
||||
/* For:
|
||||
* html/parser/parse.c
|
||||
* html/parser.c
|
||||
@ -131,13 +137,13 @@ struct html_context {
|
||||
|
||||
#define html_top ((struct html_element *) html_context->stack.next)
|
||||
#define html_bottom ((struct html_element *) html_context->stack.prev)
|
||||
#define format (html_top->attr)
|
||||
#define par_format (html_top->parattr)
|
||||
#define elformat (html_top->attr)
|
||||
#define par_elformat (html_top->parattr)
|
||||
|
||||
#define html_is_preformatted() (format.style.attr & AT_PREFORMATTED)
|
||||
#define html_is_preformatted() (elformat.style.attr & AT_PREFORMATTED)
|
||||
|
||||
#define get_html_max_width() \
|
||||
int_max(par_format.width - (par_format.leftmargin + par_format.rightmargin), 0)
|
||||
int_max(par_elformat.width - (par_elformat.leftmargin + par_elformat.rightmargin), 0)
|
||||
|
||||
/* For parser/link.c: */
|
||||
|
||||
|
@ -77,6 +77,19 @@ get_color(struct html_context *html_context, char *a,
|
||||
return extract_color(html_context, a, attribute, rgb);
|
||||
}
|
||||
|
||||
int
|
||||
get_color2(struct html_context *html_context, unsigned char *value_value, color_T *rgb)
|
||||
{
|
||||
if (!use_document_fg_colors(html_context->options))
|
||||
return -1;
|
||||
|
||||
if (!value_value)
|
||||
return -1;
|
||||
|
||||
return decode_color(value_value, strlen(value_value), rgb);
|
||||
}
|
||||
|
||||
|
||||
int
|
||||
get_bgcolor(struct html_context *html_context, char *a, color_T *rgb)
|
||||
{
|
||||
@ -244,8 +257,8 @@ html_focusable(struct html_context *html_context, char *a)
|
||||
int cp;
|
||||
int tabindex;
|
||||
|
||||
format.accesskey = 0;
|
||||
format.tabindex = 0x80000000;
|
||||
elformat.accesskey = 0;
|
||||
elformat.tabindex = 0x80000000;
|
||||
|
||||
if (!a) return;
|
||||
|
||||
@ -253,22 +266,22 @@ html_focusable(struct html_context *html_context, char *a)
|
||||
|
||||
accesskey = get_attr_val(a, "accesskey", cp);
|
||||
if (accesskey) {
|
||||
format.accesskey = accesskey_string_to_unicode(accesskey);
|
||||
elformat.accesskey = accesskey_string_to_unicode(accesskey);
|
||||
mem_free(accesskey);
|
||||
}
|
||||
|
||||
tabindex = get_num(a, "tabindex", cp);
|
||||
if (0 < tabindex && tabindex < 32767) {
|
||||
format.tabindex = (tabindex & 0x7fff) << 16;
|
||||
elformat.tabindex = (tabindex & 0x7fff) << 16;
|
||||
}
|
||||
|
||||
mem_free_set(&format.onclick, get_attr_val(a, "onclick", cp));
|
||||
mem_free_set(&format.ondblclick, get_attr_val(a, "ondblclick", cp));
|
||||
mem_free_set(&format.onmouseover, get_attr_val(a, "onmouseover", cp));
|
||||
mem_free_set(&format.onhover, get_attr_val(a, "onhover", cp));
|
||||
mem_free_set(&format.onfocus, get_attr_val(a, "onfocus", cp));
|
||||
mem_free_set(&format.onmouseout, get_attr_val(a, "onmouseout", cp));
|
||||
mem_free_set(&format.onblur, get_attr_val(a, "onblur", cp));
|
||||
mem_free_set(&elformat.onclick, get_attr_val(a, "onclick", cp));
|
||||
mem_free_set(&elformat.ondblclick, get_attr_val(a, "ondblclick", cp));
|
||||
mem_free_set(&elformat.onmouseover, get_attr_val(a, "onmouseover", cp));
|
||||
mem_free_set(&elformat.onhover, get_attr_val(a, "onhover", cp));
|
||||
mem_free_set(&elformat.onfocus, get_attr_val(a, "onfocus", cp));
|
||||
mem_free_set(&elformat.onmouseout, get_attr_val(a, "onmouseout", cp));
|
||||
mem_free_set(&elformat.onblur, get_attr_val(a, "onblur", cp));
|
||||
}
|
||||
|
||||
void
|
||||
@ -692,15 +705,15 @@ init_html_parser_state(struct html_context *html_context,
|
||||
{
|
||||
html_stack_dup(html_context, type);
|
||||
|
||||
par_format.align = align;
|
||||
par_elformat.align = align;
|
||||
|
||||
if (type <= ELEMENT_IMMORTAL) {
|
||||
par_format.leftmargin = margin;
|
||||
par_format.rightmargin = margin;
|
||||
par_format.width = width;
|
||||
par_format.list_level = 0;
|
||||
par_format.list_number = 0;
|
||||
par_format.dd_margin = 0;
|
||||
par_elformat.leftmargin = margin;
|
||||
par_elformat.rightmargin = margin;
|
||||
par_elformat.width = width;
|
||||
par_elformat.list_level = 0;
|
||||
par_elformat.list_number = 0;
|
||||
par_elformat.dd_margin = 0;
|
||||
html_top->namelen = 0;
|
||||
}
|
||||
|
||||
@ -783,34 +796,34 @@ init_html_parser(struct uri *uri, struct document_options *options,
|
||||
if (!e) return NULL;
|
||||
add_to_list(html_context->stack, e);
|
||||
|
||||
format.style.attr = 0;
|
||||
format.fontsize = 3;
|
||||
format.link = format.target = format.image = NULL;
|
||||
format.onclick = format.ondblclick = format.onmouseover = format.onhover
|
||||
= format.onfocus = format.onmouseout = format.onblur = NULL;
|
||||
format.select = NULL;
|
||||
format.form = NULL;
|
||||
format.title = NULL;
|
||||
elformat.style.attr = 0;
|
||||
elformat.fontsize = 3;
|
||||
elformat.link = elformat.target = elformat.image = NULL;
|
||||
elformat.onclick = elformat.ondblclick = elformat.onmouseover = elformat.onhover
|
||||
= elformat.onfocus = elformat.onmouseout = elformat.onblur = NULL;
|
||||
elformat.select = NULL;
|
||||
elformat.form = NULL;
|
||||
elformat.title = NULL;
|
||||
|
||||
format.style = options->default_style;
|
||||
format.color.clink = options->default_color.link;
|
||||
format.color.vlink = options->default_color.vlink;
|
||||
elformat.style = options->default_style;
|
||||
elformat.color.clink = options->default_color.link;
|
||||
elformat.color.vlink = options->default_color.vlink;
|
||||
#ifdef CONFIG_BOOKMARKS
|
||||
format.color.bookmark_link = options->default_color.bookmark_link;
|
||||
elformat.color.bookmark_link = options->default_color.bookmark_link;
|
||||
#endif
|
||||
format.color.image_link = options->default_color.image_link;
|
||||
format.color.link_number = options->default_color.link_number;
|
||||
elformat.color.image_link = options->default_color.image_link;
|
||||
elformat.color.link_number = options->default_color.link_number;
|
||||
|
||||
par_format.align = ALIGN_LEFT;
|
||||
par_format.leftmargin = options->margin;
|
||||
par_format.rightmargin = options->margin;
|
||||
par_elformat.align = ALIGN_LEFT;
|
||||
par_elformat.leftmargin = options->margin;
|
||||
par_elformat.rightmargin = options->margin;
|
||||
|
||||
par_format.width = options->document_width;
|
||||
par_format.list_level = par_format.list_number = 0;
|
||||
par_format.dd_margin = options->margin;
|
||||
par_format.flags = P_DISC;
|
||||
par_elformat.width = options->document_width;
|
||||
par_elformat.list_level = par_elformat.list_number = 0;
|
||||
par_elformat.dd_margin = options->margin;
|
||||
par_elformat.flags = P_DISC;
|
||||
|
||||
par_format.color.background = options->default_style.color.background;
|
||||
par_elformat.color.background = options->default_style.color.background;
|
||||
|
||||
html_top->invisible = 0;
|
||||
html_top->name = NULL;
|
||||
|
@ -211,6 +211,8 @@ void ln_break(struct html_context *html_context, int n);
|
||||
|
||||
int get_color(struct html_context *html_context, char *a, char *c, color_T *rgb);
|
||||
|
||||
int get_color2(struct html_context *html_context, unsigned char *value_value, color_T *rgb);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
@ -183,8 +183,8 @@ no_type_attr:
|
||||
fc->default_value = stracpy("");
|
||||
|
||||
html_context->special_f(html_context, SP_CONTROL, fc);
|
||||
format.form = fc;
|
||||
format.style.attr |= AT_BOLD;
|
||||
elformat.form = fc;
|
||||
elformat.style.attr |= AT_BOLD;
|
||||
}
|
||||
|
||||
static void
|
||||
@ -194,9 +194,9 @@ html_input_format(struct html_context *html_context, char *a,
|
||||
put_chrs(html_context, " ", 1);
|
||||
html_stack_dup(html_context, ELEMENT_KILLABLE);
|
||||
html_focusable(html_context, a);
|
||||
format.form = fc;
|
||||
mem_free_if(format.title);
|
||||
format.title = get_attr_val(a, "title", html_context->doc_cp);
|
||||
elformat.form = fc;
|
||||
mem_free_if(elformat.title);
|
||||
elformat.title = get_attr_val(a, "title", html_context->doc_cp);
|
||||
switch (fc->type) {
|
||||
case FC_TEXT:
|
||||
case FC_PASSWORD:
|
||||
@ -204,42 +204,42 @@ html_input_format(struct html_context *html_context, char *a,
|
||||
{
|
||||
int i;
|
||||
|
||||
format.style.attr |= AT_BOLD;
|
||||
elformat.style.attr |= AT_BOLD;
|
||||
for (i = 0; i < fc->size; i++)
|
||||
put_chrs(html_context, "_", 1);
|
||||
break;
|
||||
}
|
||||
case FC_CHECKBOX:
|
||||
format.style.attr |= AT_BOLD;
|
||||
elformat.style.attr |= AT_BOLD;
|
||||
put_chrs(html_context, "[ ]", 8);
|
||||
break;
|
||||
case FC_RADIO:
|
||||
format.style.attr |= AT_BOLD;
|
||||
elformat.style.attr |= AT_BOLD;
|
||||
put_chrs(html_context, "( )", 8);
|
||||
break;
|
||||
case FC_IMAGE:
|
||||
{
|
||||
char *al;
|
||||
|
||||
mem_free_set(&format.image, NULL);
|
||||
mem_free_set(&elformat.image, NULL);
|
||||
al = get_url_val(a, "src", html_context->doc_cp);
|
||||
if (!al)
|
||||
al = get_url_val(a, "dynsrc",
|
||||
html_context->doc_cp);
|
||||
if (al) {
|
||||
format.image = join_urls(html_context->base_href, al);
|
||||
elformat.image = join_urls(html_context->base_href, al);
|
||||
mem_free(al);
|
||||
}
|
||||
format.style.attr |= AT_BOLD;
|
||||
elformat.style.attr |= AT_BOLD;
|
||||
put_chrs(html_context, "[ ", 7);
|
||||
format.style.attr |= AT_NO_ENTITIES;
|
||||
elformat.style.attr |= AT_NO_ENTITIES;
|
||||
if (fc->alt)
|
||||
put_chrs(html_context, fc->alt, strlen(fc->alt));
|
||||
else if (fc->name)
|
||||
put_chrs(html_context, fc->name, strlen(fc->name));
|
||||
else
|
||||
put_chrs(html_context, "Submit", 6);
|
||||
format.style.attr &= ~AT_NO_ENTITIES;
|
||||
elformat.style.attr &= ~AT_NO_ENTITIES;
|
||||
|
||||
put_chrs(html_context, " ]", 7);
|
||||
break;
|
||||
@ -247,12 +247,12 @@ html_input_format(struct html_context *html_context, char *a,
|
||||
case FC_SUBMIT:
|
||||
case FC_RESET:
|
||||
case FC_BUTTON:
|
||||
format.style.attr |= AT_BOLD;
|
||||
elformat.style.attr |= AT_BOLD;
|
||||
put_chrs(html_context, "[ ", 7);
|
||||
if (fc->default_value) {
|
||||
format.style.attr |= AT_NO_ENTITIES;
|
||||
elformat.style.attr |= AT_NO_ENTITIES;
|
||||
put_chrs(html_context, fc->default_value, strlen(fc->default_value));
|
||||
format.style.attr &= ~AT_NO_ENTITIES;
|
||||
elformat.style.attr &= ~AT_NO_ENTITIES;
|
||||
}
|
||||
put_chrs(html_context, " ]", 7);
|
||||
break;
|
||||
@ -495,8 +495,8 @@ end_parse:
|
||||
|
||||
menu_labels(fc->menu, "", labels);
|
||||
html_stack_dup(html_context, ELEMENT_KILLABLE);
|
||||
format.form = fc;
|
||||
format.style.attr |= AT_BOLD;
|
||||
elformat.form = fc;
|
||||
elformat.style.attr |= AT_BOLD;
|
||||
put_chrs(html_context, "[ ", 7);
|
||||
|
||||
max_width = 0;
|
||||
@ -530,8 +530,8 @@ do_html_select_multiple(struct html_context *html_context, char *a,
|
||||
if (!al) return;
|
||||
html_focusable(html_context, a);
|
||||
html_top->type = ELEMENT_DONT_KILL;
|
||||
mem_free_set(&format.select, al);
|
||||
format.select_disabled = has_attr(a, "disabled", html_context->doc_cp)
|
||||
mem_free_set(&elformat.select, al);
|
||||
elformat.select_disabled = has_attr(a, "disabled", html_context->doc_cp)
|
||||
? FORM_MODE_DISABLED
|
||||
: FORM_MODE_NORMAL;
|
||||
}
|
||||
@ -554,7 +554,7 @@ html_option(struct html_context *html_context, char *a,
|
||||
struct el_form_control *fc;
|
||||
char *val;
|
||||
|
||||
if (!format.select) return;
|
||||
if (!elformat.select) return;
|
||||
|
||||
val = get_attr_val(a, "value", html_context->doc_cp);
|
||||
if (!val) {
|
||||
@ -608,17 +608,17 @@ end_parse:
|
||||
}
|
||||
|
||||
fc->id = get_attr_val(a, "id", html_context->doc_cp);
|
||||
fc->name = null_or_stracpy(format.select);
|
||||
fc->name = null_or_stracpy(elformat.select);
|
||||
fc->default_value = val;
|
||||
fc->default_state = has_attr(a, "selected", html_context->doc_cp);
|
||||
fc->mode = has_attr(a, "disabled", html_context->doc_cp)
|
||||
? FORM_MODE_DISABLED
|
||||
: format.select_disabled;
|
||||
: elformat.select_disabled;
|
||||
|
||||
put_chrs(html_context, " ", 1);
|
||||
html_stack_dup(html_context, ELEMENT_KILLABLE);
|
||||
format.form = fc;
|
||||
format.style.attr |= AT_BOLD;
|
||||
elformat.form = fc;
|
||||
elformat.style.attr |= AT_BOLD;
|
||||
put_chrs(html_context, "[ ]", 3);
|
||||
pop_html_element(html_context);
|
||||
put_chrs(html_context, " ", 1);
|
||||
@ -717,8 +717,8 @@ pp:
|
||||
else put_chrs(html_context, " ", 1);
|
||||
|
||||
html_stack_dup(html_context, ELEMENT_KILLABLE);
|
||||
format.form = fc;
|
||||
format.style.attr |= AT_BOLD;
|
||||
elformat.form = fc;
|
||||
elformat.style.attr |= AT_BOLD;
|
||||
|
||||
for (i = 0; i < rows; i++) {
|
||||
int j;
|
||||
|
@ -52,28 +52,28 @@ void
|
||||
html_bold(struct html_context *html_context, char *a,
|
||||
char *xxx3, char *xxx4, char **xxx5)
|
||||
{
|
||||
format.style.attr |= AT_BOLD;
|
||||
elformat.style.attr |= AT_BOLD;
|
||||
}
|
||||
|
||||
void
|
||||
html_italic(struct html_context *html_context, char *a,
|
||||
char *xxx3, char *xxx4, char **xxx5)
|
||||
{
|
||||
format.style.attr |= AT_ITALIC;
|
||||
elformat.style.attr |= AT_ITALIC;
|
||||
}
|
||||
|
||||
void
|
||||
html_underline(struct html_context *html_context, char *a,
|
||||
char *xxx3, char *xxx4, char **xxx5)
|
||||
{
|
||||
format.style.attr |= AT_UNDERLINE;
|
||||
elformat.style.attr |= AT_UNDERLINE;
|
||||
}
|
||||
|
||||
void
|
||||
html_fixed(struct html_context *html_context, char *a,
|
||||
char *xxx3, char *xxx4, char **xxx5)
|
||||
{
|
||||
format.style.attr |= AT_FIXED;
|
||||
elformat.style.attr |= AT_FIXED;
|
||||
}
|
||||
|
||||
void
|
||||
@ -152,25 +152,25 @@ html_font(struct html_context *html_context, char *a,
|
||||
s = strtoul(nn, (char **) &end, 10);
|
||||
if (!errno && *nn && !*end) {
|
||||
if (s > 7) s = 7;
|
||||
if (!p) format.fontsize = s;
|
||||
else format.fontsize += p * s;
|
||||
if (format.fontsize < 1) format.fontsize = 1;
|
||||
else if (format.fontsize > 7) format.fontsize = 7;
|
||||
if (!p) elformat.fontsize = s;
|
||||
else elformat.fontsize += p * s;
|
||||
if (elformat.fontsize < 1) elformat.fontsize = 1;
|
||||
else if (elformat.fontsize > 7) elformat.fontsize = 7;
|
||||
}
|
||||
mem_free(al);
|
||||
}
|
||||
get_color(html_context, a, "color", &format.style.color.foreground);
|
||||
get_color(html_context, a, "color", &elformat.style.color.foreground);
|
||||
}
|
||||
|
||||
void
|
||||
html_body(struct html_context *html_context, char *a,
|
||||
char *xxx3, char *xxx4, char **xxx5)
|
||||
{
|
||||
get_color(html_context, a, "text", &format.style.color.foreground);
|
||||
get_color(html_context, a, "link", &format.color.clink);
|
||||
get_color(html_context, a, "vlink", &format.color.vlink);
|
||||
get_color(html_context, a, "text", &elformat.style.color.foreground);
|
||||
get_color(html_context, a, "link", &elformat.color.clink);
|
||||
get_color(html_context, a, "vlink", &elformat.color.vlink);
|
||||
|
||||
if (get_bgcolor(html_context, a, &format.style.color.background) != -1)
|
||||
if (get_bgcolor(html_context, a, &elformat.style.color.background) != -1)
|
||||
html_context->was_body_background = 1;
|
||||
|
||||
html_context->was_body = 1; /* this will be used by "meta inside body" */
|
||||
@ -188,17 +188,17 @@ html_apply_canvas_bgcolor(struct html_context *html_context)
|
||||
&html_context->stack);
|
||||
#endif
|
||||
|
||||
if (par_format.color.background != format.style.color.background) {
|
||||
if (par_elformat.color.background != elformat.style.color.background) {
|
||||
/* Modify the root HTML element - format_html_part() will take
|
||||
* this from there. */
|
||||
struct html_element *e = html_bottom;
|
||||
|
||||
html_context->was_body_background = 1;
|
||||
e->parattr.color.background = e->attr.style.color.background = par_format.color.background = format.style.color.background;
|
||||
e->parattr.color.background = e->attr.style.color.background = par_elformat.color.background = elformat.style.color.background;
|
||||
}
|
||||
|
||||
if (html_context->has_link_lines
|
||||
&& par_format.color.background != html_context->options->default_style.color.background
|
||||
&& par_elformat.color.background != html_context->options->default_style.color.background
|
||||
&& !search_html_stack(html_context, "BODY")) {
|
||||
html_context->special_f(html_context, SP_COLOR_LINK_LINES);
|
||||
}
|
||||
@ -417,8 +417,8 @@ html_html(struct html_context *html_context, char *a,
|
||||
* this from there. */
|
||||
struct html_element *e = html_bottom;
|
||||
|
||||
if (par_format.color.background != format.style.color.background)
|
||||
e->parattr.color.background = e->attr.style.color.background = par_format.color.background = format.style.color.background;
|
||||
if (par_elformat.color.background != elformat.style.color.background)
|
||||
e->parattr.color.background = e->attr.style.color.background = par_elformat.color.background = elformat.style.color.background;
|
||||
}
|
||||
|
||||
void
|
||||
@ -473,9 +473,9 @@ void
|
||||
html_center(struct html_context *html_context, char *a,
|
||||
char *xxx3, char *xxx4, char **xxx5)
|
||||
{
|
||||
par_format.align = ALIGN_CENTER;
|
||||
par_elformat.align = ALIGN_CENTER;
|
||||
if (!html_context->table_level)
|
||||
par_format.leftmargin = par_format.rightmargin = 0;
|
||||
par_elformat.leftmargin = par_elformat.rightmargin = 0;
|
||||
}
|
||||
|
||||
void
|
||||
@ -485,13 +485,13 @@ html_linebrk(struct html_context *html_context, char *a,
|
||||
char *al = get_attr_val(a, "align", html_context->doc_cp);
|
||||
|
||||
if (al) {
|
||||
if (!c_strcasecmp(al, "left")) par_format.align = ALIGN_LEFT;
|
||||
else if (!c_strcasecmp(al, "right")) par_format.align = ALIGN_RIGHT;
|
||||
if (!c_strcasecmp(al, "left")) par_elformat.align = ALIGN_LEFT;
|
||||
else if (!c_strcasecmp(al, "right")) par_elformat.align = ALIGN_RIGHT;
|
||||
else if (!c_strcasecmp(al, "center")) {
|
||||
par_format.align = ALIGN_CENTER;
|
||||
par_elformat.align = ALIGN_CENTER;
|
||||
if (!html_context->table_level)
|
||||
par_format.leftmargin = par_format.rightmargin = 0;
|
||||
} else if (!c_strcasecmp(al, "justify")) par_format.align = ALIGN_JUSTIFY;
|
||||
par_elformat.leftmargin = par_elformat.rightmargin = 0;
|
||||
} else if (!c_strcasecmp(al, "justify")) par_elformat.align = ALIGN_JUSTIFY;
|
||||
mem_free(al);
|
||||
}
|
||||
}
|
||||
@ -511,9 +511,9 @@ void
|
||||
html_p(struct html_context *html_context, char *a,
|
||||
char *html, char *eof, char **end)
|
||||
{
|
||||
int_lower_bound(&par_format.leftmargin, html_context->margin);
|
||||
int_lower_bound(&par_format.rightmargin, html_context->margin);
|
||||
/*par_format.align = ALIGN_LEFT;*/
|
||||
int_lower_bound(&par_elformat.leftmargin, html_context->margin);
|
||||
int_lower_bound(&par_elformat.rightmargin, html_context->margin);
|
||||
/*par_elformat.align = ALIGN_LEFT;*/
|
||||
html_linebrk(html_context, a, html, eof, end);
|
||||
}
|
||||
|
||||
@ -521,28 +521,28 @@ void
|
||||
html_address(struct html_context *html_context, char *a,
|
||||
char *xxx3, char *xxx4, char **xxx5)
|
||||
{
|
||||
par_format.leftmargin++;
|
||||
par_format.align = ALIGN_LEFT;
|
||||
par_elformat.leftmargin++;
|
||||
par_elformat.align = ALIGN_LEFT;
|
||||
}
|
||||
|
||||
void
|
||||
html_blockquote(struct html_context *html_context, char *a,
|
||||
char *xxx3, char *xxx4, char **xxx5)
|
||||
{
|
||||
par_format.align = ALIGN_LEFT;
|
||||
if (par_format.blockquote_level == 0) {
|
||||
par_format.orig_leftmargin = par_format.leftmargin;
|
||||
par_format.blockquote_level++;
|
||||
par_elformat.align = ALIGN_LEFT;
|
||||
if (par_elformat.blockquote_level == 0) {
|
||||
par_elformat.orig_leftmargin = par_elformat.leftmargin;
|
||||
par_elformat.blockquote_level++;
|
||||
}
|
||||
par_format.blockquote_level++;
|
||||
par_elformat.blockquote_level++;
|
||||
}
|
||||
|
||||
void
|
||||
html_blockquote_close(struct html_context *html_context, char *a,
|
||||
char *xxx3, char *xxx4, char **xxx5)
|
||||
{
|
||||
if (par_format.blockquote_level == 2) par_format.blockquote_level--;
|
||||
if (par_format.blockquote_level > 0) par_format.blockquote_level--;
|
||||
if (par_elformat.blockquote_level == 2) par_elformat.blockquote_level--;
|
||||
if (par_elformat.blockquote_level > 0) par_elformat.blockquote_level--;
|
||||
}
|
||||
|
||||
void
|
||||
@ -550,26 +550,26 @@ html_h(int h, char *a,
|
||||
enum format_align default_align, struct html_context *html_context,
|
||||
char *html, char *eof, char **end)
|
||||
{
|
||||
if (!par_format.align) par_format.align = default_align;
|
||||
if (!par_elformat.align) par_elformat.align = default_align;
|
||||
html_linebrk(html_context, a, html, eof, end);
|
||||
|
||||
h -= 2;
|
||||
if (h < 0) h = 0;
|
||||
|
||||
switch (par_format.align) {
|
||||
switch (par_elformat.align) {
|
||||
case ALIGN_LEFT:
|
||||
par_format.leftmargin = h * 2;
|
||||
par_format.rightmargin = 0;
|
||||
par_elformat.leftmargin = h * 2;
|
||||
par_elformat.rightmargin = 0;
|
||||
break;
|
||||
case ALIGN_RIGHT:
|
||||
par_format.leftmargin = 0;
|
||||
par_format.rightmargin = h * 2;
|
||||
par_elformat.leftmargin = 0;
|
||||
par_elformat.rightmargin = h * 2;
|
||||
break;
|
||||
case ALIGN_CENTER:
|
||||
par_format.leftmargin = par_format.rightmargin = 0;
|
||||
par_elformat.leftmargin = par_elformat.rightmargin = 0;
|
||||
break;
|
||||
case ALIGN_JUSTIFY:
|
||||
par_format.leftmargin = par_format.rightmargin = h * 2;
|
||||
par_elformat.leftmargin = par_elformat.rightmargin = h * 2;
|
||||
break;
|
||||
}
|
||||
}
|
||||
@ -578,7 +578,7 @@ void
|
||||
html_h1(struct html_context *html_context, char *a,
|
||||
char *html, char *eof, char **end)
|
||||
{
|
||||
format.style.attr |= AT_BOLD;
|
||||
elformat.style.attr |= AT_BOLD;
|
||||
html_h(1, a, ALIGN_CENTER, html_context, html, eof, end);
|
||||
}
|
||||
|
||||
@ -621,9 +621,9 @@ void
|
||||
html_pre(struct html_context *html_context, char *a,
|
||||
char *xxx3, char *xxx4, char **xxx5)
|
||||
{
|
||||
format.style.attr |= AT_PREFORMATTED;
|
||||
par_format.leftmargin = (par_format.leftmargin > 1);
|
||||
par_format.rightmargin = 0;
|
||||
elformat.style.attr |= AT_PREFORMATTED;
|
||||
par_elformat.leftmargin = (par_elformat.leftmargin > 1);
|
||||
par_elformat.rightmargin = 0;
|
||||
}
|
||||
|
||||
void
|
||||
@ -645,22 +645,22 @@ void
|
||||
html_hr(struct html_context *html_context, char *a,
|
||||
char *html, char *eof, char **end)
|
||||
{
|
||||
int i/* = par_format.width - 10*/;
|
||||
int i/* = par_elformat.width - 10*/;
|
||||
char r = BORDER_DHLINE;
|
||||
int q = get_num(a, "size", html_context->doc_cp);
|
||||
|
||||
if (q >= 0 && q < 2) r = BORDER_SHLINE;
|
||||
html_stack_dup(html_context, ELEMENT_KILLABLE);
|
||||
par_format.align = ALIGN_CENTER;
|
||||
mem_free_set(&format.link, NULL);
|
||||
format.form = NULL;
|
||||
par_elformat.align = ALIGN_CENTER;
|
||||
mem_free_set(&elformat.link, NULL);
|
||||
elformat.form = NULL;
|
||||
html_linebrk(html_context, a, html, eof, end);
|
||||
if (par_format.align == ALIGN_JUSTIFY) par_format.align = ALIGN_CENTER;
|
||||
par_format.leftmargin = par_format.rightmargin = html_context->margin;
|
||||
if (par_elformat.align == ALIGN_JUSTIFY) par_elformat.align = ALIGN_CENTER;
|
||||
par_elformat.leftmargin = par_elformat.rightmargin = html_context->margin;
|
||||
|
||||
i = get_width(a, "width", 1, html_context);
|
||||
if (i == -1) i = get_html_max_width();
|
||||
format.style.attr = AT_GRAPHICS;
|
||||
elformat.style.attr = AT_GRAPHICS;
|
||||
html_context->special_f(html_context, SP_NOWRAP, 1);
|
||||
while (i-- > 0) {
|
||||
put_chrs(html_context, &r, 1);
|
||||
@ -682,10 +682,10 @@ html_table(struct html_context *html_context, char *attr,
|
||||
return;
|
||||
}
|
||||
|
||||
par_format.leftmargin = par_format.rightmargin = html_context->margin;
|
||||
par_format.align = ALIGN_LEFT;
|
||||
par_elformat.leftmargin = par_elformat.rightmargin = html_context->margin;
|
||||
par_elformat.align = ALIGN_LEFT;
|
||||
html_linebrk(html_context, attr, html, eof, end);
|
||||
format.style.attr = 0;
|
||||
elformat.style.attr = 0;
|
||||
}
|
||||
|
||||
void
|
||||
@ -708,7 +708,7 @@ html_th(struct html_context *html_context, char *a,
|
||||
/*html_linebrk(html_context, a, html, eof, end);*/
|
||||
kill_html_stack_until(html_context, 1,
|
||||
"TD", "TH", "", "TR", "TABLE", NULL);
|
||||
format.style.attr |= AT_BOLD;
|
||||
elformat.style.attr |= AT_BOLD;
|
||||
put_chrs(html_context, " ", 1);
|
||||
}
|
||||
|
||||
@ -719,7 +719,7 @@ html_td(struct html_context *html_context, char *a,
|
||||
/*html_linebrk(html_context, a, html, eof, end);*/
|
||||
kill_html_stack_until(html_context, 1,
|
||||
"TD", "TH", "", "TR", "TABLE", NULL);
|
||||
format.style.attr &= ~AT_BOLD;
|
||||
elformat.style.attr &= ~AT_BOLD;
|
||||
put_chrs(html_context, " ", 1);
|
||||
}
|
||||
|
||||
@ -754,25 +754,25 @@ html_ul(struct html_context *html_context, char *a,
|
||||
char *al;
|
||||
|
||||
/* dump_html_stack(html_context); */
|
||||
par_format.list_level++;
|
||||
par_format.list_number = 0;
|
||||
par_format.flags = P_DISC;
|
||||
par_elformat.list_level++;
|
||||
par_elformat.list_number = 0;
|
||||
par_elformat.flags = P_DISC;
|
||||
|
||||
al = get_attr_val(a, "type", html_context->doc_cp);
|
||||
if (al) {
|
||||
if (!c_strcasecmp(al, "disc"))
|
||||
par_format.flags = P_DISC;
|
||||
par_elformat.flags = P_DISC;
|
||||
else if (!c_strcasecmp(al, "circle"))
|
||||
par_format.flags = P_O;
|
||||
par_elformat.flags = P_O;
|
||||
else if (!c_strcasecmp(al, "square"))
|
||||
par_format.flags = P_SQUARE;
|
||||
par_elformat.flags = P_SQUARE;
|
||||
mem_free(al);
|
||||
}
|
||||
par_format.leftmargin += 2 + (par_format.list_level > 1);
|
||||
par_elformat.leftmargin += 2 + (par_elformat.list_level > 1);
|
||||
if (!html_context->table_level)
|
||||
int_upper_bound(&par_format.leftmargin, par_format.width / 2);
|
||||
int_upper_bound(&par_elformat.leftmargin, par_elformat.width / 2);
|
||||
|
||||
par_format.align = ALIGN_LEFT;
|
||||
par_elformat.align = ALIGN_LEFT;
|
||||
html_top->type = ELEMENT_DONT_KILL;
|
||||
}
|
||||
|
||||
@ -783,31 +783,31 @@ html_ol(struct html_context *html_context, char *a,
|
||||
char *al;
|
||||
int st;
|
||||
|
||||
par_format.list_level++;
|
||||
par_elformat.list_level++;
|
||||
st = get_num(a, "start", html_context->doc_cp);
|
||||
if (st == -1) st = 1;
|
||||
par_format.list_number = st;
|
||||
par_format.flags = P_NUMBER;
|
||||
par_elformat.list_number = st;
|
||||
par_elformat.flags = P_NUMBER;
|
||||
|
||||
al = get_attr_val(a, "type", html_context->doc_cp);
|
||||
if (al) {
|
||||
if (*al && !al[1]) {
|
||||
if (*al == '1') par_format.flags = P_NUMBER;
|
||||
else if (*al == 'a') par_format.flags = P_alpha;
|
||||
else if (*al == 'A') par_format.flags = P_ALPHA;
|
||||
else if (*al == 'r') par_format.flags = P_roman;
|
||||
else if (*al == 'R') par_format.flags = P_ROMAN;
|
||||
else if (*al == 'i') par_format.flags = P_roman;
|
||||
else if (*al == 'I') par_format.flags = P_ROMAN;
|
||||
if (*al == '1') par_elformat.flags = P_NUMBER;
|
||||
else if (*al == 'a') par_elformat.flags = P_alpha;
|
||||
else if (*al == 'A') par_elformat.flags = P_ALPHA;
|
||||
else if (*al == 'r') par_elformat.flags = P_roman;
|
||||
else if (*al == 'R') par_elformat.flags = P_ROMAN;
|
||||
else if (*al == 'i') par_elformat.flags = P_roman;
|
||||
else if (*al == 'I') par_elformat.flags = P_ROMAN;
|
||||
}
|
||||
mem_free(al);
|
||||
}
|
||||
|
||||
par_format.leftmargin += (par_format.list_level > 1);
|
||||
par_elformat.leftmargin += (par_elformat.list_level > 1);
|
||||
if (!html_context->table_level)
|
||||
int_upper_bound(&par_format.leftmargin, par_format.width / 2);
|
||||
int_upper_bound(&par_elformat.leftmargin, par_elformat.width / 2);
|
||||
|
||||
par_format.align = ALIGN_LEFT;
|
||||
par_elformat.align = ALIGN_LEFT;
|
||||
html_top->type = ELEMENT_DONT_KILL;
|
||||
}
|
||||
|
||||
@ -866,7 +866,7 @@ void
|
||||
html_li(struct html_context *html_context, char *a,
|
||||
char *xxx3, char *xxx4, char **xxx5)
|
||||
{
|
||||
int t = par_format.flags & P_LISTMASK;
|
||||
int t = par_elformat.flags & P_LISTMASK;
|
||||
|
||||
/* When handling the code <li><li> @was_li will be 1 and it means we
|
||||
* have to insert a line break since no list item content has done it
|
||||
@ -880,7 +880,7 @@ html_li(struct html_context *html_context, char *a,
|
||||
"", "UL", "OL", NULL);*/
|
||||
if (t == P_NO_BULLET) {
|
||||
/* Print nothing. */
|
||||
} else if (!par_format.list_number) {
|
||||
} else if (!par_elformat.list_number) {
|
||||
if (t == P_O) /* Print U+25E6 WHITE BULLET. */
|
||||
put_chrs(html_context, "◦", 7);
|
||||
else if (t == P_SQUARE) /* Print U+25AA BLACK SMALL SQUARE. */
|
||||
@ -888,33 +888,33 @@ html_li(struct html_context *html_context, char *a,
|
||||
else /* Print U+2022 BULLET. */
|
||||
put_chrs(html_context, "•", 7);
|
||||
put_chrs(html_context, " ", 6);
|
||||
par_format.leftmargin += 2;
|
||||
par_format.align = ALIGN_LEFT;
|
||||
par_elformat.leftmargin += 2;
|
||||
par_elformat.align = ALIGN_LEFT;
|
||||
|
||||
} else {
|
||||
unsigned char c = 0;
|
||||
int nlen;
|
||||
int t = par_format.flags & P_LISTMASK;
|
||||
int t = par_elformat.flags & P_LISTMASK;
|
||||
int s = get_num(a, "value", html_context->doc_cp);
|
||||
struct string n;
|
||||
|
||||
if (!init_string(&n)) return;
|
||||
|
||||
if (s != -1) par_format.list_number = s;
|
||||
if (s != -1) par_elformat.list_number = s;
|
||||
|
||||
if (t == P_ALPHA || t == P_alpha) {
|
||||
unsigned char n0;
|
||||
|
||||
put_chrs(html_context, " ", 6);
|
||||
c = 1;
|
||||
n0 = par_format.list_number
|
||||
? (par_format.list_number - 1) % 26
|
||||
n0 = par_elformat.list_number
|
||||
? (par_elformat.list_number - 1) % 26
|
||||
+ (t == P_ALPHA ? 'A' : 'a')
|
||||
: 0;
|
||||
if (n0) add_char_to_string(&n, n0);
|
||||
|
||||
} else if (t == P_ROMAN || t == P_roman) {
|
||||
roman(&n, par_format.list_number);
|
||||
roman(&n, par_elformat.list_number);
|
||||
if (t == P_ROMAN) {
|
||||
char *x;
|
||||
|
||||
@ -923,20 +923,20 @@ html_li(struct html_context *html_context, char *a,
|
||||
|
||||
} else {
|
||||
char n0[64];
|
||||
if (par_format.list_number < 10) {
|
||||
if (par_elformat.list_number < 10) {
|
||||
put_chrs(html_context, " ", 6);
|
||||
c = 1;
|
||||
}
|
||||
|
||||
ulongcat(n0, NULL, par_format.list_number, (sizeof(n) - 1), 0);
|
||||
ulongcat(n0, NULL, par_elformat.list_number, (sizeof(n) - 1), 0);
|
||||
add_to_string(&n, n0);
|
||||
}
|
||||
|
||||
nlen = n.length;
|
||||
put_chrs(html_context, n.source, nlen);
|
||||
put_chrs(html_context, ". ", 7);
|
||||
par_format.leftmargin += nlen + c + 2;
|
||||
par_format.align = ALIGN_LEFT;
|
||||
par_elformat.leftmargin += nlen + c + 2;
|
||||
par_elformat.align = ALIGN_LEFT;
|
||||
done_string(&n);
|
||||
|
||||
{
|
||||
@ -944,10 +944,10 @@ html_li(struct html_context *html_context, char *a,
|
||||
|
||||
element = search_html_stack(html_context, "ol");
|
||||
if (element)
|
||||
element->parattr.list_number = par_format.list_number + 1;
|
||||
element->parattr.list_number = par_elformat.list_number + 1;
|
||||
}
|
||||
|
||||
par_format.list_number = 0;
|
||||
par_elformat.list_number = 0;
|
||||
}
|
||||
|
||||
html_context->putsp = HTML_SPACE_SUPPRESS;
|
||||
@ -959,16 +959,16 @@ void
|
||||
html_dl(struct html_context *html_context, char *a,
|
||||
char *xxx3, char *xxx4, char **xxx5)
|
||||
{
|
||||
par_format.flags &= ~P_COMPACT;
|
||||
par_elformat.flags &= ~P_COMPACT;
|
||||
if (has_attr(a, "compact", html_context->doc_cp))
|
||||
par_format.flags |= P_COMPACT;
|
||||
if (par_format.list_level) par_format.leftmargin += 5;
|
||||
par_format.list_level++;
|
||||
par_format.list_number = 0;
|
||||
par_format.align = ALIGN_LEFT;
|
||||
par_format.dd_margin = par_format.leftmargin;
|
||||
par_elformat.flags |= P_COMPACT;
|
||||
if (par_elformat.list_level) par_elformat.leftmargin += 5;
|
||||
par_elformat.list_level++;
|
||||
par_elformat.list_number = 0;
|
||||
par_elformat.align = ALIGN_LEFT;
|
||||
par_elformat.dd_margin = par_elformat.leftmargin;
|
||||
html_top->type = ELEMENT_DONT_KILL;
|
||||
if (!(par_format.flags & P_COMPACT)) {
|
||||
if (!(par_elformat.flags & P_COMPACT)) {
|
||||
ln_break(html_context, 2);
|
||||
html_top->linebreak = 2;
|
||||
}
|
||||
@ -979,9 +979,9 @@ html_dt(struct html_context *html_context, char *a,
|
||||
char *xxx3, char *xxx4, char **xxx5)
|
||||
{
|
||||
kill_html_stack_until(html_context, 0, "", "DL", NULL);
|
||||
par_format.align = ALIGN_LEFT;
|
||||
par_format.leftmargin = par_format.dd_margin;
|
||||
if (!(par_format.flags & P_COMPACT)
|
||||
par_elformat.align = ALIGN_LEFT;
|
||||
par_elformat.leftmargin = par_elformat.dd_margin;
|
||||
if (!(par_elformat.flags & P_COMPACT)
|
||||
&& !has_attr(a, "compact", html_context->doc_cp))
|
||||
ln_break(html_context, 2);
|
||||
}
|
||||
@ -992,13 +992,13 @@ html_dd(struct html_context *html_context, char *a,
|
||||
{
|
||||
kill_html_stack_until(html_context, 0, "", "DL", NULL);
|
||||
|
||||
par_format.leftmargin = par_format.dd_margin + 3;
|
||||
par_elformat.leftmargin = par_elformat.dd_margin + 3;
|
||||
|
||||
if (!html_context->table_level) {
|
||||
par_format.leftmargin += 5;
|
||||
int_upper_bound(&par_format.leftmargin, par_format.width / 2);
|
||||
par_elformat.leftmargin += 5;
|
||||
int_upper_bound(&par_elformat.leftmargin, par_elformat.width / 2);
|
||||
}
|
||||
par_format.align = ALIGN_LEFT;
|
||||
par_elformat.align = ALIGN_LEFT;
|
||||
}
|
||||
|
||||
|
||||
|
@ -51,7 +51,7 @@ html_a(struct html_context *html_context, char *a,
|
||||
if (href) {
|
||||
char *target;
|
||||
|
||||
mem_free_set(&format.link,
|
||||
mem_free_set(&elformat.link,
|
||||
join_urls(html_context->base_href,
|
||||
trim_chars(href, ' ', 0)));
|
||||
|
||||
@ -59,33 +59,33 @@ html_a(struct html_context *html_context, char *a,
|
||||
|
||||
target = get_target(html_context->options, a);
|
||||
if (target) {
|
||||
mem_free_set(&format.target, target);
|
||||
mem_free_set(&elformat.target, target);
|
||||
} else {
|
||||
mem_free_set(&format.target, stracpy(html_context->base_target));
|
||||
mem_free_set(&elformat.target, stracpy(html_context->base_target));
|
||||
}
|
||||
|
||||
if (0) {
|
||||
; /* Shut up compiler */
|
||||
#ifdef CONFIG_GLOBHIST
|
||||
} else if (get_global_history_item(format.link)) {
|
||||
format.style.color.foreground = format.color.vlink;
|
||||
} else if (get_global_history_item(elformat.link)) {
|
||||
elformat.style.color.foreground = elformat.color.vlink;
|
||||
html_top->pseudo_class &= ~ELEMENT_LINK;
|
||||
html_top->pseudo_class |= ELEMENT_VISITED;
|
||||
#endif
|
||||
#ifdef CONFIG_BOOKMARKS
|
||||
} else if (get_bookmark(format.link)) {
|
||||
format.style.color.foreground = format.color.bookmark_link;
|
||||
} else if (get_bookmark(elformat.link)) {
|
||||
elformat.style.color.foreground = elformat.color.bookmark_link;
|
||||
html_top->pseudo_class &= ~ELEMENT_VISITED;
|
||||
/* XXX: Really set ELEMENT_LINK? --pasky */
|
||||
html_top->pseudo_class |= ELEMENT_LINK;
|
||||
#endif
|
||||
} else {
|
||||
format.style.color.foreground = format.color.clink;
|
||||
elformat.style.color.foreground = elformat.color.clink;
|
||||
html_top->pseudo_class &= ~ELEMENT_VISITED;
|
||||
html_top->pseudo_class |= ELEMENT_LINK;
|
||||
}
|
||||
|
||||
mem_free_set(&format.title,
|
||||
mem_free_set(&elformat.title,
|
||||
get_attr_val(a, "title", html_context->doc_cp));
|
||||
|
||||
html_focusable(html_context, a);
|
||||
@ -201,13 +201,13 @@ put_image_label(char *a, char *label,
|
||||
* extension to the standard. After all, it makes sense. */
|
||||
html_focusable(html_context, a);
|
||||
|
||||
saved_foreground = format.style.color.foreground;
|
||||
saved_attr = format.style.attr;
|
||||
format.style.color.foreground = format.color.image_link;
|
||||
format.style.attr |= AT_NO_ENTITIES;
|
||||
saved_foreground = elformat.style.color.foreground;
|
||||
saved_attr = elformat.style.attr;
|
||||
elformat.style.color.foreground = elformat.color.image_link;
|
||||
elformat.style.attr |= AT_NO_ENTITIES;
|
||||
put_chrs(html_context, label, strlen(label));
|
||||
format.style.color.foreground = saved_foreground;
|
||||
format.style.attr = saved_attr;
|
||||
elformat.style.color.foreground = saved_foreground;
|
||||
elformat.style.attr = saved_attr;
|
||||
}
|
||||
|
||||
static void
|
||||
@ -242,13 +242,13 @@ html_img_do(char *a, char *object_src,
|
||||
if (!map_url) return;
|
||||
|
||||
html_stack_dup(html_context, ELEMENT_KILLABLE);
|
||||
mem_free_set(&format.link, map_url);
|
||||
format.form = NULL;
|
||||
format.style.attr |= AT_BOLD;
|
||||
mem_free_set(&elformat.link, map_url);
|
||||
elformat.form = NULL;
|
||||
elformat.style.attr |= AT_BOLD;
|
||||
usemap = 1;
|
||||
}
|
||||
|
||||
ismap = format.link
|
||||
ismap = elformat.link
|
||||
&& has_attr(a, "ismap", html_context->doc_cp)
|
||||
&& !usemap;
|
||||
|
||||
@ -274,7 +274,7 @@ html_img_do(char *a, char *object_src,
|
||||
/* Do we want to display images with no alt/title and with no
|
||||
* link on them ?
|
||||
* If not, just exit now. */
|
||||
if (!options->images && !format.link) {
|
||||
if (!options->images && !elformat.link) {
|
||||
mem_free_if(src);
|
||||
if (usemap) pop_html_element(html_context);
|
||||
return;
|
||||
@ -304,8 +304,8 @@ html_img_do(char *a, char *object_src,
|
||||
mem_free_set(&label, stracpy("IMG"));
|
||||
}
|
||||
|
||||
mem_free_set(&format.image, NULL);
|
||||
mem_free_set(&format.title, NULL);
|
||||
mem_free_set(&elformat.image, NULL);
|
||||
mem_free_set(&elformat.title, NULL);
|
||||
|
||||
if (label) {
|
||||
int img_link_tag = options->image_link.tagging;
|
||||
@ -323,25 +323,25 @@ html_img_do(char *a, char *object_src,
|
||||
|
||||
} else {
|
||||
if (src) {
|
||||
format.image = join_urls(html_context->base_href, src);
|
||||
elformat.image = join_urls(html_context->base_href, src);
|
||||
}
|
||||
|
||||
format.title = get_attr_val(a, "title", html_context->doc_cp);
|
||||
elformat.title = get_attr_val(a, "title", html_context->doc_cp);
|
||||
|
||||
if (ismap) {
|
||||
char *new_link;
|
||||
|
||||
html_stack_dup(html_context, ELEMENT_KILLABLE);
|
||||
new_link = straconcat(format.link, "?0,0", (char *) NULL);
|
||||
new_link = straconcat(elformat.link, "?0,0", (char *) NULL);
|
||||
if (new_link)
|
||||
mem_free_set(&format.link, new_link);
|
||||
mem_free_set(&elformat.link, new_link);
|
||||
}
|
||||
|
||||
put_image_label(a, label, html_context);
|
||||
|
||||
if (ismap) pop_html_element(html_context);
|
||||
mem_free_set(&format.image, NULL);
|
||||
mem_free_set(&format.title, NULL);
|
||||
mem_free_set(&elformat.image, NULL);
|
||||
mem_free_set(&elformat.title, NULL);
|
||||
}
|
||||
|
||||
mem_free(label);
|
||||
@ -399,18 +399,18 @@ put_link_line(char *prefix, char *linkname,
|
||||
html_context->has_link_lines = 1;
|
||||
html_stack_dup(html_context, ELEMENT_KILLABLE);
|
||||
ln_break(html_context, 1);
|
||||
mem_free_set(&format.link, NULL);
|
||||
mem_free_set(&format.target, NULL);
|
||||
mem_free_set(&format.title, NULL);
|
||||
format.form = NULL;
|
||||
mem_free_set(&elformat.link, NULL);
|
||||
mem_free_set(&elformat.target, NULL);
|
||||
mem_free_set(&elformat.title, NULL);
|
||||
elformat.form = NULL;
|
||||
put_chrs(html_context, prefix, strlen(prefix));
|
||||
format.link = join_urls(html_context->base_href, link);
|
||||
format.target = stracpy(target);
|
||||
format.style.color.foreground = format.color.clink;
|
||||
elformat.link = join_urls(html_context->base_href, link);
|
||||
elformat.target = stracpy(target);
|
||||
elformat.style.color.foreground = elformat.color.clink;
|
||||
/* linkname typically comes from get_attr_val, which
|
||||
* has already expanded character entity references.
|
||||
* Tell put_chrs not to expand them again. */
|
||||
format.style.attr |= AT_NO_ENTITIES;
|
||||
elformat.style.attr |= AT_NO_ENTITIES;
|
||||
put_chrs(html_context, linkname, strlen(linkname));
|
||||
ln_break(html_context, 1);
|
||||
pop_html_element(html_context);
|
||||
|
@ -255,6 +255,28 @@ get_num(char *a, char *name, int cp)
|
||||
char *al = get_attr_val(a, name, cp);
|
||||
int result = -1;
|
||||
|
||||
if (al) {
|
||||
result = get_num2(al);
|
||||
|
||||
// char *end;
|
||||
// long num;
|
||||
|
||||
// errno = 0;
|
||||
// num = strtol(al, (char **) &end, 10);
|
||||
// if (!errno && *al && !*end && num >= 0 && num <= INT_MAX)
|
||||
// result = (int) num;
|
||||
|
||||
mem_free(al);
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
int
|
||||
get_num2(char *al)
|
||||
{
|
||||
int result = -1;
|
||||
|
||||
if (al) {
|
||||
char *end;
|
||||
long num;
|
||||
@ -263,8 +285,6 @@ get_num(char *a, char *name, int cp)
|
||||
num = strtol(al, (char **) &end, 10);
|
||||
if (!errno && *al && !*end && num >= 0 && num <= INT_MAX)
|
||||
result = (int) num;
|
||||
|
||||
mem_free(al);
|
||||
}
|
||||
|
||||
return result;
|
||||
@ -279,6 +299,15 @@ get_width(char *a, char *name, int limited,
|
||||
struct html_context *html_context)
|
||||
{
|
||||
char *value = get_attr_val(a, name, html_context->doc_cp);
|
||||
int ret = get_width2(value, limited, html_context);
|
||||
|
||||
mem_free_if(value);
|
||||
return ret;
|
||||
}
|
||||
|
||||
int
|
||||
get_width2(char *value, int limited, struct html_context *html_context)
|
||||
{
|
||||
char *str = value;
|
||||
char *end;
|
||||
int percentage = 0;
|
||||
@ -295,14 +324,14 @@ get_width(char *a, char *name, int limited,
|
||||
|
||||
/* Go back, and skip spaces after width if any. */
|
||||
while (len && isspace(str[len - 1])) len--;
|
||||
if (!len) { mem_free(value); return -1; } /* Nothing to parse. */
|
||||
if (!len) { return -1; } /* Nothing to parse. */
|
||||
|
||||
/* Is this a percentage ? */
|
||||
if (str[len - 1] == '%') len--, percentage = 1;
|
||||
|
||||
/* Skip spaces between width number and percentage if any. */
|
||||
while (len && isspace(str[len - 1])) len--;
|
||||
if (!len) { mem_free(value); return -1; } /* Nothing to parse. */
|
||||
if (!len) { return -1; } /* Nothing to parse. */
|
||||
|
||||
/* Shorten the string a bit, so strtoul() will work on useful
|
||||
* part of it. */
|
||||
@ -317,12 +346,9 @@ get_width(char *a, char *name, int limited,
|
||||
/* We will accept floats but ceil() them. */
|
||||
if (errno || (*end && *end != '.') || width >= INT_MAX) {
|
||||
/* Not a valid number. */
|
||||
mem_free(value);
|
||||
return -1;
|
||||
}
|
||||
|
||||
mem_free(value);
|
||||
|
||||
#define WIDTH_PIXELS2CHARS(width) ((width) + (HTML_CHAR_WIDTH - 1) / 2) / HTML_CHAR_WIDTH;
|
||||
|
||||
if (limited) {
|
||||
@ -356,8 +382,8 @@ get_width(char *a, char *name, int limited,
|
||||
width = 0;
|
||||
|
||||
return width;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
char *
|
||||
skip_comment(char *html, char *eof)
|
||||
@ -580,7 +606,7 @@ static char *process_element(char *name, int namelen, int endingtag,
|
||||
* This function currently requires a semicolon at the end of any
|
||||
* entity reference, and does not support U+2028 LINE SEPARATOR and
|
||||
* U+2029 PARAGRAPH SEPARATOR. */
|
||||
static const char *
|
||||
const char *
|
||||
count_newline_entities(const char *html, const char *eof,
|
||||
int *newlines_out)
|
||||
{
|
||||
@ -858,7 +884,7 @@ start_element(struct element_info *ei,
|
||||
/* Store formatting information for the currently top element on the
|
||||
* stack before processing the new element. */
|
||||
restore_format = html_is_preformatted();
|
||||
old_format = par_format;
|
||||
old_format = par_elformat;
|
||||
|
||||
/* Check for <meta refresh="..."> and <meta> cache-control directives
|
||||
* inside <body> (see bug 700). */
|
||||
@ -936,12 +962,12 @@ start_element(struct element_info *ei,
|
||||
* clickable. */
|
||||
#ifdef CONFIG_ECMASCRIPT
|
||||
if (has_attr(attr, "onClick", html_context->doc_cp)) {
|
||||
/* XXX: Put something better to format.link. --pasky */
|
||||
mem_free_set(&format.link, stracpy("javascript:void(0);"));
|
||||
mem_free_set(&format.target, stracpy(html_context->base_target));
|
||||
format.style.color.foreground = format.color.clink;
|
||||
/* XXX: Put something better to elformat.link. --pasky */
|
||||
mem_free_set(&elformat.link, stracpy("javascript:void(0);"));
|
||||
mem_free_set(&elformat.target, stracpy(html_context->base_target));
|
||||
elformat.style.color.foreground = elformat.color.clink;
|
||||
html_top->pseudo_class = ELEMENT_LINK;
|
||||
mem_free_set(&format.title, stracpy("onClick placeholder"));
|
||||
mem_free_set(&elformat.title, stracpy("onClick placeholder"));
|
||||
/* Er. I know. Well, double html_focusable()s shouldn't
|
||||
* really hurt. */
|
||||
html_focusable(html_context, attr);
|
||||
@ -1015,7 +1041,7 @@ start_element(struct element_info *ei,
|
||||
/* If we are rendering preformatted text (see above), restore the
|
||||
* formatting attributes that were in effect before processing this
|
||||
* element. */
|
||||
if (restore_format) par_format = old_format;
|
||||
if (restore_format) par_elformat = old_format;
|
||||
|
||||
return html;
|
||||
#undef ELEMENT_RENDER_PROLOGUE
|
||||
|
@ -65,7 +65,10 @@ typedef void (element_handler_T)(struct html_context *, char *attr,
|
||||
int parse_element(char *, char *, char **, int *, char **, char **);
|
||||
|
||||
int get_num(char *, char *, int);
|
||||
int get_num2(char *);
|
||||
|
||||
int get_width(char *, char *, int, struct html_context *);
|
||||
int get_width2(char *, int , struct html_context *);
|
||||
|
||||
char *skip_comment(char *, char *);
|
||||
|
||||
@ -80,6 +83,8 @@ int supports_html_media_attr(const char *media);
|
||||
void free_tags_lookup(void);
|
||||
void init_tags_lookup(void);
|
||||
|
||||
const char *count_newline_entities(const char *html, const char *eof, int *newlines_out);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
@ -242,10 +242,10 @@ parse_table_attributes(struct table *table, char *attr, int real,
|
||||
|
||||
set_table_rules(html_context, table, attr);
|
||||
|
||||
table->align = par_format.align;
|
||||
table->align = par_elformat.align;
|
||||
get_align(html_context, attr, &table->align);
|
||||
|
||||
table->color.background = par_format.color.background;
|
||||
table->color.background = par_elformat.color.background;
|
||||
get_bgcolor(html_context, attr, &table->color.background);
|
||||
}
|
||||
|
||||
|
@ -93,7 +93,6 @@ struct table_cache_entry {
|
||||
static int table_cache_entries;
|
||||
static struct hash *table_cache;
|
||||
|
||||
|
||||
struct renderer_context {
|
||||
int last_link_to_move;
|
||||
struct tag *last_tag_to_move;
|
||||
@ -123,11 +122,9 @@ struct renderer_context {
|
||||
unsigned int nowrap:1; /* Activated/deactivated by SP_NOWRAP. */
|
||||
};
|
||||
|
||||
static struct renderer_context renderer_context;
|
||||
|
||||
struct renderer_context renderer_context;
|
||||
|
||||
/* Prototypes */
|
||||
static void line_break(struct html_context *);
|
||||
static void put_chars(struct html_context *, char *, int);
|
||||
|
||||
#define X(x_) (part->box.x + (x_))
|
||||
@ -174,7 +171,7 @@ realloc_line(struct html_context *html_context, struct document *document,
|
||||
end = &line->chars[length];
|
||||
end->data = ' ';
|
||||
end->attr = 0;
|
||||
set_screen_char_color(end, par_format.color.background, 0x0,
|
||||
set_screen_char_color(end, par_elformat.color.background, 0x0,
|
||||
COLOR_ENSURE_CONTRAST, /* for bug 461 */
|
||||
document->options.color_mode);
|
||||
|
||||
@ -288,9 +285,9 @@ get_format_screen_char(struct html_context *html_context,
|
||||
static struct text_style ta_cache = INIT_TEXT_STYLE(-1, 0x0, 0x0);
|
||||
static struct screen_char schar_cache;
|
||||
|
||||
if (memcmp(&ta_cache, &format.style, sizeof(ta_cache))) {
|
||||
copy_struct(&ta_cache, &format.style);
|
||||
struct text_style final_style = format.style;
|
||||
if (memcmp(&ta_cache, &elformat.style, sizeof(ta_cache))) {
|
||||
copy_struct(&ta_cache, &elformat.style);
|
||||
struct text_style final_style = elformat.style;
|
||||
|
||||
get_screen_char_template(&schar_cache, html_context->options, final_style);
|
||||
}
|
||||
@ -300,7 +297,7 @@ get_format_screen_char(struct html_context *html_context,
|
||||
schar_cache.attr ^= SCREEN_ATTR_UNSEARCHABLE;
|
||||
}
|
||||
if (link_state != LINK_STATE_NONE
|
||||
&& !format.form
|
||||
&& !elformat.form
|
||||
&& html_context->options->underline_links) {
|
||||
schar_cache.attr |= SCREEN_ATTR_UNDERLINE;
|
||||
}
|
||||
@ -326,7 +323,7 @@ draw_frame_hchars(struct part *part, int x, int y, int width,
|
||||
copy_screen_chars(&POS(x, y), template_, 1);
|
||||
}
|
||||
|
||||
if (par_format.blockquote_level) {
|
||||
if (par_elformat.blockquote_level) {
|
||||
draw_blockquote_chars(part, y, html_context);
|
||||
}
|
||||
}
|
||||
@ -335,15 +332,15 @@ void
|
||||
draw_blockquote_chars(struct part *part, int y, struct html_context *html_context)
|
||||
{
|
||||
int i;
|
||||
int x = par_format.orig_leftmargin;
|
||||
int x = par_elformat.orig_leftmargin;
|
||||
struct screen_char *const schar = get_format_screen_char(html_context, 0);
|
||||
|
||||
if (LEN(y) + par_format.blockquote_level <= x) {
|
||||
if (LEN(y) + par_elformat.blockquote_level <= x) {
|
||||
return;
|
||||
}
|
||||
|
||||
schar->data = '>';
|
||||
for (i = 1; i < par_format.blockquote_level; i++) {
|
||||
for (i = 1; i < par_elformat.blockquote_level; i++) {
|
||||
copy_screen_chars(&POS(x, y), schar, 1);
|
||||
if (part->char_width) part->char_width[x] = 1;
|
||||
x++;
|
||||
@ -382,10 +379,10 @@ expand_lines(struct html_context *html_context, struct part *part,
|
||||
assert(part && part->document);
|
||||
if_assert_failed return;
|
||||
|
||||
if (!use_document_bg_colors(&part->document->options) && !par_format.blockquote_level)
|
||||
if (!use_document_bg_colors(&part->document->options) && !par_elformat.blockquote_level)
|
||||
return;
|
||||
|
||||
par_format.color.background = bgcolor;
|
||||
par_elformat.color.background = bgcolor;
|
||||
|
||||
if (x < 0) {
|
||||
x = 0;
|
||||
@ -394,7 +391,7 @@ expand_lines(struct html_context *html_context, struct part *part,
|
||||
for (line = 0; line < lines; line++) {
|
||||
if (realloc_line(html_context, part->document, Y(y + line), X(x))) return;
|
||||
|
||||
if (par_format.blockquote_level) {
|
||||
if (par_elformat.blockquote_level) {
|
||||
draw_blockquote_chars(part, y + line, html_context);
|
||||
}
|
||||
}
|
||||
@ -568,7 +565,7 @@ set_hline(struct html_context *html_context, char *chars, int charslen,
|
||||
return 0;
|
||||
|
||||
if (part->begin) {
|
||||
if (par_format.blockquote_level && !html_context->table_level) {
|
||||
if (par_elformat.blockquote_level && !html_context->table_level) {
|
||||
draw_blockquote_chars(part, y, html_context);
|
||||
}
|
||||
part->begin = 0;
|
||||
@ -809,7 +806,7 @@ set_hline(struct html_context *html_context, char *chars, int charslen,
|
||||
return;
|
||||
|
||||
if (part->begin) {
|
||||
if (par_format.blockquote_level && !html_context->table_level) {
|
||||
if (par_elformat.blockquote_level && !html_context->table_level) {
|
||||
draw_blockquote_chars(part, y, html_context);
|
||||
}
|
||||
part->begin = 0;
|
||||
@ -997,7 +994,7 @@ move_chars(struct html_context *html_context, int x, int y, int nx, int ny)
|
||||
if_assert_failed discard_comb_x_y(part->document);
|
||||
move_links(html_context, x, y, nx, ny);
|
||||
|
||||
if (par_format.blockquote_level && !html_context->table_level) {
|
||||
if (par_elformat.blockquote_level && !html_context->table_level) {
|
||||
draw_blockquote_chars(part, ny, html_context);
|
||||
}
|
||||
}
|
||||
@ -1077,7 +1074,7 @@ split_line_at(struct html_context *html_context, int width)
|
||||
{
|
||||
struct part *part;
|
||||
int tmp;
|
||||
int new_width = width + par_format.rightmargin;
|
||||
int new_width = width + par_elformat.rightmargin;
|
||||
|
||||
assert(html_context);
|
||||
if_assert_failed return 0;
|
||||
@ -1097,14 +1094,14 @@ split_line_at(struct html_context *html_context, int width)
|
||||
#ifdef CONFIG_UTF8
|
||||
if (html_context->options->utf8
|
||||
&& width < part->spaces_len && part->char_width[width] == 2) {
|
||||
move_chars(html_context, width, part->cy, par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0), part->cy + 1);
|
||||
move_chars(html_context, width, part->cy, par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0), part->cy + 1);
|
||||
del_chars(html_context, width, part->cy);
|
||||
} else
|
||||
#endif
|
||||
{
|
||||
assertm(POS(width, part->cy).data == ' ',
|
||||
"bad split: %c", POS(width, part->cy).data);
|
||||
move_chars(html_context, width + 1, part->cy, par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0), part->cy + 1);
|
||||
move_chars(html_context, width + 1, part->cy, par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0), part->cy + 1);
|
||||
del_chars(html_context, width, part->cy);
|
||||
}
|
||||
}
|
||||
@ -1132,13 +1129,13 @@ split_line_at(struct html_context *html_context, int width)
|
||||
memset(part->char_width + tmp, 0, width);
|
||||
#endif
|
||||
|
||||
if (par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0) > 0) {
|
||||
tmp = part->spaces_len - (par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0));
|
||||
assertm(tmp > 0, "part->spaces_len - par_format.leftmargin == %d", tmp);
|
||||
if (par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0) > 0) {
|
||||
tmp = part->spaces_len - (par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0));
|
||||
assertm(tmp > 0, "part->spaces_len - par_elformat.leftmargin == %d", tmp);
|
||||
/* So tmp is zero, memmove() should survive that. Don't recover. */
|
||||
memmove(part->spaces + par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0), part->spaces, tmp);
|
||||
memmove(part->spaces + par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0), part->spaces, tmp);
|
||||
#ifdef CONFIG_UTF8
|
||||
memmove(part->char_width + par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0), part->char_width, tmp);
|
||||
memmove(part->char_width + par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0), part->char_width, tmp);
|
||||
#endif
|
||||
}
|
||||
|
||||
@ -1149,7 +1146,7 @@ split_line_at(struct html_context *html_context, int width)
|
||||
int_lower_bound(&part->box.height, part->cy);
|
||||
return 2;
|
||||
} else {
|
||||
part->cx -= width - (par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0));
|
||||
part->cx -= width - (par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0));
|
||||
int_lower_bound(&part->box.height, part->cy + 1);
|
||||
return 1;
|
||||
}
|
||||
@ -1179,40 +1176,40 @@ split_line(struct html_context *html_context)
|
||||
|
||||
#ifdef CONFIG_UTF8
|
||||
if (html_context->options->utf8) {
|
||||
for (x = overlap(par_format); x >= (par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0)); x--) {
|
||||
for (x = overlap(par_elformat); x >= (par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0)); x--) {
|
||||
|
||||
if (x < part->spaces_len && (part->spaces[x]
|
||||
|| (part->char_width[x] == 2
|
||||
/* Ugly hack. If we haven't place for
|
||||
* double-width characters we print two
|
||||
* double-width characters. */
|
||||
&& x != (par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0)))))
|
||||
&& x != (par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0)))))
|
||||
return split_line_at(html_context, x);
|
||||
}
|
||||
|
||||
for (x = par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0); x < part->cx ; x++) {
|
||||
for (x = par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0); x < part->cx ; x++) {
|
||||
if (x < part->spaces_len && (part->spaces[x]
|
||||
|| (part->char_width[x] == 2
|
||||
/* We want to break line after _second_
|
||||
* double-width character. */
|
||||
&& x > (par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0)))))
|
||||
&& x > (par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0)))))
|
||||
return split_line_at(html_context, x);
|
||||
}
|
||||
} else
|
||||
#endif
|
||||
{
|
||||
for (x = overlap(par_format); x >= (par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0)); x--)
|
||||
for (x = overlap(par_elformat); x >= (par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0)); x--)
|
||||
if (x < part->spaces_len && part->spaces[x])
|
||||
return split_line_at(html_context, x);
|
||||
|
||||
for (x = par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0); x < part->cx ; x++)
|
||||
for (x = par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0); x < part->cx ; x++)
|
||||
if (x < part->spaces_len && part->spaces[x])
|
||||
return split_line_at(html_context, x);
|
||||
}
|
||||
|
||||
/* Make sure that we count the right margin to the total
|
||||
* actual box width. */
|
||||
int_lower_bound(&part->box.width, part->cx + par_format.rightmargin);
|
||||
int_lower_bound(&part->box.width, part->cx + par_elformat.rightmargin);
|
||||
|
||||
return 0;
|
||||
}
|
||||
@ -1318,10 +1315,10 @@ justify_line(struct html_context *html_context, int y)
|
||||
|
||||
/* Diff is the difference between the width of the paragraph
|
||||
* and the current length of the line. */
|
||||
diff = overlap(par_format) - len;
|
||||
diff = overlap(par_elformat) - len;
|
||||
|
||||
/* We check diff > 0 because diff can be negative (i.e., we have
|
||||
* an unbroken line of length > overlap(par_format))
|
||||
* an unbroken line of length > overlap(par_elformat))
|
||||
* even when spaces > 1 if the line has only non-breaking spaces. */
|
||||
if (spaces > 1 && diff > 0) {
|
||||
int prev_end = 0;
|
||||
@ -1332,7 +1329,7 @@ justify_line(struct html_context *html_context, int y)
|
||||
* line unchanged, rather than halfway there. The
|
||||
* following loop assumes the allocation succeeded. */
|
||||
if (!realloc_line(html_context, html_context->part->document,
|
||||
Y(y), X(overlap(par_format))))
|
||||
Y(y), X(overlap(par_elformat))))
|
||||
goto out_of_memory;
|
||||
|
||||
for (word = 0; word < spaces; word++) {
|
||||
@ -1418,17 +1415,17 @@ align_line(struct html_context *html_context, int y, int last)
|
||||
|
||||
len = LEN(y);
|
||||
|
||||
if (!len || par_format.align == ALIGN_LEFT)
|
||||
if (!len || par_elformat.align == ALIGN_LEFT)
|
||||
return;
|
||||
|
||||
if (par_format.align == ALIGN_JUSTIFY) {
|
||||
if (par_elformat.align == ALIGN_JUSTIFY) {
|
||||
if (!last)
|
||||
justify_line(html_context, y);
|
||||
return;
|
||||
}
|
||||
|
||||
shift = overlap(par_format) - len;
|
||||
if (par_format.align == ALIGN_CENTER)
|
||||
shift = overlap(par_elformat) - len;
|
||||
if (par_elformat.align == ALIGN_CENTER)
|
||||
shift /= 2;
|
||||
if (shift > 0)
|
||||
shift_chars(html_context, y, shift);
|
||||
@ -1455,13 +1452,13 @@ init_link_event_hooks(struct html_context *html_context, struct link *link)
|
||||
} while (0)
|
||||
|
||||
init_list(*link->event_hooks);
|
||||
add_evhook(link->event_hooks, SEVHOOK_ONCLICK, format.onclick);
|
||||
add_evhook(link->event_hooks, SEVHOOK_ONDBLCLICK, format.ondblclick);
|
||||
add_evhook(link->event_hooks, SEVHOOK_ONMOUSEOVER, format.onmouseover);
|
||||
add_evhook(link->event_hooks, SEVHOOK_ONHOVER, format.onhover);
|
||||
add_evhook(link->event_hooks, SEVHOOK_ONFOCUS, format.onfocus);
|
||||
add_evhook(link->event_hooks, SEVHOOK_ONMOUSEOUT, format.onmouseout);
|
||||
add_evhook(link->event_hooks, SEVHOOK_ONBLUR, format.onblur);
|
||||
add_evhook(link->event_hooks, SEVHOOK_ONCLICK, elformat.onclick);
|
||||
add_evhook(link->event_hooks, SEVHOOK_ONDBLCLICK, elformat.ondblclick);
|
||||
add_evhook(link->event_hooks, SEVHOOK_ONMOUSEOVER, elformat.onmouseover);
|
||||
add_evhook(link->event_hooks, SEVHOOK_ONHOVER, elformat.onhover);
|
||||
add_evhook(link->event_hooks, SEVHOOK_ONFOCUS, elformat.onfocus);
|
||||
add_evhook(link->event_hooks, SEVHOOK_ONMOUSEOUT, elformat.onmouseout);
|
||||
add_evhook(link->event_hooks, SEVHOOK_ONBLUR, elformat.onblur);
|
||||
|
||||
#undef add_evhook
|
||||
}
|
||||
@ -1494,30 +1491,30 @@ new_link(struct html_context *html_context, char *name, int namelen)
|
||||
|
||||
link = &document->links[document->nlinks++];
|
||||
link->number = link_number - 1;
|
||||
if (document->options.use_tabindex) link->number += format.tabindex;
|
||||
link->accesskey = format.accesskey;
|
||||
link->title = null_or_stracpy(format.title);
|
||||
link->where_img = null_or_stracpy(format.image);
|
||||
if (document->options.use_tabindex) link->number += elformat.tabindex;
|
||||
link->accesskey = elformat.accesskey;
|
||||
link->title = null_or_stracpy(elformat.title);
|
||||
link->where_img = null_or_stracpy(elformat.image);
|
||||
|
||||
if (!format.form) {
|
||||
link->target = null_or_stracpy(format.target);
|
||||
if (!elformat.form) {
|
||||
link->target = null_or_stracpy(elformat.target);
|
||||
link->data.name = memacpy(name, namelen);
|
||||
/* if (strlen(url) > 4 && !c_strncasecmp(url, "MAP@", 4)) { */
|
||||
if (format.link
|
||||
&& ((format.link[0]|32) == 'm')
|
||||
&& ((format.link[1]|32) == 'a')
|
||||
&& ((format.link[2]|32) == 'p')
|
||||
&& (format.link[3] == '@')
|
||||
&& format.link[4]) {
|
||||
if (elformat.link
|
||||
&& ((elformat.link[0]|32) == 'm')
|
||||
&& ((elformat.link[1]|32) == 'a')
|
||||
&& ((elformat.link[2]|32) == 'p')
|
||||
&& (elformat.link[3] == '@')
|
||||
&& elformat.link[4]) {
|
||||
link->type = LINK_MAP;
|
||||
link->where = stracpy(format.link + 4);
|
||||
link->where = stracpy(elformat.link + 4);
|
||||
} else {
|
||||
link->type = LINK_HYPERTEXT;
|
||||
link->where = null_or_stracpy(format.link);
|
||||
link->where = null_or_stracpy(elformat.link);
|
||||
}
|
||||
|
||||
} else {
|
||||
struct el_form_control *fc = format.form;
|
||||
struct el_form_control *fc = elformat.form;
|
||||
struct form *form;
|
||||
|
||||
switch (fc->type) {
|
||||
@ -1544,7 +1541,7 @@ new_link(struct html_context *html_context, char *name, int namelen)
|
||||
link->type = LINK_BUTTON;
|
||||
}
|
||||
link->data.form_control = fc;
|
||||
/* At this point, format.form might already be set but
|
||||
/* At this point, elformat.form might already be set but
|
||||
* the form_control not registered through SP_CONTROL
|
||||
* yet, therefore without fc->form set. It is always
|
||||
* after the "good" last form was already processed,
|
||||
@ -1555,10 +1552,10 @@ new_link(struct html_context *html_context, char *name, int namelen)
|
||||
link->target = null_or_stracpy(form ? form->target : NULL);
|
||||
}
|
||||
|
||||
link->color.background = format.style.color.background;
|
||||
link->color.background = elformat.style.color.background;
|
||||
link->color.foreground = link_is_textinput(link)
|
||||
? format.style.color.foreground
|
||||
: format.color.clink;
|
||||
? elformat.style.color.foreground
|
||||
: elformat.color.clink;
|
||||
|
||||
init_link_event_hooks(html_context, link);
|
||||
|
||||
@ -1589,7 +1586,7 @@ html_special_tag(struct document *document, char *t, int x, int y)
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
void
|
||||
put_chars_conv(struct html_context *html_context,
|
||||
char *chars, int charslen)
|
||||
{
|
||||
@ -1599,14 +1596,14 @@ put_chars_conv(struct html_context *html_context,
|
||||
assert(html_context->part && chars && charslen);
|
||||
if_assert_failed return;
|
||||
|
||||
if (format.style.attr & AT_GRAPHICS) {
|
||||
if (elformat.style.attr & AT_GRAPHICS) {
|
||||
put_chars(html_context, chars, charslen);
|
||||
return;
|
||||
}
|
||||
|
||||
convert_string(renderer_context.convert_table, chars, charslen,
|
||||
html_context->options->cp,
|
||||
(format.style.attr & AT_NO_ENTITIES) ? CSM_NONE : CSM_DEFAULT,
|
||||
(elformat.style.attr & AT_NO_ENTITIES) ? CSM_NONE : CSM_DEFAULT,
|
||||
NULL, (void (*)(void *, char *, int)) put_chars, html_context);
|
||||
}
|
||||
|
||||
@ -1658,19 +1655,19 @@ put_link_number(struct html_context *html_context)
|
||||
char *symkey = get_opt_str("document.browse.links.label_key", NULL);
|
||||
struct part *part = html_context->part;
|
||||
char s[64];
|
||||
char *fl = format.link;
|
||||
char *ft = format.target;
|
||||
char *fi = format.image;
|
||||
struct text_style old_style = format.style;
|
||||
struct el_form_control *ff = format.form;
|
||||
char *fl = elformat.link;
|
||||
char *ft = elformat.target;
|
||||
char *fi = elformat.image;
|
||||
struct text_style old_style = elformat.style;
|
||||
struct el_form_control *ff = elformat.form;
|
||||
int slen = 0;
|
||||
int base = strlen(symkey);
|
||||
|
||||
format.link = format.target = format.image = NULL;
|
||||
format.form = NULL;
|
||||
elformat.link = elformat.target = elformat.image = NULL;
|
||||
elformat.form = NULL;
|
||||
if (html_context->options->use_link_number_color) {
|
||||
format.style.attr &= ~AT_BOLD;
|
||||
format.style.color.foreground = format.color.link_number;
|
||||
elformat.style.attr &= ~AT_BOLD;
|
||||
elformat.style.color.foreground = elformat.color.link_number;
|
||||
}
|
||||
|
||||
s[slen++] = '[';
|
||||
@ -1687,15 +1684,15 @@ put_link_number(struct html_context *html_context)
|
||||
/* We might have ended up on a new line after the line breaking
|
||||
* or putting the link number chars. */
|
||||
if (part->cx == -1) {
|
||||
part->cx = par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0);
|
||||
part->cx = par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0);
|
||||
part->begin = 1;
|
||||
}
|
||||
|
||||
format.link = fl;
|
||||
format.target = ft;
|
||||
format.image = fi;
|
||||
format.form = ff;
|
||||
format.style = old_style;
|
||||
elformat.link = fl;
|
||||
elformat.target = ft;
|
||||
elformat.image = fi;
|
||||
elformat.form = ff;
|
||||
elformat.style = old_style;
|
||||
}
|
||||
|
||||
#define assert_link_variable(old, new) \
|
||||
@ -1775,8 +1772,8 @@ process_link(struct html_context *html_context, enum link_state link_state,
|
||||
case LINK_STATE_NEW:
|
||||
part->link_num++;
|
||||
|
||||
init_link_state_info(format.link, format.target,
|
||||
format.image, format.form);
|
||||
init_link_state_info(elformat.link, elformat.target,
|
||||
elformat.image, elformat.form);
|
||||
if (!part->document) return;
|
||||
|
||||
/* Trim leading space from the link text */
|
||||
@ -1834,16 +1831,16 @@ get_link_state(struct html_context *html_context)
|
||||
{
|
||||
enum link_state state;
|
||||
|
||||
if (!(format.link || format.image || format.form)) {
|
||||
if (!(elformat.link || elformat.image || elformat.form)) {
|
||||
state = LINK_STATE_NONE;
|
||||
|
||||
} else if ((renderer_context.link_state_info.link
|
||||
|| renderer_context.link_state_info.image
|
||||
|| renderer_context.link_state_info.form)
|
||||
&& !xstrcmp(format.link, renderer_context.link_state_info.link)
|
||||
&& !xstrcmp(format.target, renderer_context.link_state_info.target)
|
||||
&& !xstrcmp(format.image, renderer_context.link_state_info.image)
|
||||
&& format.form == renderer_context.link_state_info.form) {
|
||||
&& !xstrcmp(elformat.link, renderer_context.link_state_info.link)
|
||||
&& !xstrcmp(elformat.target, renderer_context.link_state_info.target)
|
||||
&& !xstrcmp(elformat.image, renderer_context.link_state_info.image)
|
||||
&& elformat.form == renderer_context.link_state_info.form) {
|
||||
|
||||
return LINK_STATE_SAME;
|
||||
|
||||
@ -1902,7 +1899,7 @@ put_chars(struct html_context *html_context, char *chars, int charslen)
|
||||
if (charslen < 1) return;
|
||||
}
|
||||
|
||||
part->cx = par_format.leftmargin + (par_format.blockquote_level * (html_context->table_level == 0));
|
||||
part->cx = par_elformat.leftmargin + (par_elformat.blockquote_level * (html_context->table_level == 0));
|
||||
part->begin = 1;
|
||||
}
|
||||
|
||||
@ -1951,13 +1948,13 @@ put_chars(struct html_context *html_context, char *chars, int charslen)
|
||||
|
||||
#ifdef CONFIG_UTF8
|
||||
if (renderer_context.nowrap
|
||||
&& part->cx + cells > overlap(par_format))
|
||||
&& part->cx + cells > overlap(par_elformat))
|
||||
return;
|
||||
|
||||
part->cx += cells;
|
||||
#else
|
||||
if (renderer_context.nowrap
|
||||
&& part->cx + charslen > overlap(par_format))
|
||||
&& part->cx + charslen > overlap(par_elformat))
|
||||
return;
|
||||
|
||||
part->cx += charslen;
|
||||
@ -1966,8 +1963,8 @@ put_chars(struct html_context *html_context, char *chars, int charslen)
|
||||
renderer_context.nobreak = 0;
|
||||
|
||||
if (html_context->options->wrap || !html_is_preformatted()) {
|
||||
while (part->cx > overlap(par_format)
|
||||
&& part->cx > (par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0))) {
|
||||
while (part->cx > overlap(par_elformat)
|
||||
&& part->cx > (par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0))) {
|
||||
int x = split_line(html_context);
|
||||
|
||||
if (!x) break;
|
||||
@ -1984,14 +1981,14 @@ put_chars(struct html_context *html_context, char *chars, int charslen)
|
||||
part->xa += charslen;
|
||||
#endif /* CONFIG_UTF8 */
|
||||
int_lower_bound(&part->max_width, part->xa
|
||||
+ par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0) + par_format.rightmargin
|
||||
+ par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0) + par_elformat.rightmargin
|
||||
- (chars[charslen - 1] == ' '
|
||||
&& (html_context->options->wrap || !html_is_preformatted())));
|
||||
}
|
||||
|
||||
#undef overlap
|
||||
|
||||
static void
|
||||
void
|
||||
line_break(struct html_context *html_context)
|
||||
{
|
||||
struct part *part;
|
||||
@ -2005,7 +2002,7 @@ line_break(struct html_context *html_context)
|
||||
assert(part);
|
||||
if_assert_failed return;
|
||||
|
||||
int_lower_bound(&part->box.width, part->cx + par_format.rightmargin);
|
||||
int_lower_bound(&part->box.width, part->cx + par_elformat.rightmargin);
|
||||
|
||||
if (renderer_context.nobreak) {
|
||||
renderer_context.nobreak = 0;
|
||||
@ -2019,7 +2016,7 @@ line_break(struct html_context *html_context)
|
||||
if (!realloc_lines(part->document, part->box.height + part->cy + 1))
|
||||
return;
|
||||
|
||||
if (part->cx > (par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0)) && LEN(part->cy) > part->cx - 1
|
||||
if (part->cx > (par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0)) && LEN(part->cy) > part->cx - 1
|
||||
&& POS(part->cx - 1, part->cy).data == ' ') {
|
||||
del_chars(html_context, part->cx - 1, part->cy);
|
||||
part->cx--;
|
||||
@ -2243,7 +2240,7 @@ static inline void
|
||||
color_link_lines(struct html_context *html_context)
|
||||
{
|
||||
struct document *document = html_context->part->document;
|
||||
struct color_pair colors = INIT_COLOR_PAIR(par_format.color.background, 0x0);
|
||||
struct color_pair colors = INIT_COLOR_PAIR(par_elformat.color.background, 0x0);
|
||||
enum color_mode color_mode = document->options.color_mode;
|
||||
enum color_flags color_flags = document->options.color_flags;
|
||||
int y;
|
||||
@ -2259,14 +2256,14 @@ color_link_lines(struct html_context *html_context)
|
||||
/* XXX: Entering hack zone! Change to clink color after
|
||||
* link text has been recolored. */
|
||||
if (schar->data == ':' && colors.foreground == 0x0)
|
||||
colors.foreground = format.color.clink;
|
||||
colors.foreground = elformat.color.clink;
|
||||
}
|
||||
|
||||
colors.foreground = 0x0;
|
||||
}
|
||||
}
|
||||
|
||||
static void *
|
||||
void *
|
||||
html_special(struct html_context *html_context, enum html_special_type c, ...)
|
||||
{
|
||||
va_list l;
|
||||
@ -2613,8 +2610,8 @@ render_html_document(struct cache_entry *cached, struct document *document,
|
||||
}
|
||||
done_string(&title);
|
||||
|
||||
part = format_html_part(html_context, start, end, par_format.align,
|
||||
par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0),
|
||||
part = format_html_part(html_context, start, end, par_elformat.align,
|
||||
par_elformat.leftmargin + par_elformat.blockquote_level * (html_context->table_level == 0),
|
||||
document->options.document_width, document,
|
||||
0, 0, head.source, 1);
|
||||
|
||||
@ -2642,7 +2639,7 @@ render_html_document(struct cache_entry *cached, struct document *document,
|
||||
>= document->options.width));
|
||||
#endif
|
||||
|
||||
document->color.background = par_format.color.background;
|
||||
document->color.background = par_elformat.color.background;
|
||||
|
||||
done_html_parser(html_context);
|
||||
|
||||
|
@ -77,6 +77,12 @@ struct part *format_html_part(struct html_context *html_context, char *, char *,
|
||||
int dec2qwerty(int num, char *link_sym, const char *key, int base);
|
||||
int qwerty2dec(const char *link_sym, const char *key, int base);
|
||||
|
||||
void put_chars_conv(struct html_context *html_context, char *chars, int charslen);
|
||||
void line_break(struct html_context *html_context);
|
||||
|
||||
void *html_special(struct html_context *html_context, enum html_special_type c, ...);
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
@ -52,22 +52,22 @@ get_table_frames(struct table *table, struct table_frames *result)
|
||||
static int
|
||||
get_table_indent(struct html_context *html_context, struct table *table)
|
||||
{
|
||||
int width = par_format.width - table->real_width;
|
||||
int width = par_elformat.width - table->real_width;
|
||||
int indent;
|
||||
|
||||
switch (table->align) {
|
||||
case ALIGN_CENTER:
|
||||
indent = /*par_format.blockquote_level +*/ (width + par_format.leftmargin - par_format.rightmargin) / 2;
|
||||
indent = /*par_elformat.blockquote_level +*/ (width + par_elformat.leftmargin - par_elformat.rightmargin) / 2;
|
||||
break;
|
||||
|
||||
case ALIGN_RIGHT:
|
||||
indent = width - par_format.rightmargin;
|
||||
indent = width - par_elformat.rightmargin;
|
||||
break;
|
||||
|
||||
case ALIGN_LEFT:
|
||||
case ALIGN_JUSTIFY:
|
||||
default:
|
||||
indent = par_format.leftmargin + par_format.blockquote_level;
|
||||
indent = par_elformat.leftmargin + par_elformat.blockquote_level;
|
||||
}
|
||||
|
||||
/* Don't use int_bounds(&x, 0, width) here,
|
||||
@ -538,7 +538,7 @@ get_table_cellpadding(struct html_context *html_context, struct table *table)
|
||||
{
|
||||
struct part *part = table->part;
|
||||
int cpd_pass = 0, cpd_width = 0, cpd_last = table->cellpadding;
|
||||
int margins = /*par_format.blockquote_level +*/ par_format.leftmargin + par_format.rightmargin;
|
||||
int margins = /*par_elformat.blockquote_level +*/ par_elformat.leftmargin + par_elformat.rightmargin;
|
||||
|
||||
again:
|
||||
get_cell_widths(html_context, table);
|
||||
@ -870,10 +870,10 @@ draw_table_cell(struct table *table, int col, int row, int x, int y,
|
||||
state = init_html_parser_state(html_context, ELEMENT_DONT_KILL,
|
||||
cell->align, 0, 0);
|
||||
|
||||
if (cell->is_header) format.style.attr |= AT_BOLD;
|
||||
if (cell->is_header) elformat.style.attr |= AT_BOLD;
|
||||
|
||||
format.style.color.background = cell->bgcolor;
|
||||
par_format.color.background = cell->bgcolor;
|
||||
elformat.style.color.background = cell->bgcolor;
|
||||
par_elformat.color.background = cell->bgcolor;
|
||||
|
||||
if (cell->valign == VALIGN_MIDDLE)
|
||||
tmpy += (height - cell->height) / 2;
|
||||
@ -908,7 +908,7 @@ draw_table_cells(struct table *table, int x, int y,
|
||||
{
|
||||
int col, row;
|
||||
int xp;
|
||||
color_T bgcolor = par_format.color.background;
|
||||
color_T bgcolor = par_elformat.color.background;
|
||||
struct table_frames table_frames;
|
||||
|
||||
get_table_frames(table, &table_frames);
|
||||
@ -1033,7 +1033,7 @@ draw_frame_point(struct table *table, signed char *frame[2], int x, int y,
|
||||
+ 27 * int_max(bottom, 0);
|
||||
|
||||
draw_frame_hchars(table->part, x, y, 1, border_chars[pos],
|
||||
par_format.color.background, table->color.border,
|
||||
par_elformat.color.background, table->color.border,
|
||||
html_context);
|
||||
}
|
||||
|
||||
@ -1050,7 +1050,7 @@ draw_frame_hline(struct table *table, signed char *frame[2], int x, int y,
|
||||
if (pos < 0 || table->cols_widths[col] <= 0) return;
|
||||
|
||||
draw_frame_hchars(table->part, x, y, table->cols_widths[col], hltable[pos],
|
||||
par_format.color.background, table->color.border, html_context);
|
||||
par_elformat.color.background, table->color.border, html_context);
|
||||
}
|
||||
|
||||
static inline void
|
||||
@ -1066,7 +1066,7 @@ draw_frame_vline(struct table *table, signed char *frame[2], int x, int y,
|
||||
if (pos < 0 || table->rows_heights[row] <= 0) return;
|
||||
|
||||
draw_frame_vchars(table->part, x, y, table->rows_heights[row], vltable[pos],
|
||||
par_format.color.background, table->color.border, html_context);
|
||||
par_elformat.color.background, table->color.border, html_context);
|
||||
}
|
||||
|
||||
static inline int
|
||||
@ -1226,7 +1226,7 @@ draw_table_caption(struct html_context *html_context, struct table *table,
|
||||
|
||||
if (!part) return;
|
||||
|
||||
if (par_format.blockquote_level) {
|
||||
if (par_elformat.blockquote_level) {
|
||||
int yy;
|
||||
|
||||
for (yy = 0; yy < part->box.height; yy++) {
|
||||
@ -1304,7 +1304,7 @@ format_table(char *attr, char *html, char *eof,
|
||||
state = init_html_parser_state(html_context, ELEMENT_DONT_KILL,
|
||||
ALIGN_LEFT, 0, 0);
|
||||
|
||||
margins = /*par_format.blockquote_level + */par_format.leftmargin + par_format.rightmargin;
|
||||
margins = /*par_elformat.blockquote_level + */par_elformat.leftmargin + par_elformat.rightmargin;
|
||||
if (get_table_cellpadding(html_context, table)) goto ret2;
|
||||
|
||||
distribute_table_widths(table);
|
||||
@ -1312,7 +1312,7 @@ format_table(char *attr, char *html, char *eof,
|
||||
if (!part->document && part->box.x == 1) {
|
||||
int total_width = table->real_width + margins;
|
||||
|
||||
int_bounds(&total_width, table->real_width, par_format.width);
|
||||
int_bounds(&total_width, table->real_width, par_elformat.width);
|
||||
int_lower_bound(&part->box.width, total_width);
|
||||
part->cy += table->real_height;
|
||||
|
||||
|
@ -21,6 +21,7 @@
|
||||
#include "document/plain/renderer.h"
|
||||
#ifdef CONFIG_XML
|
||||
#include "document/xml/renderer.h"
|
||||
#include "document/xml/renderer2.h"
|
||||
#endif
|
||||
#include "document/renderer.h"
|
||||
#include "document/view.h"
|
||||
@ -279,6 +280,11 @@ render_encoded_document(struct cache_entry *cached, struct document *document)
|
||||
&& (!c_strlcasecmp("application/rss+xml", 19, cached->content_type, -1)))
|
||||
render_dom_document(cached, document, &buffer);
|
||||
else
|
||||
#endif
|
||||
#ifdef CONFIG_XML
|
||||
if (document->dom)
|
||||
render_xhtml_document(cached, document, &buffer);
|
||||
else
|
||||
#endif
|
||||
render_html_document(cached, document, &buffer);
|
||||
}
|
||||
|
364
src/document/xml/renderer2.c
Normal file
364
src/document/xml/renderer2.c
Normal file
@ -0,0 +1,364 @@
|
||||
/* Plain text document renderer */
|
||||
|
||||
#ifdef HAVE_CONFIG_H
|
||||
#include "config.h"
|
||||
#endif
|
||||
|
||||
#include <ctype.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
#include "elinks.h"
|
||||
|
||||
#include "bookmarks/bookmarks.h"
|
||||
#include "cache/cache.h"
|
||||
#include "config/options.h"
|
||||
#include "document/docdata.h"
|
||||
#include "document/document.h"
|
||||
#include "document/format.h"
|
||||
#include "document/options.h"
|
||||
#include "document/html/internal.h"
|
||||
#include "document/html/parser.h"
|
||||
#include "document/html/parser/parse.h"
|
||||
#include "document/plain/renderer.h"
|
||||
#include "document/renderer.h"
|
||||
#include "document/xml/renderer2.h"
|
||||
#include "document/xml/tags.h"
|
||||
#include "globhist/globhist.h"
|
||||
#include "intl/charsets.h"
|
||||
#include "protocol/protocol.h"
|
||||
#include "protocol/uri.h"
|
||||
#include "terminal/color.h"
|
||||
#include "terminal/draw.h"
|
||||
#include "util/color.h"
|
||||
#include "util/error.h"
|
||||
#include "util/memory.h"
|
||||
#include "util/string.h"
|
||||
|
||||
#include <libxml++/libxml++.h>
|
||||
|
||||
static void
|
||||
dump_text(struct source_renderer *renderer, unsigned char *html, int length)
|
||||
{
|
||||
struct html_context *html_context = renderer->html_context;
|
||||
unsigned char *eof = html + length;
|
||||
unsigned char *base_pos = html;
|
||||
|
||||
if (length > 0 && (eof[-1] == '\n')) {
|
||||
length--;
|
||||
eof--;
|
||||
}
|
||||
#ifdef CONFIG_CSS
|
||||
if (html_context->was_style) {
|
||||
/// css_parse_stylesheet(&html_context->css_styles, html_context->base_href, html, eof);
|
||||
return;
|
||||
}
|
||||
#endif
|
||||
//fprintf(stderr, "html='%s'\n", html);
|
||||
if (length <= 0) {
|
||||
return;
|
||||
}
|
||||
int noupdate = 0;
|
||||
|
||||
main_loop:
|
||||
if (!html_is_preformatted()) {
|
||||
unsigned char *buffer = fmem_alloc(length+1);
|
||||
unsigned char *dst;
|
||||
html_context->part = renderer->part;
|
||||
html_context->eoff = eof;
|
||||
|
||||
if (!buffer) {
|
||||
return;
|
||||
}
|
||||
dst = buffer;
|
||||
*dst = *html;
|
||||
|
||||
for (html++; html <= eof; html++) {
|
||||
if (isspace(*html)) {
|
||||
if (*dst != ' ') {
|
||||
*(++dst) = ' ';
|
||||
}
|
||||
} else {
|
||||
*(++dst) = *html;
|
||||
}
|
||||
}
|
||||
|
||||
if (dst - buffer > 1) {
|
||||
if (*buffer == ' ') {
|
||||
html_context->putsp = HTML_SPACE_ADD;
|
||||
}
|
||||
}
|
||||
put_chrs(html_context, buffer, dst - buffer);
|
||||
fmem_free(buffer);
|
||||
}
|
||||
|
||||
while (html < eof) {
|
||||
int dotcounter = 0;
|
||||
|
||||
if (!noupdate) {
|
||||
html_context->part = renderer->part;
|
||||
html_context->eoff = eof;
|
||||
base_pos = html;
|
||||
} else {
|
||||
noupdate = 0;
|
||||
}
|
||||
if (html_is_preformatted()) {
|
||||
html_context->putsp = HTML_SPACE_NORMAL;
|
||||
if (*html == ASCII_TAB) {
|
||||
put_chrs(html_context, base_pos, html - base_pos);
|
||||
put_chrs(html_context, " ",
|
||||
8 - (html_context->position % 8));
|
||||
html++;
|
||||
continue;
|
||||
|
||||
} else if (*html == ASCII_CR || *html == ASCII_LF) {
|
||||
put_chrs(html_context, base_pos, html - base_pos);
|
||||
if (html - base_pos == 0 && html_context->line_breax > 0) {
|
||||
html_context->line_breax--;
|
||||
}
|
||||
next_break:
|
||||
if (*html == ASCII_CR && html < eof - 1 && html[1] == ASCII_LF) {
|
||||
html++;
|
||||
}
|
||||
ln_break(html_context, 1);
|
||||
html++;
|
||||
|
||||
if (*html == ASCII_CR || *html == ASCII_LF) {
|
||||
html_context->line_breax = 0;
|
||||
goto next_break;
|
||||
}
|
||||
continue;
|
||||
|
||||
} else if (html + 5 < eof && *html == '&') {
|
||||
/* Really nasty hack to make handling in
|
||||
* <pre>-tags lynx-compatible. It works around
|
||||
* the entity handling done in the renderer,
|
||||
* since checking #13 value there would require
|
||||
* something along the lines of NBSP_CHAR or
|
||||
* checking for '\n's in AT_PREFORMATTED text. */
|
||||
/* See bug 52 and 387 for more info. */
|
||||
int length = html - base_pos;
|
||||
int newlines;
|
||||
|
||||
html = (unsigned char *) count_newline_entities(html, eof, &newlines);
|
||||
if (newlines) {
|
||||
put_chrs(html_context, base_pos, length);
|
||||
ln_break(html_context, newlines);
|
||||
continue;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
while (*html < ' ') {
|
||||
if (html - base_pos) {
|
||||
put_chrs(html_context, base_pos, html - base_pos);
|
||||
}
|
||||
|
||||
dotcounter++;
|
||||
base_pos = ++html;
|
||||
if (*html >= ' ' || isspace(*html) || html >= eof) {
|
||||
unsigned char *dots = fmem_alloc(dotcounter);
|
||||
|
||||
if (dots) {
|
||||
memset(dots, '.', dotcounter);
|
||||
put_chrs(html_context, dots, dotcounter);
|
||||
fmem_free(dots);
|
||||
}
|
||||
goto main_loop;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#define HTML_MAX_DOM_STRUCTURE_DEPTH 1024
|
||||
|
||||
static bool
|
||||
dump_dom_structure(struct source_renderer *renderer, xmlpp::Node *node, int depth)
|
||||
{
|
||||
if (depth >= HTML_MAX_DOM_STRUCTURE_DEPTH) {
|
||||
return false;
|
||||
}
|
||||
|
||||
std::string tag_name = node->get_name();
|
||||
struct element_info2 *ei = get_tag_value(tag_name.c_str(), tag_name.size());
|
||||
|
||||
/* Print this node's entry */
|
||||
if (ei) {
|
||||
ei->open(renderer, node, NULL, NULL, NULL, NULL);
|
||||
}
|
||||
|
||||
/* Get the node's first child */
|
||||
auto children = node->get_children();
|
||||
auto it = children.begin();
|
||||
auto end = children.end();
|
||||
|
||||
for (;it != end; ++it) {
|
||||
xmlpp::Element *el = dynamic_cast<xmlpp::Element *>(*it);
|
||||
|
||||
if (el) {
|
||||
dump_dom_structure(renderer, el, depth + 1);
|
||||
} else {
|
||||
xmlpp::TextNode *text = dynamic_cast<xmlpp::TextNode *>(*it);
|
||||
|
||||
if (text) {
|
||||
std::string v = text->get_content();
|
||||
dump_text(renderer, v.c_str(), v.size());
|
||||
}
|
||||
}
|
||||
}
|
||||
if (ei && ei->close) {
|
||||
ei->close(renderer, node, NULL, NULL, NULL, NULL);
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
void
|
||||
render_xhtml_document(struct cache_entry *cached, struct document *document, struct string *buffer)
|
||||
{
|
||||
struct html_context *html_context;
|
||||
struct part *part = NULL;
|
||||
char *start;
|
||||
char *end;
|
||||
struct string title;
|
||||
struct string head;
|
||||
|
||||
struct source_renderer renderer;
|
||||
|
||||
assert(cached && document);
|
||||
if_assert_failed return;
|
||||
|
||||
if (!init_string(&head)) return;
|
||||
|
||||
if (cached->head) add_to_string(&head, cached->head);
|
||||
|
||||
start = buffer->source;
|
||||
end = buffer->source + buffer->length;
|
||||
|
||||
html_context = init_html_parser(cached->uri, &document->options,
|
||||
start, end, &head, &title,
|
||||
put_chars_conv, line_break,
|
||||
html_special);
|
||||
if (!html_context) return;
|
||||
|
||||
/// renderer_context.g_ctrl_num = 0;
|
||||
/// renderer_context.cached = cached;
|
||||
/// renderer_context.convert_table = get_convert_table(head.source,
|
||||
/// document->options.cp,
|
||||
/// document->options.assume_cp,
|
||||
/// &document->cp,
|
||||
/// &document->cp_status,
|
||||
/// document->options.hard_assume);
|
||||
|
||||
struct conv_table *convert_table = get_convert_table(head.source,
|
||||
document->options.cp,
|
||||
document->options.assume_cp,
|
||||
&document->cp,
|
||||
&document->cp_status,
|
||||
document->options.hard_assume);;
|
||||
|
||||
|
||||
|
||||
#ifdef CONFIG_UTF8
|
||||
html_context->options->utf8 = is_cp_utf8(document->options.cp);
|
||||
#endif /* CONFIG_UTF8 */
|
||||
html_context->doc_cp = document->cp;
|
||||
|
||||
if (title.length) {
|
||||
/* CSM_DEFAULT because init_html_parser() did not
|
||||
* decode entities in the title. */
|
||||
document->title = convert_string(convert_table,
|
||||
title.source, title.length,
|
||||
document->options.cp,
|
||||
CSM_DEFAULT, NULL, NULL, NULL);
|
||||
}
|
||||
done_string(&title);
|
||||
|
||||
xmlpp::Document *doc = document->dom;
|
||||
xmlpp::Element *root = doc->get_root_node();
|
||||
renderer.html_context = html_context;
|
||||
|
||||
html_context->putsp = HTML_SPACE_SUPPRESS;
|
||||
html_context->line_breax = html_context->table_level ? 2 : 1;
|
||||
html_context->position = 0;
|
||||
html_context->was_br = 0;
|
||||
html_context->was_li = 0;
|
||||
html_context->was_body = 0;
|
||||
/* html_context->was_body_background = 0; */
|
||||
renderer.part = html_context->part = part;
|
||||
/// html_context->eoff = eof;
|
||||
|
||||
dump_dom_structure(&renderer, root, 0);
|
||||
|
||||
/// part = format_html_part(html_context, start, end, par_format.align,
|
||||
/// par_format.leftmargin + par_format.blockquote_level * (html_context->table_level == 0),
|
||||
/// document->options.document_width, document,
|
||||
/// 0, 0, head.source, 1);
|
||||
|
||||
/* Drop empty allocated lines at end of document if any
|
||||
* and adjust document height. */
|
||||
while (document->height && !document->data[document->height - 1].length)
|
||||
mem_free_if(document->data[--document->height].chars);
|
||||
|
||||
/* Calculate document width. */
|
||||
{
|
||||
int i;
|
||||
|
||||
document->width = 0;
|
||||
for (i = 0; i < document->height; i++)
|
||||
int_lower_bound(&document->width, document->data[i].length);
|
||||
}
|
||||
|
||||
#if 1
|
||||
document->options.needs_width = 1;
|
||||
#else
|
||||
/* FIXME: This needs more tuning since if we are centering stuff it
|
||||
* does not work. */
|
||||
document->options.needs_width =
|
||||
(document->width + (document->options.margin
|
||||
>= document->options.width));
|
||||
#endif
|
||||
|
||||
document->color.background = par_elformat.color.background;
|
||||
|
||||
done_html_parser(html_context);
|
||||
|
||||
/* Drop forms which has been serving as a placeholder for form items
|
||||
* added in the wrong order due to the ordering of table rendering. */
|
||||
{
|
||||
struct form *form;
|
||||
|
||||
foreach (form, document->forms) {
|
||||
if (form->form_num)
|
||||
continue;
|
||||
|
||||
if (list_empty(form->items))
|
||||
done_form(form);
|
||||
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/* @part was residing in html_context so it has to stay alive until
|
||||
* done_html_parser(). */
|
||||
done_string(&head);
|
||||
mem_free_if(part);
|
||||
|
||||
#if 0 /* debug purpose */
|
||||
{
|
||||
FILE *f = fopen("forms", "ab");
|
||||
struct el_form_control *form;
|
||||
char *qq;
|
||||
fprintf(f,"FORM:\n");
|
||||
foreach (form, document->forms) {
|
||||
fprintf(f, "g=%d f=%d c=%d t:%d\n",
|
||||
form->g_ctrl_num, form->form_num,
|
||||
form->ctrl_num, form->type);
|
||||
}
|
||||
fprintf(f,"fragment: \n");
|
||||
for (qq = start; qq < end; qq++) fprintf(f, "%c", *qq);
|
||||
fprintf(f,"----------\n\n");
|
||||
fclose(f);
|
||||
}
|
||||
#endif
|
||||
}
|
19
src/document/xml/renderer2.h
Normal file
19
src/document/xml/renderer2.h
Normal file
@ -0,0 +1,19 @@
|
||||
#ifndef EL__DOCUMENT_XML_RENDERER2_H
|
||||
#define EL__DOCUMENT_XML_RENDERER2_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
struct cache_entry;
|
||||
struct document;
|
||||
struct string;
|
||||
|
||||
void render_xhtml_document(struct cache_entry *cached, struct document *document, struct string *buffer);
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user