private static ReaderType defaultType = ReaderType.GUI;
private BasicLibrary lib;
+ private MetaData meta;
private Story story;
+ private int chapter;
/**
* Take the default reader type configuration from the config file.
}
}
- public Story getStory() {
+ @Override
+ public synchronized Story getStory(Progress pg) {
+ if (story == null) {
+ story = getLibrary().getStory(meta.getLuid(), pg);
+ }
+
return story;
}
+ @Override
public BasicLibrary getLibrary() {
if (lib == null) {
lib = defaultLibrary;
return lib;
}
- public void setLibrary(LocalLibrary lib) {
+ @Override
+ public void setLibrary(BasicLibrary lib) {
this.lib = lib;
}
- public void setStory(String luid, Progress pg) throws IOException {
- story = getLibrary().getStory(luid, pg);
- if (story == null) {
+ @Override
+ public MetaData getMeta() {
+ return meta;
+ }
+
+ @Override
+ public synchronized void setMeta(MetaData meta) throws IOException {
+ setMeta(meta == null ? null : meta.getLuid()); // must check the library
+ }
+
+ @Override
+ public synchronized void setMeta(String luid) throws IOException {
+ story = null;
+ meta = getLibrary().getInfo(luid);
+
+ if (meta == null) {
throw new IOException("Cannot retrieve story from library: " + luid);
}
}
- public void setStory(URL source, Progress pg) throws IOException {
+ @Override
+ public synchronized void setMeta(URL source, Progress pg)
+ throws IOException {
BasicSupport support = BasicSupport.getSupport(source);
if (support == null) {
throw new IOException("URL not supported: " + source.toString());
throw new IOException(
"Cannot retrieve story from external source: "
+ source.toString());
-
}
+
+ meta = story.getMeta();
+ }
+
+ @Override
+ public int getChapter() {
+ return chapter;
}
- public void read() throws IOException {
- read(-1);
+ @Override
+ public void setChapter(int chapter) {
+ this.chapter = chapter;
}
/**
}
/**
- * The default {@link ReaderType} used when calling
+ * The default {@link Reader.ReaderType} used when calling
* {@link BasicReader#getReader()}.
*
* @return the default type
}
/**
- * The default {@link ReaderType} used when calling
+ * The default {@link Reader.ReaderType} used when calling
* {@link BasicReader#getReader()}.
*
* @param defaultType