commit b17aa7d5229c90724ca1b8c87f4ed62f46b6cb3f
parent 5f047d46c0ad2dd2f1cf83f359ac1ad779cb67f8
Author: default <nobody@localhost>
Date: Sun, 3 Dec 2023 23:47:25 +0100
Backport from xs.
Diffstat:
2 files changed, 24 insertions(+), 35 deletions(-)
diff --git a/xs_html.h b/xs_html.h
@@ -203,61 +203,50 @@ xs_html *_xs_html_container(xs_html *var[])
void xs_html_render_f(xs_html *h, FILE *f)
/* renders the tag and its subtags into a file */
{
- xs_html *st;
+ if (h == NULL)
+ return;
switch (h->type) {
case XS_HTML_TAG:
- case XS_HTML_SCTAG:
fprintf(f, "<%s", h->content);
- /* render the attributes */
- st = h->f_attr;
- while (st) {
- xs_html *nst = st->next;
- xs_html_render_f(st, f);
- st = nst;
- }
+ /* attributes */
+ xs_html_render_f(h->f_attr, f);
- if (h->type == XS_HTML_SCTAG) {
- /* self-closing tags should not have subtags */
- fprintf(f, "/>");
- }
- else {
- fprintf(f, ">");
+ fprintf(f, ">");
- /* render the subtags */
- st = h->f_tag;
- while (st) {
- xs_html *nst = st->next;
- xs_html_render_f(st, f);
- st = nst;
- }
+ /* sub-tags */
+ xs_html_render_f(h->f_tag, f);
- fprintf(f, "</%s>", h->content);
- }
+ fprintf(f, "</%s>", h->content);
+ break;
+
+ case XS_HTML_SCTAG:
+ fprintf(f, "<%s", h->content);
+ /* attributes */
+ xs_html_render_f(h->f_attr, f);
+
+ fprintf(f, "/>");
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;
- }
-
+ /* sub-tags */
+ xs_html_render_f(h->f_tag, f);
break;
case XS_HTML_ATTR:
- fprintf(f, " %s", h->content);
- break;
+ fprintf(f, " ");
+ /* fallthrough */
case XS_HTML_TEXT:
fprintf(f, "%s", h->content);
break;
}
+ /* follow the chain */
+ xs_html_render_f(h->next, f);
+
xs_free(h->content);
xs_free(h);
}
diff --git a/xs_version.h b/xs_version.h
@@ -1 +1 @@
-/* f27e092c79ca6e2e96f83e0d4c3dbc73d737ffaa 2023-12-03T17:12:47+01:00 */
+/* 1b21549513460489504a2caa4127607c914a10da 2023-12-03T23:45:32+01:00 */