package be.nikiroo.fanfix.library;
-import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
+import java.net.URL;
import java.util.List;
import be.nikiroo.fanfix.Instance;
import be.nikiroo.fanfix.bundles.UiConfig;
import be.nikiroo.fanfix.data.MetaData;
import be.nikiroo.fanfix.data.Story;
+import be.nikiroo.utils.Image;
import be.nikiroo.utils.Progress;
/**
return lib.getLibraryName();
}
+ @Override
+ public Status getStatus() {
+ return lib.getStatus();
+ }
+
@Override
protected List<MetaData> getMetas(Progress pg) {
if (pg == null) {
if (!isCached(luid)) {
try {
cacheLib.imprt(lib, luid, pgImport);
+ updateInfo(cacheLib.getInfo(luid));
pgImport.done();
- clearCache();
} catch (IOException e) {
- Instance.syserr(e);
+ Instance.getTraceHandler().error(e);
}
pgImport.done();
}
@Override
- public BufferedImage getCover(final String luid) {
+ public Image getCover(final String luid) {
if (isCached(luid)) {
return cacheLib.getCover(luid);
}
}
@Override
- public BufferedImage getSourceCover(String source) {
+ public Image getSourceCover(String source) {
// no cache for the source cover
return lib.getSourceCover(source);
}
}
@Override
- protected void clearCache() {
- metas = null;
- cacheLib.clearCache();
- lib.clearCache();
+ protected void updateInfo(MetaData meta) {
+ 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);
+ }
+ }
+ }
+
+ cacheLib.updateInfo(meta);
+ lib.updateInfo(meta);
+ }
+
+ @Override
+ protected void deleteInfo(String luid) {
+ if (luid == null) {
+ metas = null;
+ } else if (metas != null) {
+ for (int i = 0; i < metas.size(); i++) {
+ if (metas.get(i).getLuid().equals(luid)) {
+ metas.remove(i--);
+ }
+ }
+ }
+
+ cacheLib.deleteInfo(luid);
+ lib.deleteInfo(luid);
}
@Override
public synchronized Story save(Story story, String luid, Progress pg)
throws IOException {
- story = lib.save(story, luid, pg);
- clearCache();
+ Progress pgLib = new Progress();
+ Progress pgCacheLib = new Progress();
+
+ if (pg == null) {
+ pg = new Progress();
+ }
+
+ pg.setMinMax(0, 2);
+ pg.addProgress(pgLib, 1);
+ pg.addProgress(pgCacheLib, 1);
+
+ story = lib.save(story, luid, pgLib);
+ story = cacheLib.save(story, story.getMeta().getLuid(), pgCacheLib);
+
+ updateInfo(story.getMeta());
+
return story;
}
cacheLib.delete(luid);
}
lib.delete(luid);
- clearCache();
+
+ MetaData meta = getInfo(luid);
+ if (meta != null) {
+ metas.remove(meta);
+ }
}
@Override
pg.addProgress(pgCache, 1);
pg.addProgress(pgOrig, 1);
- cacheLib.changeSource(luid, newSource, pgCache);
+ MetaData meta = getInfo(luid);
+ if (meta == null) {
+ throw new IOException("Story not found: " + luid);
+ }
+
+ if (isCached(luid)) {
+ cacheLib.changeSource(luid, newSource, pgCache);
+ }
pgCache.done();
+
lib.changeSource(luid, newSource, pgOrig);
pgOrig.done();
+ meta.setSource(newSource);
pg.done();
}
* in case of I/O error
*/
public void clearFromCache(String luid) throws IOException {
- cacheLib.delete(luid);
- clearCache();
+ if (isCached(luid)) {
+ cacheLib.delete(luid);
+ deleteInfo(luid);
+ }
+ }
+
+ @Override
+ public Story imprt(URL url, Progress pg) throws IOException {
+ if (pg == null) {
+ pg = new Progress();
+ }
+
+ Progress pgImprt = new Progress();
+ Progress pgCache = new Progress();
+ pg.setMinMax(0, 10);
+ pg.addProgress(pgImprt, 7);
+ pg.addProgress(pgCache, 3);
+
+ Story story = lib.imprt(url, pgImprt);
+ cacheLib.save(story, story.getMeta().getLuid(), pgCache);
+
+ updateInfo(story.getMeta());
+
+ pg.done();
+ return story;
}
// All the following methods are only used by Save and Delete in