commit 584c14eb5dd080bb1c0435f48b67e10e88e34a77
parent bad5f90cb1b0a06c0315cf3408b3ed4c2023dc21
Author: Hiltjo Posthuma <hiltjo@codemadness.org>
Date:   Sat,  3 Jan 2015 21:45:02 +0100
clear some fields if they are set previously (some feeds define multiple date field)
Diffstat:
1 file changed, 8 insertions(+), 1 deletion(-)
diff --git a/sfeed.c b/sfeed.c
@@ -505,7 +505,6 @@ xml_handler_attr(XMLParser *p, const char *tag, size_t taglen,
 	}
 
 	if(ctx.item.feedtype == FeedTypeAtom) {
-		/*if(ctx.tagid == AtomTagContent || ctx.tagid == AtomTagSummary) {*/
 		if(ISCONTENTTAG(ctx)) {
 			if(isattr(name, namelen, STRP("type")) &&
 			   (isattr(value, valuelen, STRP("xhtml")) ||
@@ -591,11 +590,15 @@ xml_handler_start_element(XMLParser *p, const char *name, size_t namelen)
 			if(!(ctx.tagid == RSSTagDescription && ctx.item.content.len)) {
 				ctx.iscontenttag = 1;
 				ctx.field = &ctx.item.content;
+				return;
 			}
 		} else if(ctx.tagid == RSSTagGuid)
 			ctx.field = &ctx.item.id;
 		else if(ctx.tagid == RSSTagAuthor || ctx.tagid == RSSTagDccreator)
 			ctx.field = &ctx.item.author;
+		/* clear field */
+		if(ctx.field)
+			string_clear(ctx.field);
 	} else if(ctx.item.feedtype == FeedTypeAtom) {
 		if(ctx.tagid == AtomTagPublished || ctx.tagid == AtomTagUpdated)
 			ctx.field = &ctx.item.timestamp;
@@ -609,6 +612,7 @@ xml_handler_start_element(XMLParser *p, const char *name, size_t namelen)
 			if(!(ctx.tagid == AtomTagSummary && ctx.item.content.len)) {
 				ctx.iscontenttag = 1;
 				ctx.field = &ctx.item.content;
+				return;
 			}
 		} else if(ctx.tagid == AtomTagId)
 			ctx.field = &ctx.item.id;
@@ -616,6 +620,9 @@ xml_handler_start_element(XMLParser *p, const char *name, size_t namelen)
 			ctx.field = &ctx.item.link;
 		else if(ctx.tagid == AtomTagAuthor)
 			ctx.field = &ctx.item.author;
+		/* clear field */
+		if(ctx.field)
+			string_clear(ctx.field);
 	}
 }