summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorH. Lehmann <ByteHamster@users.noreply.github.com>2020-05-14 16:52:06 +0200
committerGitHub <noreply@github.com>2020-05-14 16:52:06 +0200
commitc2c6364826ecab642b27375579145d46fa5d3080 (patch)
treeaf0a29c699fbb57f5540e117dd16b6123f587c13
parent571ac6f1d115a7ae36516f06c16d6524e761241b (diff)
parentcea8c3a3985fad247ce1eaca76962b7872b895a1 (diff)
downloadAntennaPod-c2c6364826ecab642b27375579145d46fa5d3080.zip
Merge pull request #4145 from ByteHamster/prefer-itunes-image
Prefer itunes:image
-rw-r--r--core/src/main/java/de/danoeh/antennapod/core/syndication/namespace/NSRSS20.java187
1 files changed, 94 insertions, 93 deletions
diff --git a/core/src/main/java/de/danoeh/antennapod/core/syndication/namespace/NSRSS20.java b/core/src/main/java/de/danoeh/antennapod/core/syndication/namespace/NSRSS20.java
index e391af1b2..3fc0a69d2 100644
--- a/core/src/main/java/de/danoeh/antennapod/core/syndication/namespace/NSRSS20.java
+++ b/core/src/main/java/de/danoeh/antennapod/core/syndication/namespace/NSRSS20.java
@@ -13,16 +13,16 @@ import de.danoeh.antennapod.core.util.DateUtils;
/**
* SAX-Parser for reading RSS-Feeds
- *
+ *
* @author daniel
- *
+ *
*/
public class NSRSS20 extends Namespace {
private static final String TAG = "NSRSS20";
public static final String CHANNEL = "channel";
- public static final String ITEM = "item";
+ public static final String ITEM = "item";
private static final String GUID = "guid";
private static final String TITLE = "title";
private static final String LINK = "link";
@@ -30,118 +30,119 @@ public class NSRSS20 extends Namespace {
private static final String PUBDATE = "pubDate";
private static final String ENCLOSURE = "enclosure";
private static final String IMAGE = "image";
- private static final String URL = "url";
+ private static final String URL = "url";
private static final String LANGUAGE = "language";
private static final String ENC_URL = "url";
private static final String ENC_LEN = "length";
private static final String ENC_TYPE = "type";
- @Override
- public SyndElement handleElementStart(String localName, HandlerState state,
- Attributes attributes) {
- if (ITEM.equals(localName)) {
- state.setCurrentItem(new FeedItem());
- state.getItems().add(state.getCurrentItem());
- state.getCurrentItem().setFeed(state.getFeed());
+ @Override
+ public SyndElement handleElementStart(String localName, HandlerState state,
+ Attributes attributes) {
+ if (ITEM.equals(localName)) {
+ state.setCurrentItem(new FeedItem());
+ state.getItems().add(state.getCurrentItem());
+ state.getCurrentItem().setFeed(state.getFeed());
- } else if (ENCLOSURE.equals(localName)) {
- String type = attributes.getValue(ENC_TYPE);
- String url = attributes.getValue(ENC_URL);
+ } else if (ENCLOSURE.equals(localName)) {
+ String type = attributes.getValue(ENC_TYPE);
+ String url = attributes.getValue(ENC_URL);
- boolean validType = SyndTypeUtils.enclosureTypeValid(type);
- if(!validType) {
+ boolean validType = SyndTypeUtils.enclosureTypeValid(type);
+ if (!validType) {
type = SyndTypeUtils.getMimeTypeFromUrl(url);
validType = SyndTypeUtils.enclosureTypeValid(type);
}
boolean validUrl = !TextUtils.isEmpty(url);
- if (state.getCurrentItem() != null && state.getCurrentItem().getMedia() == null &&
- validType && validUrl) {
- long size = 0;
- try {
- size = Long.parseLong(attributes.getValue(ENC_LEN));
- if(size < 16384) {
- // less than 16kb is suspicious, check manually
- size = 0;
- }
- } catch (NumberFormatException e) {
- Log.d(TAG, "Length attribute could not be parsed.");
- }
- FeedMedia media = new FeedMedia(state.getCurrentItem(), url, size, type);
- state.getCurrentItem().setMedia(media);
- }
+ if (state.getCurrentItem() != null && state.getCurrentItem().getMedia() == null
+ && validType && validUrl) {
+ long size = 0;
+ try {
+ size = Long.parseLong(attributes.getValue(ENC_LEN));
+ if (size < 16384) {
+ // less than 16kb is suspicious, check manually
+ size = 0;
+ }
+ } catch (NumberFormatException e) {
+ Log.d(TAG, "Length attribute could not be parsed.");
+ }
+ FeedMedia media = new FeedMedia(state.getCurrentItem(), url, size, type);
+ state.getCurrentItem().setMedia(media);
+ }
- }
- return new SyndElement(localName, this);
- }
+ }
+ return new SyndElement(localName, this);
+ }
- @Override
- public void handleElementEnd(String localName, HandlerState state) {
- if (ITEM.equals(localName)) {
- if (state.getCurrentItem() != null) {
- FeedItem currentItem = state.getCurrentItem();
- // the title tag is optional in RSS 2.0. The description is used
- // as a
- // title if the item has no title-tag.
- if (currentItem.getTitle() == null) {
- currentItem.setTitle(currentItem.getDescription());
- }
+ @Override
+ public void handleElementEnd(String localName, HandlerState state) {
+ if (ITEM.equals(localName)) {
+ if (state.getCurrentItem() != null) {
+ FeedItem currentItem = state.getCurrentItem();
+ // the title tag is optional in RSS 2.0. The description is used
+ // as a
+ // title if the item has no title-tag.
+ if (currentItem.getTitle() == null) {
+ currentItem.setTitle(currentItem.getDescription());
+ }
if (state.getTempObjects().containsKey(NSITunes.DURATION)) {
if (currentItem.hasMedia()) {
- Integer duration = (Integer) state.getTempObjects().get(NSITunes.DURATION);
- currentItem.getMedia().setDuration(duration);
+ Integer duration = (Integer) state.getTempObjects().get(NSITunes.DURATION);
+ currentItem.getMedia().setDuration(duration);
}
state.getTempObjects().remove(NSITunes.DURATION);
}
- }
- state.setCurrentItem(null);
- } else if (state.getTagstack().size() >= 2 && state.getContentBuf() != null) {
- String content = state.getContentBuf().toString();
- SyndElement topElement = state.getTagstack().peek();
- String top = topElement.getName();
- SyndElement secondElement = state.getSecondTag();
- String second = secondElement.getName();
- String third = null;
- if (state.getTagstack().size() >= 3) {
- third = state.getThirdTag().getName();
- }
- if (GUID.equals(top) && ITEM.equals(second)) {
- // some feed creators include an empty or non-standard guid-element in their feed, which should be ignored
+ }
+ state.setCurrentItem(null);
+ } else if (state.getTagstack().size() >= 2 && state.getContentBuf() != null) {
+ String content = state.getContentBuf().toString();
+ SyndElement topElement = state.getTagstack().peek();
+ String top = topElement.getName();
+ SyndElement secondElement = state.getSecondTag();
+ String second = secondElement.getName();
+ String third = null;
+ if (state.getTagstack().size() >= 3) {
+ third = state.getThirdTag().getName();
+ }
+ if (GUID.equals(top) && ITEM.equals(second)) {
+ // some feed creators include an empty or non-standard guid-element in their feed,
+ // which should be ignored
if (!TextUtils.isEmpty(content) && state.getCurrentItem() != null) {
- state.getCurrentItem().setItemIdentifier(content);
+ state.getCurrentItem().setItemIdentifier(content);
}
- } else if (TITLE.equals(top)) {
- String title = content.trim();
- if (ITEM.equals(second) && state.getCurrentItem() != null) {
- state.getCurrentItem().setTitle(title);
- } else if (CHANNEL.equals(second) && state.getFeed() != null) {
- state.getFeed().setTitle(title);
- }
- } else if (LINK.equals(top)) {
- if (CHANNEL.equals(second) && state.getFeed() != null) {
- state.getFeed().setLink(content);
- } else if (ITEM.equals(second) && state.getCurrentItem() != null) {
- state.getCurrentItem().setLink(content);
- }
- } else if (PUBDATE.equals(top) && ITEM.equals(second) && state.getCurrentItem() != null) {
- state.getCurrentItem().setPubDate(DateUtils.parse(content));
- } else if (URL.equals(top) && IMAGE.equals(second) && CHANNEL.equals(third)) {
- // prefer itunes:image
- if (state.getFeed() != null) {
- state.getFeed().setImageUrl(content);
- }
- } else if (DESCR.equals(localName)) {
- if (CHANNEL.equals(second) && state.getFeed() != null) {
- state.getFeed().setDescription(content);
- } else if (ITEM.equals(second) && state.getCurrentItem() != null) {
- state.getCurrentItem().setDescription(content);
- }
- } else if (LANGUAGE.equals(localName) && state.getFeed() != null) {
- state.getFeed().setLanguage(content.toLowerCase());
- }
- }
- }
+ } else if (TITLE.equals(top)) {
+ String title = content.trim();
+ if (ITEM.equals(second) && state.getCurrentItem() != null) {
+ state.getCurrentItem().setTitle(title);
+ } else if (CHANNEL.equals(second) && state.getFeed() != null) {
+ state.getFeed().setTitle(title);
+ }
+ } else if (LINK.equals(top)) {
+ if (CHANNEL.equals(second) && state.getFeed() != null) {
+ state.getFeed().setLink(content);
+ } else if (ITEM.equals(second) && state.getCurrentItem() != null) {
+ state.getCurrentItem().setLink(content);
+ }
+ } else if (PUBDATE.equals(top) && ITEM.equals(second) && state.getCurrentItem() != null) {
+ state.getCurrentItem().setPubDate(DateUtils.parse(content));
+ } else if (URL.equals(top) && IMAGE.equals(second) && CHANNEL.equals(third)) {
+ // prefer itunes:image
+ if (state.getFeed() != null && state.getFeed().getImageUrl() == null) {
+ state.getFeed().setImageUrl(content);
+ }
+ } else if (DESCR.equals(localName)) {
+ if (CHANNEL.equals(second) && state.getFeed() != null) {
+ state.getFeed().setDescription(content);
+ } else if (ITEM.equals(second) && state.getCurrentItem() != null) {
+ state.getCurrentItem().setDescription(content);
+ }
+ } else if (LANGUAGE.equals(localName) && state.getFeed() != null) {
+ state.getFeed().setLanguage(content.toLowerCase());
+ }
+ }
+ }
}