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 */