Another set of local ownership down.
This commit is contained in:
106
src/form.cc
106
src/form.cc
@ -447,7 +447,6 @@ void Html_tag_open_input(DilloHtml *html, const char *tag, int tagsize)
|
||||
DilloHtmlInputType inp_type;
|
||||
Resource *resource = NULL;
|
||||
Embed *embed = NULL;
|
||||
char *value, *name, *type, *init_str, *placeholder = NULL;
|
||||
const char *attrbuf, *label;
|
||||
bool init_val = false;
|
||||
ResourceFactory *factory;
|
||||
@ -464,61 +463,62 @@ void Html_tag_open_input(DilloHtml *html, const char *tag, int tagsize)
|
||||
factory = HT2LT(html)->getResourceFactory();
|
||||
|
||||
/* Get 'value', 'name' and 'type' */
|
||||
value = a_Html_get_attr_wdef(html, tag, tagsize, "value", NULL);
|
||||
name = a_Html_get_attr_wdef(html, tag, tagsize, "name", NULL);
|
||||
type = a_Html_get_attr_wdef(html, tag, tagsize, "type", "");
|
||||
auto value = a_Html_get_attr_wdef(html, tag, tagsize, "value", NULL);
|
||||
auto name = a_Html_get_attr_wdef(html, tag, tagsize, "name", NULL);
|
||||
auto type = a_Html_get_attr_wdef(html, tag, tagsize, "type", "");
|
||||
std::optional< std::string > init_str;
|
||||
std::optional< std::string > placeholder;
|
||||
|
||||
init_str = NULL;
|
||||
inp_type = DILLO_HTML_INPUT_UNKNOWN;
|
||||
if (!dStrAsciiCasecmp(type, "password")) {
|
||||
if (!dStrAsciiCasecmp(type.value().c_str(), "password")) {
|
||||
inp_type = DILLO_HTML_INPUT_PASSWORD;
|
||||
placeholder = a_Html_get_attr_wdef(html, tag,tagsize,"placeholder",NULL);
|
||||
attrbuf = a_Html_get_attr(html, tag, tagsize, "size");
|
||||
int size = Html_input_get_size(html, attrbuf);
|
||||
resource = factory->createEntryResource (size, true, NULL, placeholder);
|
||||
resource = factory->createEntryResource (size, true, NULL, placeholder.value().c_str());
|
||||
init_str = value;
|
||||
} else if (!dStrAsciiCasecmp(type, "checkbox")) {
|
||||
} else if (!dStrAsciiCasecmp(type.value().c_str(), "checkbox")) {
|
||||
inp_type = DILLO_HTML_INPUT_CHECKBOX;
|
||||
resource = factory->createCheckButtonResource(false);
|
||||
init_val = (a_Html_get_attr(html, tag, tagsize, "checked") != NULL);
|
||||
init_str = (value) ? value : dStrdup("on");
|
||||
} else if (!dStrAsciiCasecmp(type, "radio")) {
|
||||
init_str = value.value_or( "on" );
|
||||
} else if (!dStrAsciiCasecmp(type.value().c_str(), "radio")) {
|
||||
inp_type = DILLO_HTML_INPUT_RADIO;
|
||||
RadioButtonResource *rb_r = NULL;
|
||||
std::shared_ptr input = Html_get_radio_input(html, name);
|
||||
std::shared_ptr input = Html_get_radio_input(html, name ? name.value().c_str() : nullptr);
|
||||
if (input)
|
||||
rb_r = (RadioButtonResource*) input->embed->getResource();
|
||||
resource = factory->createRadioButtonResource(rb_r, false);
|
||||
init_val = (a_Html_get_attr(html, tag, tagsize, "checked") != NULL);
|
||||
init_str = value;
|
||||
} else if (!dStrAsciiCasecmp(type, "hidden")) {
|
||||
} else if (!dStrAsciiCasecmp(type.value().c_str(), "hidden")) {
|
||||
inp_type = DILLO_HTML_INPUT_HIDDEN;
|
||||
init_str = value;
|
||||
int size = Html_input_get_size(html, NULL);
|
||||
resource = factory->createEntryResource(size, false, name, NULL);
|
||||
} else if (!dStrAsciiCasecmp(type, "submit")) {
|
||||
resource = factory->createEntryResource(size, false, name ? name.value().c_str() : nullptr, NULL);
|
||||
} else if (!dStrAsciiCasecmp(type.value().c_str(), "submit")) {
|
||||
inp_type = DILLO_HTML_INPUT_SUBMIT;
|
||||
init_str = (value) ? value : dStrdup("submit");
|
||||
resource = factory->createLabelButtonResource(init_str);
|
||||
} else if (!dStrAsciiCasecmp(type, "reset")) {
|
||||
init_str = value.value_or("submit");
|
||||
resource = factory->createLabelButtonResource(init_str.value().c_str());
|
||||
} else if (!dStrAsciiCasecmp(type.value().c_str(), "reset")) {
|
||||
inp_type = DILLO_HTML_INPUT_RESET;
|
||||
init_str = (value) ? value : dStrdup("Reset");
|
||||
resource = factory->createLabelButtonResource(init_str);
|
||||
} else if (!dStrAsciiCasecmp(type, "image")) {
|
||||
init_str = value.value_or( "Reset" );
|
||||
resource = factory->createLabelButtonResource(init_str.value().c_str());
|
||||
} else if (!dStrAsciiCasecmp(type.value().c_str(), "image")) {
|
||||
if (URL_FLAGS(html->base_url) & URL_SpamSafe) {
|
||||
/* Don't request the image; make a text submit button instead */
|
||||
inp_type = DILLO_HTML_INPUT_SUBMIT;
|
||||
attrbuf = a_Html_get_attr(html, tag, tagsize, "alt");
|
||||
label = attrbuf ? attrbuf : value ? value : name ? name : "Submit";
|
||||
init_str = dStrdup(label);
|
||||
resource = factory->createLabelButtonResource(init_str);
|
||||
label = attrbuf ? attrbuf : value.value_or( name.value_or( "Submit" ) ).c_str();
|
||||
init_str = label;
|
||||
resource = factory->createLabelButtonResource(init_str.value().c_str());
|
||||
} else {
|
||||
inp_type = DILLO_HTML_INPUT_IMAGE;
|
||||
/* use a dw_image widget */
|
||||
embed = Html_input_image(html, tag, tagsize);
|
||||
init_str = value;
|
||||
}
|
||||
} else if (!dStrAsciiCasecmp(type, "file")) {
|
||||
} else if (!dStrAsciiCasecmp(type.value().c_str(), "file")) {
|
||||
bool valid = true;
|
||||
if (html->InFlags & IN_FORM) {
|
||||
DilloHtmlForm *form = html->getCurrentForm();
|
||||
@ -536,14 +536,14 @@ void Html_tag_open_input(DilloHtml *html, const char *tag, int tagsize)
|
||||
}
|
||||
if (valid) {
|
||||
inp_type = DILLO_HTML_INPUT_FILE;
|
||||
init_str = dStrdup("File selector");
|
||||
resource = factory->createLabelButtonResource(init_str);
|
||||
init_str = "File selector";
|
||||
resource = factory->createLabelButtonResource(init_str.value().c_str());
|
||||
}
|
||||
} else if (!dStrAsciiCasecmp(type, "button")) {
|
||||
} else if (!dStrAsciiCasecmp(type.value().c_str(), "button")) {
|
||||
inp_type = DILLO_HTML_INPUT_BUTTON;
|
||||
if (value) {
|
||||
init_str = value;
|
||||
resource = factory->createLabelButtonResource(init_str);
|
||||
resource = factory->createLabelButtonResource(init_str.value().c_str());
|
||||
}
|
||||
} else {
|
||||
/* Text input, which also is the default */
|
||||
@ -551,15 +551,15 @@ void Html_tag_open_input(DilloHtml *html, const char *tag, int tagsize)
|
||||
placeholder = a_Html_get_attr_wdef(html, tag,tagsize,"placeholder",NULL);
|
||||
attrbuf = a_Html_get_attr(html, tag, tagsize, "size");
|
||||
int size = Html_input_get_size(html, attrbuf);
|
||||
resource = factory->createEntryResource(size, false, NULL, placeholder);
|
||||
resource = factory->createEntryResource(size, false, NULL, placeholder.value().c_str());
|
||||
init_str = value;
|
||||
}
|
||||
if (resource)
|
||||
embed = new Embed (resource);
|
||||
|
||||
if (inp_type != DILLO_HTML_INPUT_UNKNOWN) {
|
||||
Html_add_input(html, inp_type, embed, name,
|
||||
(init_str) ? init_str : "", init_val);
|
||||
Html_add_input(html, inp_type, embed, name ? name.value().c_str() : nullptr,
|
||||
init_str.value_or( "" ).c_str(), init_val);
|
||||
}
|
||||
|
||||
if (embed != NULL && inp_type != DILLO_HTML_INPUT_IMAGE &&
|
||||
@ -587,12 +587,6 @@ void Html_tag_open_input(DilloHtml *html, const char *tag, int tagsize)
|
||||
}
|
||||
HT2TB(html)->addWidget (embed, html->backgroundStyle());
|
||||
}
|
||||
dFree(type);
|
||||
dFree(name);
|
||||
if (init_str != value)
|
||||
dFree(init_str);
|
||||
dFree(placeholder);
|
||||
dFree(value);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -754,7 +748,7 @@ void Html_tag_open_select(DilloHtml *html, const char *tag, int tagsize)
|
||||
html->InFlags |= IN_SELECT;
|
||||
html->InFlags &= ~IN_OPTION;
|
||||
|
||||
char *name = a_Html_get_attr_wdef(html, tag, tagsize, "name", NULL);
|
||||
auto name = a_Html_get_attr_wdef(html, tag, tagsize, "name", NULL);
|
||||
ResourceFactory *factory = HT2LT(html)->getResourceFactory ();
|
||||
DilloHtmlInputType type;
|
||||
SelectionResource *res;
|
||||
@ -789,9 +783,8 @@ void Html_tag_open_select(DilloHtml *html, const char *tag, int tagsize)
|
||||
}
|
||||
HT2TB(html)->addWidget (embed, html->backgroundStyle ());
|
||||
|
||||
Html_add_input(html, type, embed, name, NULL, false);
|
||||
Html_add_input(html, type, embed, name.value().c_str(), NULL, false);
|
||||
a_Html_stash_init(html);
|
||||
dFree(name);
|
||||
}
|
||||
|
||||
/*
|
||||
@ -838,16 +831,16 @@ void Html_tag_open_optgroup(DilloHtml *html, const char *tag, int tagsize)
|
||||
if (input &&
|
||||
(input->type == DILLO_HTML_INPUT_SELECT ||
|
||||
input->type == DILLO_HTML_INPUT_SEL_LIST)) {
|
||||
char *label = a_Html_get_attr_wdef(html, tag, tagsize, "label", NULL);
|
||||
auto label = a_Html_get_attr_wdef(html, tag, tagsize, "label", NULL);
|
||||
bool enabled = (a_Html_get_attr(html, tag, tagsize, "disabled") == NULL);
|
||||
|
||||
if (!label) {
|
||||
BUG_MSG("<optgroup> requires label attribute.");
|
||||
label = dStrdup("");
|
||||
label = "";
|
||||
}
|
||||
|
||||
DilloHtmlOptgroup *opt =
|
||||
new DilloHtmlOptgroup (label, enabled);
|
||||
new DilloHtmlOptgroup (dStrdup(label.value().c_str()), enabled);
|
||||
|
||||
input->select->addOpt(opt);
|
||||
}
|
||||
@ -891,13 +884,13 @@ void Html_tag_open_option(DilloHtml *html, const char *tag, int tagsize)
|
||||
if (input &&
|
||||
(input->type == DILLO_HTML_INPUT_SELECT ||
|
||||
input->type == DILLO_HTML_INPUT_SEL_LIST)) {
|
||||
char *value = a_Html_get_attr_wdef(html, tag, tagsize, "value", NULL);
|
||||
char *label = a_Html_get_attr_wdef(html, tag, tagsize, "label", NULL);
|
||||
auto value = a_Html_get_attr_wdef(html, tag, tagsize, "value", NULL);
|
||||
auto label = a_Html_get_attr_wdef(html, tag, tagsize, "label", NULL);
|
||||
bool selected = (a_Html_get_attr(html, tag, tagsize,"selected") != NULL);
|
||||
bool enabled = (a_Html_get_attr(html, tag, tagsize, "disabled") == NULL);
|
||||
|
||||
DilloHtmlOption *option =
|
||||
new DilloHtmlOption (value, label, selected, enabled);
|
||||
new DilloHtmlOption (dStrdup( value.value().c_str() ), dStrdup( label.value().c_str() ), selected, enabled);
|
||||
|
||||
input->select->addOpt(option);
|
||||
}
|
||||
@ -923,30 +916,28 @@ void Html_tag_open_button(DilloHtml *html, const char *tag, int tagsize)
|
||||
* bit simpler. May be changed in the future.
|
||||
*/
|
||||
DilloHtmlInputType inp_type;
|
||||
char *type;
|
||||
|
||||
assert((html->InFlags & (IN_BUTTON | IN_SELECT | IN_TEXTAREA)) == 0);
|
||||
|
||||
html->InFlags |= IN_BUTTON;
|
||||
type = a_Html_get_attr_wdef(html, tag, tagsize, "type", "");
|
||||
auto type = a_Html_get_attr_wdef(html, tag, tagsize, "type", "");
|
||||
|
||||
if (!dStrAsciiCasecmp(type, "button")) {
|
||||
if (!dStrAsciiCasecmp(type.value().c_str(), "button")) {
|
||||
inp_type = DILLO_HTML_INPUT_BUTTON;
|
||||
} else if (!dStrAsciiCasecmp(type, "reset")) {
|
||||
} else if (!dStrAsciiCasecmp(type.value().c_str(), "reset")) {
|
||||
inp_type = DILLO_HTML_INPUT_BUTTON_RESET;
|
||||
} else if (!dStrAsciiCasecmp(type, "submit") || !*type) {
|
||||
} else if (!dStrAsciiCasecmp(type.value().c_str(), "submit") || type.value().empty()) {
|
||||
/* submit button is the default */
|
||||
inp_type = DILLO_HTML_INPUT_BUTTON_SUBMIT;
|
||||
} else {
|
||||
inp_type = DILLO_HTML_INPUT_UNKNOWN;
|
||||
BUG_MSG("<button> type unknown: '%s'.", type);
|
||||
BUG_MSG("<button> type unknown: '%s'.", type.value().c_str());
|
||||
}
|
||||
|
||||
if (inp_type != DILLO_HTML_INPUT_UNKNOWN) {
|
||||
/* Render the button */
|
||||
Embed *embed;
|
||||
const char *attrbuf;
|
||||
char *name, *value;
|
||||
|
||||
if (prefs.show_tooltip &&
|
||||
(attrbuf = a_Html_get_attr(html, tag, tagsize, "title"))) {
|
||||
@ -970,14 +961,11 @@ void Html_tag_open_button(DilloHtml *html, const char *tag, int tagsize)
|
||||
|
||||
S_TOP(html)->textblock = html->dw = page_p;
|
||||
|
||||
value = a_Html_get_attr_wdef(html, tag, tagsize, "value", NULL);
|
||||
name = a_Html_get_attr_wdef(html, tag, tagsize, "name", NULL);
|
||||
auto value = a_Html_get_attr_wdef(html, tag, tagsize, "value", NULL);
|
||||
auto name = a_Html_get_attr_wdef(html, tag, tagsize, "name", NULL);
|
||||
|
||||
Html_add_input(html, inp_type, embed, name, value, FALSE);
|
||||
dFree(name);
|
||||
dFree(value);
|
||||
Html_add_input(html, inp_type, embed, name.value().c_str(), value.value().c_str(), FALSE);
|
||||
}
|
||||
dFree(type);
|
||||
}
|
||||
|
||||
/**
|
||||
|
Reference in New Issue
Block a user