@Override
public Image getSourceCover(String source) {
- // no cache for the source cover
+ Image custom = getCustomSourceCover(source);
+ if (custom != null) {
+ return custom;
+ }
+
+ Image cached = cacheLib.getSourceCover(source);
+ if (cached != null) {
+ return cached;
+ }
+
return lib.getSourceCover(source);
}
+ @Override
+ public Image getCustomSourceCover(String source) {
+ Image custom = cacheLib.getCustomSourceCover(source);
+ if (custom == null) {
+ custom = lib.getCustomSourceCover(source);
+ if (custom != null) {
+ cacheLib.setSourceCover(source, custom);
+ }
+ }
+
+ return custom;
+ }
+
@Override
public void setSourceCover(String source, String luid) {
lib.setSourceCover(source, luid);
- cacheLib.setSourceCover(source, getSourceCover(source));
+ cacheLib.setSourceCover(source, getCover(luid));
}
@Override
protected void updateInfo(MetaData meta) {
- if (meta != null) {
+ if (meta != null && metas != null) {
for (int i = 0; i < metas.size(); i++) {
if (metas.get(i).getLuid().equals(meta.getLuid())) {
metas.set(i, meta);
}
@Override
- protected void deleteInfo(String luid) {
+ protected void invalidateInfo(String luid) {
if (luid == null) {
metas = null;
} else if (metas != null) {
}
}
- cacheLib.deleteInfo(luid);
- lib.deleteInfo(luid);
+ cacheLib.invalidateInfo(luid);
+ lib.invalidateInfo(luid);
}
@Override
}
@Override
- public synchronized void changeSource(String luid, String newSource,
- Progress pg) throws IOException {
+ protected synchronized void changeSTA(String luid, String newSource,
+ String newTitle, String newAuthor, Progress pg) throws IOException {
if (pg == null) {
pg = new Progress();
}
}
if (isCached(luid)) {
- cacheLib.changeSource(luid, newSource, pgCache);
+ cacheLib.changeSTA(luid, newSource, newTitle, newAuthor, pgCache);
}
pgCache.done();
- lib.changeSource(luid, newSource, pgOrig);
+ lib.changeSTA(luid, newSource, newTitle, newAuthor, pgOrig);
pgOrig.done();
meta.setSource(newSource);
+ meta.setTitle(newTitle);
+ meta.setAuthor(newAuthor);
pg.done();
}
/**
* Clear the {@link Story} from the cache.
+ * <p>
+ * The next time we try to retrieve the {@link Story}, it may be required to
+ * cache it again.
*
* @param luid
* the story to clear
public void clearFromCache(String luid) throws IOException {
if (isCached(luid)) {
cacheLib.delete(luid);
- deleteInfo(luid);
}
}