1
0
mirror of https://github.com/rkd77/elinks.git synced 2025-01-03 14:57:44 -05:00

[select] test/select.html is displayable

This commit is contained in:
Witold Filipczyk 2021-06-30 16:20:57 +02:00
parent d55ea80fe6
commit 30226a1b11
2 changed files with 38 additions and 19 deletions

View File

@ -246,6 +246,7 @@ dump_dom_structure(struct source_renderer *renderer, xmlpp::Node *node, int dept
xmlpp::TextNode *text = dynamic_cast<xmlpp::TextNode *>(*it);
if (text) {
if (renderer->html_context->skip_select) continue;
std::string v = text->get_content();
dump_text(renderer, v.c_str(), v.size());
}

View File

@ -192,8 +192,28 @@ roman(struct string *p, unsigned n)
}
}
static int
tags_get_form_mode(struct html_context *html_context, void *node)
{
xmlpp::Element *el = node;
xmlpp::Attribute *attr;
attr = el->get_attribute("disabled");
if (attr) {
return FORM_MODE_DISABLED;
}
attr = el->get_attribute("readonly");
if (attr) {
return FORM_MODE_READONLY;
}
return FORM_MODE_NORMAL;
}
static struct el_form_control *
tags_init_form_control(enum form_type type, unsigned char *attr,
tags_init_form_control(enum form_type type, void *node,
struct html_context *html_context)
{
struct el_form_control *fc;
@ -204,7 +224,7 @@ tags_init_form_control(enum form_type type, unsigned char *attr,
fc->type = type;
fc->position = ++html_context->ff;
// fc->position = attr - html_context->startf;
// fc->mode = get_form_mode(html_context, attr);
fc->mode = tags_get_form_mode(html_context, node);
return fc;
}
@ -368,9 +388,6 @@ tags_html_a(struct source_renderer *renderer, void *node, unsigned char *a,
join_urls(html_context->base_href,
trim_chars(href, ' ', 0)));
//fprintf(stderr, "tags_html_a: elformat.link=%s\n", elformat.link);
mem_free(href);
std::string target_value = anchor->get_attribute_value("target");
@ -748,7 +765,7 @@ tags_html_button(struct source_renderer *renderer, void *node, unsigned char *a,
mem_free(al);
no_type_attr:
fc = tags_init_form_control(type, a, html_context);
fc = tags_init_form_control(type, node, html_context);
if (!fc) return;
std::string disabled = button->get_attribute_value("disabled");
@ -1809,7 +1826,6 @@ tags_html_img_do(struct source_renderer *renderer, void *node, unsigned char *a,
html_stack_dup(html_context, ELEMENT_KILLABLE);
mem_free_set(&elformat.link, map_url);
//fprintf(stderr, "html_img_do: elformat.link=%s\n", elformat.link);
elformat.form = NULL;
elformat.style.attr |= AT_BOLD;
usemap = 1;
@ -1926,7 +1942,6 @@ tags_html_img_do(struct source_renderer *renderer, void *node, unsigned char *a,
new_link = straconcat(elformat.link, "?0,0", (unsigned char *) NULL);
if (new_link) {
mem_free_set(&elformat.link, new_link);
//fprintf(stderr, "new_link: elformat.link=%s\n", elformat.link);
}
}
@ -2063,7 +2078,7 @@ tags_html_input(struct source_renderer *renderer, void *node, unsigned char *a,
xmlpp::Element *input = node;
unsigned int size = 0;
fc = tags_init_form_control(FC_TEXT, a, html_context);
fc = tags_init_form_control(FC_TEXT, node, html_context);
if (!fc) return;
std::string disabled = input->get_attribute_value("disabled");
@ -3298,7 +3313,7 @@ do_tags_html_select(struct source_renderer *renderer, void *node, unsigned char
order = 0;
auto it = options.begin();
auto end = options.end();
for (i = 0; i < len, it != end; ++i, ++it) {
for (i = 0; it != end; ++it) {
xmlpp::Element *option_node = dynamic_cast<xmlpp::Element *>(*it);
if (option_node) {
@ -3309,20 +3324,21 @@ do_tags_html_select(struct source_renderer *renderer, void *node, unsigned char
unsigned char *label = NULL;
add_select_item(&lnk_menu, &lbl, &orig_lbl, values, order, nnmi);
std::string disabled = option_node->get_attribute_value("disabled");
xmlpp::Attribute *disabled = option_node->get_attribute("disabled");
if (disabled == "disabled" || disabled == "true" || disabled == "1") {
if (disabled) {
++i;
continue;
}
std::string selected_value = option_node->get_attribute_value("selected");
bool selected = (selected_value == "selected" || selected_value == "true" || selected_value == "1");
xmlpp::Attribute *selected_attr = option_node->get_attribute("selected");
bool selected = (selected_attr != nullptr);
if (-1 == preselect && selected) {
preselect = order;
}
std::string value_value = option_node->get_attribute_value("value");
if (value_value != "") {
if (true) {
value = memacpy(value_value.c_str(), value_value.size());
if (!mem_align_alloc(&values, i, i + 1, 0xFF)) {
@ -3345,7 +3361,6 @@ do_tags_html_select(struct source_renderer *renderer, void *node, unsigned char
std::string label_value = option_node->get_attribute_value("label");
if (label_value != "") {
label = memacpy(label_value.c_str(), label_value.size());
//fprintf(stderr, "label=%s\n", label);
}
if (label) {
new_menu_item(&lnk_menu, label, order - 1, 0);
@ -3402,6 +3417,7 @@ do_tags_html_select(struct source_renderer *renderer, void *node, unsigned char
// goto see;
// }
++i;
} else if ("optgroup" == tag) {
unsigned char *label = NULL;
@ -3420,6 +3436,7 @@ do_tags_html_select(struct source_renderer *renderer, void *node, unsigned char
}
new_menu_item(&lnk_menu, label, -1, 0);
group = 1;
++i;
}
if (group) new_menu_item(&lnk_menu, NULL, -1, 0), group = 0;
}
@ -3478,10 +3495,11 @@ do_tags_html_select(struct source_renderer *renderer, void *node, unsigned char
mem_free(values);
}
destroy_menu(&lnk_menu);
return;
}
fc = tags_init_form_control(FC_SELECT, a, html_context);
fc = tags_init_form_control(FC_SELECT, node, html_context);
if (!fc) {
mem_free(labels);
@ -3495,6 +3513,7 @@ do_tags_html_select(struct source_renderer *renderer, void *node, unsigned char
mem_free(values);
}
destroy_menu(&lnk_menu);
return;
}
@ -3839,7 +3858,7 @@ pp:
if (parse_element(p, eof, &t_name, &t_namelen, NULL, end)) goto pp;
if (c_strlcasecmp(t_name, t_namelen, "/TEXTAREA", 9)) goto pp;
#endif
fc = tags_init_form_control(FC_TEXTAREA, NULL, html_context);
fc = tags_init_form_control(FC_TEXTAREA, node, html_context);
if (!fc) return;
std::string disabled = textarea->get_attribute_value("disabled");
@ -3972,7 +3991,6 @@ tags_html_textarea_close(struct source_renderer *renderer, void *node, unsigned
{
struct html_context *html_context = renderer->html_context;
//fprintf(stderr, "tags_html_textarea_close\n");
html_context->skip_textarea = 0;
}