From b118d0c449931045c85c424556684d6ae4854531 Mon Sep 17 00:00:00 2001 From: cinap_lenrek Date: Wed, 21 Sep 2011 17:56:42 +0200 Subject: [PATCH] html2ms: fix broken closetag handling --- sys/src/cmd/html2ms.c | 65 ++++++++++++++++++++++++++----------------- 1 file changed, 40 insertions(+), 25 deletions(-) diff --git a/sys/src/cmd/html2ms.c b/sys/src/cmd/html2ms.c index 77cb85d75..9caabe636 100644 --- a/sys/src/cmd/html2ms.c +++ b/sys/src/cmd/html2ms.c @@ -285,23 +285,6 @@ tabletag(Tag *tag) return tabletag(tag->up); } -void -reparent(Text *text, Tag *tag, Tag *up) -{ - Tag *old; - - old = tag->up; - while(old != up){ - if(old->close){ - debugtag(old, "reparent close"); - old->close(text, old); - old->close = nil; - } - old = old->up; - } - tag->up = up; -} - void dumprows(Text *text, Table *s, Table *e) { @@ -510,6 +493,7 @@ struct { "head", ongarbage, "hr", onbr, "i", oni, + "img", onmeta, "kbd", ontt, "li", onli, "link", onmeta, @@ -782,14 +766,33 @@ gotstyle(Tag *tag, char *style, char *val) return 1; } +void +reparent(Text *text, Tag *tag, Tag *up) +{ + Tag *old; + + old = tag->up; + while(old != up){ + debugtag(old, "reparent"); + if(old->close){ + old->close(text, old); + old->close = nil; + } + old = old->up; + } + tag->up = up; +} + + void parsetext(Text *text, Tag *tag) { int hidden, c; - Tag t, *p; + Tag t, *up; Rune r; if(tag){ + up = tag->up; debugtag(tag, "open"); for(c = 0; c < nelem(ontag); c++){ if(cistrcmp(tag->tag, ontag[c].tag) == 0){ @@ -798,8 +801,10 @@ parsetext(Text *text, Tag *tag) } } hidden = getattr(tag, "hidden") || gotstyle(tag, "display", "none"); - } else + } else { + up = nil; hidden = 0; + } if(tag == nil || tag->closing == 0){ while((c = Bgetc(&in)) > 0){ if(c == '<'){ @@ -809,14 +814,20 @@ parsetext(Text *text, Tag *tag) if(t.opening){ t.up = tag; parsetext(text, &t); - if(t.up != tag) + if(t.up != tag){ + debugtag(tag, "skip"); + up = t.up; break; + } + debugtag(tag, "back"); } else if(t.closing){ - p = tag; - while(p && cistrcmp(p->tag, t.tag)) - p = p->up; - if(p) + up = tag; + while(up && cistrcmp(up->tag, t.tag)) + up = up->up; + if(up){ + up = up->up; break; + } } } continue; @@ -856,8 +867,12 @@ parsetext(Text *text, Tag *tag) } if(tag){ debugtag(tag, "close"); - if(tag->close) + if(tag->close){ tag->close(text, tag); + tag->close = nil; + } + if(up) + tag->up = up; } }