Made sure that the downloaded-attribute of FeedFile does not reach an inconsistent state

(downloaded=false and file_url != null)
This commit is contained in:
daniel oeh 2014-04-27 16:35:25 +02:00
parent c881b7982c
commit 8769d29cef
3 changed files with 87 additions and 67 deletions

View File

@ -181,7 +181,7 @@ public abstract class OnlineFeedViewActivity extends ActionBarActivity {
} }
private void parseFeed() { private void parseFeed() {
if (feed == null || feed.getFile_url() == null) { if (feed == null || feed.getFile_url() == null && feed.isDownloaded()) {
throw new IllegalStateException( throw new IllegalStateException(
"feed must be non-null and downloaded when parseFeed is called"); "feed must be non-null and downloaded when parseFeed is called");
} }

View File

@ -118,7 +118,7 @@ public class FeedlistAdapter extends BaseAdapter {
holder.inProgressEpisodesLabel.setVisibility(View.INVISIBLE); holder.inProgressEpisodesLabel.setVisibility(View.INVISIBLE);
} }
} }
final String imageUrl = (feed.getImage() != null) ? feed.getImage() final String imageUrl = (feed.getImage() != null && feed.getImage().isDownloaded()) ? feed.getImage()
.getFile_url() : null; .getFile_url() : null;
imageLoader.loadThumbnailBitmap( imageLoader.loadThumbnailBitmap(
feed.getImage(), feed.getImage(),

View File

@ -2,84 +2,104 @@ package de.danoeh.antennapod.feed;
import java.io.File; import java.io.File;
/** Represents a component of a Feed that has to be downloaded */ /**
* Represents a component of a Feed that has to be downloaded
*/
public abstract class FeedFile extends FeedComponent { public abstract class FeedFile extends FeedComponent {
protected String file_url; protected String file_url;
protected String download_url; protected String download_url;
protected boolean downloaded; protected boolean downloaded;
public FeedFile(String file_url, String download_url, boolean downloaded) { /**
super(); * Creates a new FeedFile object.
this.file_url = file_url; *
this.download_url = download_url; * @param file_url The location of the FeedFile. If this is null, the downloaded-attribute
this.downloaded = downloaded; * will automatically be set to false.
} * @param download_url The location where the FeedFile can be downloaded.
* @param downloaded true if the FeedFile has been downloaded, false otherwise. This parameter
* will automatically be interpreted as false if the file_url is null.
*/
public FeedFile(String file_url, String download_url, boolean downloaded) {
super();
this.file_url = file_url;
this.download_url = download_url;
this.downloaded = (file_url != null) && downloaded;
}
public FeedFile() { public FeedFile() {
this(null, null, false); this(null, null, false);
} }
public abstract int getTypeAsInt(); public abstract int getTypeAsInt();
/** /**
* Update this FeedFile's attributes with the attributes from another * Update this FeedFile's attributes with the attributes from another
* FeedFile. This method should only update attributes which where read from * FeedFile. This method should only update attributes which where read from
* the feed. * the feed.
*/ */
public void updateFromOther(FeedFile other) { public void updateFromOther(FeedFile other) {
super.updateFromOther(other); super.updateFromOther(other);
this.download_url = other.download_url; this.download_url = other.download_url;
} }
/** /**
* Compare's this FeedFile's attribute values with another FeedFile's * Compare's this FeedFile's attribute values with another FeedFile's
* attribute values. This method will only compare attributes which were * attribute values. This method will only compare attributes which were
* read from the feed. * read from the feed.
* *
* @return true if attribute values are different, false otherwise * @return true if attribute values are different, false otherwise
*/ */
public boolean compareWithOther(FeedFile other) { public boolean compareWithOther(FeedFile other) {
if (super.compareWithOther(other)) { if (super.compareWithOther(other)) {
return true; return true;
} }
if (!download_url.equals(other.download_url)) { if (!download_url.equals(other.download_url)) {
return true; return true;
} }
return false; return false;
} }
/** Returns true if the file exists at file_url. */
public boolean fileExists() {
if (file_url == null) {
return false;
} else {
File f = new File(file_url);
return f.exists();
}
}
public String getFile_url() { /**
return file_url; * Returns true if the file exists at file_url.
} */
public boolean fileExists() {
if (file_url == null) {
return false;
} else {
File f = new File(file_url);
return f.exists();
}
}
public void setFile_url(String file_url) { public String getFile_url() {
this.file_url = file_url; return file_url;
} }
public String getDownload_url() { /**
return download_url; * Changes the file_url of this FeedFile. Setting this value to
} * null will also set the downloaded-attribute to false.
*/
public void setFile_url(String file_url) {
this.file_url = file_url;
if (file_url == null) {
downloaded = false;
}
}
public void setDownload_url(String download_url) { public String getDownload_url() {
this.download_url = download_url; return download_url;
} }
public boolean isDownloaded() { public void setDownload_url(String download_url) {
return downloaded; this.download_url = download_url;
} }
public void setDownloaded(boolean downloaded) { public boolean isDownloaded() {
this.downloaded = downloaded; return downloaded;
} }
public void setDownloaded(boolean downloaded) {
this.downloaded = downloaded;
}
} }