Browse Source

Merge pull request #10514 from Mataniko/rss-enclosure-type

Download RSS "enclosure" element if no proper MIME type is found
adaptive-webui-19844
Vladimir Golovnev 6 years ago committed by GitHub
parent
commit
af7d8f6a43
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 6
      src/base/rss/private/rss_parser.cpp

6
src/base/rss/private/rss_parser.cpp

@ -588,6 +588,7 @@ void Parser::parse_impl(const QByteArray &feedData) @@ -588,6 +588,7 @@ void Parser::parse_impl(const QByteArray &feedData)
void Parser::parseRssArticle(QXmlStreamReader &xml)
{
QVariantHash article;
QString altTorrentUrl;
while (!xml.atEnd()) {
xml.readNext();
@ -603,6 +604,8 @@ void Parser::parseRssArticle(QXmlStreamReader &xml) @@ -603,6 +604,8 @@ void Parser::parseRssArticle(QXmlStreamReader &xml)
else if (name == QLatin1String("enclosure")) {
if (xml.attributes().value("type") == QLatin1String("application/x-bittorrent"))
article[Article::KeyTorrentURL] = xml.attributes().value(QLatin1String("url")).toString();
else if (xml.attributes().value("type").isEmpty())
altTorrentUrl = xml.attributes().value(QLatin1String("url")).toString();
}
else if (name == QLatin1String("link")) {
const QString text {xml.readElementText().trimmed()};
@ -629,6 +632,9 @@ void Parser::parseRssArticle(QXmlStreamReader &xml) @@ -629,6 +632,9 @@ void Parser::parseRssArticle(QXmlStreamReader &xml)
}
}
if (article[Article::KeyTorrentURL].toString().isEmpty())
article[Article::KeyTorrentURL] = altTorrentUrl;
m_result.articles.prepend(article);
}

Loading…
Cancel
Save