mirror of
https://github.com/rkd77/elinks.git
synced 2024-12-04 14:46:47 -05:00
[textarea] Fixes
Still not functional: document.write css tables and others
This commit is contained in:
parent
30226a1b11
commit
a910dda61b
@ -246,7 +246,7 @@ dump_dom_structure(struct source_renderer *renderer, xmlpp::Node *node, int dept
|
|||||||
xmlpp::TextNode *text = dynamic_cast<xmlpp::TextNode *>(*it);
|
xmlpp::TextNode *text = dynamic_cast<xmlpp::TextNode *>(*it);
|
||||||
|
|
||||||
if (text) {
|
if (text) {
|
||||||
if (renderer->html_context->skip_select) continue;
|
if (renderer->html_context->skip_select || renderer->html_context->skip_textarea) continue;
|
||||||
std::string v = text->get_content();
|
std::string v = text->get_content();
|
||||||
dump_text(renderer, v.c_str(), v.size());
|
dump_text(renderer, v.c_str(), v.size());
|
||||||
}
|
}
|
||||||
|
@ -743,7 +743,7 @@ tags_html_button(struct source_renderer *renderer, void *node, unsigned char *a,
|
|||||||
enum form_type type = FC_SUBMIT;
|
enum form_type type = FC_SUBMIT;
|
||||||
xmlpp::Element *button = node;
|
xmlpp::Element *button = node;
|
||||||
|
|
||||||
html_focusable(html_context, a);
|
tags_html_focusable(renderer, node);
|
||||||
|
|
||||||
std::string type_value = button->get_attribute_value("type");
|
std::string type_value = button->get_attribute_value("type");
|
||||||
if (type_value != "") {
|
if (type_value != "") {
|
||||||
@ -787,7 +787,7 @@ no_type_attr:
|
|||||||
//fc->name = get_attr_val(a, "name", cp);
|
//fc->name = get_attr_val(a, "name", cp);
|
||||||
|
|
||||||
std::string value_value = button->get_attribute_value("value");
|
std::string value_value = button->get_attribute_value("value");
|
||||||
if (value_value != "") {
|
if (true) {
|
||||||
fc->default_value = memacpy(value_value.c_str(), value_value.size());
|
fc->default_value = memacpy(value_value.c_str(), value_value.size());
|
||||||
}
|
}
|
||||||
//fc->default_value = get_attr_val(a, "value", cp);
|
//fc->default_value = get_attr_val(a, "value", cp);
|
||||||
@ -1336,7 +1336,7 @@ tags_html_frame(struct source_renderer *renderer, void *no, unsigned char *a,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!html_context->options->frames || !html_top->frameset) {
|
if (!html_context->options->frames || !html_top->frameset) {
|
||||||
html_focusable(html_context, a);
|
tags_html_focusable(renderer, no);
|
||||||
put_link_line("Frame: ", name, url, "", html_context);
|
put_link_line("Frame: ", name, url, "", html_context);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
@ -1763,16 +1763,16 @@ get_image_label(int max_len, unsigned char *label)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
put_image_label(unsigned char *a, unsigned char *label,
|
put_image_label(struct source_renderer *renderer, void *node, unsigned char *label)
|
||||||
struct html_context *html_context)
|
|
||||||
{
|
{
|
||||||
|
struct html_context *html_context = renderer->html_context;
|
||||||
color_T saved_foreground;
|
color_T saved_foreground;
|
||||||
enum text_style_format saved_attr;
|
enum text_style_format saved_attr;
|
||||||
|
|
||||||
/* This is not 100% appropriate for <img>, but well, accepting
|
/* This is not 100% appropriate for <img>, but well, accepting
|
||||||
* accesskey and tabindex near <img> is just our little
|
* accesskey and tabindex near <img> is just our little
|
||||||
* extension to the standard. After all, it makes sense. */
|
* extension to the standard. After all, it makes sense. */
|
||||||
html_focusable(html_context, a);
|
tags_html_focusable(renderer, node);
|
||||||
|
|
||||||
saved_foreground = elformat.style.color.foreground;
|
saved_foreground = elformat.style.color.foreground;
|
||||||
saved_attr = elformat.style.attr;
|
saved_attr = elformat.style.attr;
|
||||||
@ -1922,7 +1922,7 @@ tags_html_img_do(struct source_renderer *renderer, void *node, unsigned char *a,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!options->image_link.show_any_as_links) {
|
if (!options->image_link.show_any_as_links) {
|
||||||
put_image_label(a, label, html_context);
|
put_image_label(renderer, node, label);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
if (src) {
|
if (src) {
|
||||||
@ -1945,7 +1945,7 @@ tags_html_img_do(struct source_renderer *renderer, void *node, unsigned char *a,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
put_image_label(a, label, html_context);
|
put_image_label(renderer, node, label);
|
||||||
|
|
||||||
if (ismap) pop_html_element(html_context);
|
if (ismap) pop_html_element(html_context);
|
||||||
mem_free_set(&elformat.image, NULL);
|
mem_free_set(&elformat.image, NULL);
|
||||||
@ -1974,12 +1974,13 @@ tags_html_img_close(struct source_renderer *renderer, void *node, unsigned char
|
|||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
tags_html_input_format(struct html_context *html_context, void *node, unsigned char *a,
|
tags_html_input_format(struct source_renderer *renderer, void *node, unsigned char *a,
|
||||||
struct el_form_control *fc)
|
struct el_form_control *fc)
|
||||||
{
|
{
|
||||||
|
struct html_context *html_context = renderer->html_context;
|
||||||
put_chrs(html_context, " ", 1);
|
put_chrs(html_context, " ", 1);
|
||||||
html_stack_dup(html_context, ELEMENT_KILLABLE);
|
html_stack_dup(html_context, ELEMENT_KILLABLE);
|
||||||
html_focusable(html_context, a);
|
tags_html_focusable(renderer, node);
|
||||||
elformat.form = fc;
|
elformat.form = fc;
|
||||||
mem_free_if(elformat.title);
|
mem_free_if(elformat.title);
|
||||||
xmlpp::Element *input = node;
|
xmlpp::Element *input = node;
|
||||||
@ -2115,7 +2116,7 @@ tags_html_input(struct source_renderer *renderer, void *node, unsigned char *a,
|
|||||||
}
|
}
|
||||||
|
|
||||||
std::string value_value = input->get_attribute_value("value");
|
std::string value_value = input->get_attribute_value("value");
|
||||||
if (value_value != "") {
|
if (true) {
|
||||||
if (fc->type == FC_HIDDEN) {
|
if (fc->type == FC_HIDDEN) {
|
||||||
fc->default_value = memacpy(value_value.c_str(), value_value.size());
|
fc->default_value = memacpy(value_value.c_str(), value_value.size());
|
||||||
} else if (fc->type != FC_FILE) {
|
} else if (fc->type != FC_FILE) {
|
||||||
@ -2187,7 +2188,7 @@ tags_html_input(struct source_renderer *renderer, void *node, unsigned char *a,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (fc->type != FC_HIDDEN) {
|
if (fc->type != FC_HIDDEN) {
|
||||||
tags_html_input_format(html_context, node, a, fc);
|
tags_html_input_format(renderer, node, a, fc);
|
||||||
}
|
}
|
||||||
|
|
||||||
html_context->special_f(html_context, SP_CONTROL, fc);
|
html_context->special_f(html_context, SP_CONTROL, fc);
|
||||||
@ -2553,7 +2554,7 @@ tags_html_link(struct source_renderer *renderer, void *node, unsigned char *a,
|
|||||||
if (!name) goto free_and_return;
|
if (!name) goto free_and_return;
|
||||||
if (!init_string(&text)) goto free_and_return;
|
if (!init_string(&text)) goto free_and_return;
|
||||||
|
|
||||||
html_focusable(html_context, a);
|
tags_html_focusable(renderer, node);
|
||||||
|
|
||||||
if (link.title) {
|
if (link.title) {
|
||||||
add_to_string(&text, link.title);
|
add_to_string(&text, link.title);
|
||||||
@ -3268,7 +3269,7 @@ do_tags_html_select_multiple(struct source_renderer *renderer, void *node, unsig
|
|||||||
//unsigned char *al = get_attr_val(a, "name", html_context->doc_cp);
|
//unsigned char *al = get_attr_val(a, "name", html_context->doc_cp);
|
||||||
|
|
||||||
//if (!al) return;
|
//if (!al) return;
|
||||||
html_focusable(html_context, a);
|
tags_html_focusable(renderer, node);
|
||||||
html_top->type = ELEMENT_DONT_KILL;
|
html_top->type = ELEMENT_DONT_KILL;
|
||||||
mem_free_set(&elformat.select, al);
|
mem_free_set(&elformat.select, al);
|
||||||
|
|
||||||
@ -3621,7 +3622,7 @@ tags_html_source(struct source_renderer *renderer, void *node, unsigned char *a,
|
|||||||
//url = get_url_val(a, "src", html_context->doc_cp);
|
//url = get_url_val(a, "src", html_context->doc_cp);
|
||||||
if (!url) return;
|
if (!url) return;
|
||||||
|
|
||||||
html_focusable(html_context, a);
|
tags_html_focusable(renderer, node);
|
||||||
|
|
||||||
xmlpp::Element *parent_node = image->get_parent();
|
xmlpp::Element *parent_node = image->get_parent();
|
||||||
if (parent_node) {
|
if (parent_node) {
|
||||||
@ -3842,37 +3843,11 @@ tags_html_textarea(struct source_renderer *renderer, void *node, unsigned char *
|
|||||||
int i;
|
int i;
|
||||||
xmlpp::Element *textarea = node;
|
xmlpp::Element *textarea = node;
|
||||||
|
|
||||||
html_focusable(html_context, NULL);
|
tags_html_focusable(renderer, node);
|
||||||
#if 0
|
|
||||||
while (html < eof && (*html == '\n' || *html == '\r')) html++;
|
|
||||||
p = html;
|
|
||||||
while (p < eof && *p != '<') {
|
|
||||||
|
|
||||||
pp:
|
|
||||||
p++;
|
|
||||||
}
|
|
||||||
if (p >= eof) {
|
|
||||||
*end = eof;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
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, node, html_context);
|
fc = tags_init_form_control(FC_TEXTAREA, node, html_context);
|
||||||
if (!fc) return;
|
if (!fc) return;
|
||||||
|
|
||||||
std::string disabled = textarea->get_attribute_value("disabled");
|
|
||||||
if (disabled != "") {
|
|
||||||
fc->mode = FORM_MODE_DISABLED;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (disabled == "") {
|
|
||||||
std::string readonly = textarea->get_attribute_value("readonly");
|
|
||||||
if (readonly != "") {
|
|
||||||
fc->mode = FORM_MODE_READONLY;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string id_value = textarea->get_attribute_value("id");
|
std::string id_value = textarea->get_attribute_value("id");
|
||||||
if (id_value != "") {
|
if (id_value != "") {
|
||||||
fc->id = memacpy(id_value.c_str(), id_value.size());
|
fc->id = memacpy(id_value.c_str(), id_value.size());
|
||||||
@ -3885,30 +3860,15 @@ pp:
|
|||||||
}
|
}
|
||||||
// fc->name = get_attr_val(attr, "name", html_context->doc_cp);
|
// fc->name = get_attr_val(attr, "name", html_context->doc_cp);
|
||||||
|
|
||||||
std::string default_value = textarea->get_attribute_value("default");
|
std::string default_value;
|
||||||
if (default_value != "") {
|
xmlpp::TextNode *textNode = dynamic_cast<xmlpp::TextNode *>(textarea->get_first_child());
|
||||||
|
if (textNode) {
|
||||||
|
default_value = textNode->get_content();
|
||||||
|
}
|
||||||
|
if (true) {
|
||||||
fc->default_value = memacpy(default_value.c_str(), default_value.size());
|
fc->default_value = memacpy(default_value.c_str(), default_value.size());
|
||||||
}
|
}
|
||||||
|
|
||||||
#if 0
|
|
||||||
fc->default_value = convert_string(NULL, html, p - html,
|
|
||||||
html_context->doc_cp,
|
|
||||||
CSM_DEFAULT, NULL, NULL, NULL);
|
|
||||||
for (p = fc->default_value; p && p[0]; p++) {
|
|
||||||
/* FIXME: We don't cope well with entities here. Bugzilla uses
|
|
||||||
* inside of textarea and we fail miserably upon that
|
|
||||||
* one. --pasky */
|
|
||||||
if (p[0] == '\r') {
|
|
||||||
if (p[1] == '\n'
|
|
||||||
|| (p > fc->default_value && p[-1] == '\n')) {
|
|
||||||
memmove(p, p + 1, strlen(p));
|
|
||||||
p--;
|
|
||||||
} else {
|
|
||||||
p[0] = '\n';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
cols = 0;
|
cols = 0;
|
||||||
std::string cols_value = textarea->get_attribute_value("cols");
|
std::string cols_value = textarea->get_attribute_value("cols");
|
||||||
cols = atoi(cols_value.c_str());
|
cols = atoi(cols_value.c_str());
|
||||||
@ -3929,28 +3889,7 @@ pp:
|
|||||||
rows = html_context->options->box.height;
|
rows = html_context->options->box.height;
|
||||||
fc->rows = rows;
|
fc->rows = rows;
|
||||||
html_context->options->needs_height = 1;
|
html_context->options->needs_height = 1;
|
||||||
#if 0
|
|
||||||
wrap_attr = get_attr_val(attr, "wrap", html_context->doc_cp);
|
|
||||||
if (wrap_attr) {
|
|
||||||
if (!c_strcasecmp(wrap_attr, "hard")
|
|
||||||
|| !c_strcasecmp(wrap_attr, "physical")) {
|
|
||||||
fc->wrap = FORM_WRAP_HARD;
|
|
||||||
} else if (!c_strcasecmp(wrap_attr, "soft")
|
|
||||||
|| !c_strcasecmp(wrap_attr, "virtual")) {
|
|
||||||
fc->wrap = FORM_WRAP_SOFT;
|
|
||||||
} else if (!c_strcasecmp(wrap_attr, "none")
|
|
||||||
|| !c_strcasecmp(wrap_attr, "off")) {
|
|
||||||
fc->wrap = FORM_WRAP_NONE;
|
|
||||||
}
|
|
||||||
mem_free(wrap_attr);
|
|
||||||
|
|
||||||
} else if (has_attr(attr, "nowrap", html_context->doc_cp)) {
|
|
||||||
fc->wrap = FORM_WRAP_NONE;
|
|
||||||
|
|
||||||
} else {
|
|
||||||
fc->wrap = FORM_WRAP_SOFT;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
fc->wrap = FORM_WRAP_SOFT;
|
fc->wrap = FORM_WRAP_SOFT;
|
||||||
fc->maxlength = -1;
|
fc->maxlength = -1;
|
||||||
std::string maxlength_value = textarea->get_attribute_value("maxlength");
|
std::string maxlength_value = textarea->get_attribute_value("maxlength");
|
||||||
|
Loading…
Reference in New Issue
Block a user