mirror of
https://codeberg.org/grunfink/snac2.git
synced 2024-11-22 13:25:04 +00:00
Backport from xs.
This commit is contained in:
parent
a658e5d1c7
commit
5f047d46c0
3 changed files with 28 additions and 13 deletions
2
html.c
2
html.c
|
@ -1000,7 +1000,7 @@ static xs_html *html_button(char *clss, char *label, char *hint)
|
|||
xs *c = xs_fmt("snac-btn-%s", clss);
|
||||
|
||||
/* use an NULL tag to separate non-css-classed buttons from one another */
|
||||
return xs_html_tag(NULL,
|
||||
return xs_html_container(
|
||||
xs_html_sctag("input",
|
||||
xs_html_attr("type", "submit"),
|
||||
xs_html_attr("name", "action"),
|
||||
|
|
29
xs_html.h
29
xs_html.h
|
@ -21,6 +21,9 @@ xs_html *_xs_html_tag(char *tag, xs_html *var[]);
|
|||
xs_html *_xs_html_sctag(char *tag, xs_html *var[]);
|
||||
#define xs_html_sctag(tag, ...) _xs_html_sctag(tag, (xs_html *[]) { __VA_ARGS__, NULL })
|
||||
|
||||
xs_html *_xs_html_container(xs_html *var[]);
|
||||
#define xs_html_container(...) _xs_html_container((xs_html *[]) { __VA_ARGS__, NULL })
|
||||
|
||||
void xs_html_render_f(xs_html *h, FILE *f);
|
||||
xs_str *xs_html_render_s(xs_html *tag, char *prefix);
|
||||
#define xs_html_render(tag) xs_html_render_s(tag, NULL)
|
||||
|
@ -31,6 +34,7 @@ xs_str *xs_html_render_s(xs_html *tag, char *prefix);
|
|||
typedef enum {
|
||||
XS_HTML_TAG,
|
||||
XS_HTML_SCTAG,
|
||||
XS_HTML_CONTAINER,
|
||||
XS_HTML_ATTR,
|
||||
XS_HTML_TEXT
|
||||
} xs_html_type;
|
||||
|
@ -75,9 +79,7 @@ xs_str *xs_html_encode(char *str)
|
|||
|
||||
/* insert the escaped char */
|
||||
char tmp[8];
|
||||
snprintf(tmp, sizeof(tmp), "&#%d;", *q);
|
||||
|
||||
z = strlen(tmp);
|
||||
z = snprintf(tmp, sizeof(tmp), "&#%d;", *q);
|
||||
s = xs_insert_m(s, o, tmp, z);
|
||||
o += z;
|
||||
|
||||
|
@ -192,6 +194,12 @@ xs_html *_xs_html_sctag(char *tag, xs_html *var[])
|
|||
}
|
||||
|
||||
|
||||
xs_html *_xs_html_container(xs_html *var[])
|
||||
{
|
||||
return _xs_html_tag_t(XS_HTML_CONTAINER, NULL, var);
|
||||
}
|
||||
|
||||
|
||||
void xs_html_render_f(xs_html *h, FILE *f)
|
||||
/* renders the tag and its subtags into a file */
|
||||
{
|
||||
|
@ -200,7 +208,6 @@ void xs_html_render_f(xs_html *h, FILE *f)
|
|||
switch (h->type) {
|
||||
case XS_HTML_TAG:
|
||||
case XS_HTML_SCTAG:
|
||||
if (h->content)
|
||||
fprintf(f, "<%s", h->content);
|
||||
|
||||
/* render the attributes */
|
||||
|
@ -213,11 +220,9 @@ void xs_html_render_f(xs_html *h, FILE *f)
|
|||
|
||||
if (h->type == XS_HTML_SCTAG) {
|
||||
/* self-closing tags should not have subtags */
|
||||
if (h->content)
|
||||
fprintf(f, "/>");
|
||||
}
|
||||
else {
|
||||
if (h->content)
|
||||
fprintf(f, ">");
|
||||
|
||||
/* render the subtags */
|
||||
|
@ -228,12 +233,22 @@ void xs_html_render_f(xs_html *h, FILE *f)
|
|||
st = nst;
|
||||
}
|
||||
|
||||
if (h->content)
|
||||
fprintf(f, "</%s>", h->content);
|
||||
}
|
||||
|
||||
break;
|
||||
|
||||
case XS_HTML_CONTAINER:
|
||||
/* render the subtags and nothing more */
|
||||
st = h->f_tag;
|
||||
while (st) {
|
||||
xs_html *nst = st->next;
|
||||
xs_html_render_f(st, f);
|
||||
st = nst;
|
||||
}
|
||||
|
||||
break;
|
||||
|
||||
case XS_HTML_ATTR:
|
||||
fprintf(f, " %s", h->content);
|
||||
break;
|
||||
|
|
|
@ -1 +1 @@
|
|||
/* b26300d01136fad22ee774d20a7da5b299f30d13 2023-12-03T11:38:09+01:00 */
|
||||
/* f27e092c79ca6e2e96f83e0d4c3dbc73d737ffaa 2023-12-03T17:12:47+01:00 */
|
||||
|
|
Loading…
Reference in a new issue