import java.io.File;
import java.io.IOException;
import java.net.MalformedURLException;
-import java.net.URISyntaxException;
import java.net.URL;
import be.nikiroo.fanfix.Instance;
@Override
protected boolean supports(URL url) {
try {
- File file = new File(url.toURI());
- if (file.getName().equals("index.html")) {
- file = file.getParentFile();
+ File txt = getTxt(url);
+ if (txt != null) {
+ return super.supports(txt.toURI().toURL());
}
-
- file = new File(file, file.getName());
-
- return super.supports(file.toURI().toURL());
- } catch (URISyntaxException e) {
} catch (MalformedURLException e) {
}
@Override
public URL getCanonicalUrl(URL source) {
+ File txt = getTxt(source);
+ if (txt != null) {
+ try {
+ source = txt.toURI().toURL();
+ } catch (MalformedURLException e) {
+ Instance.getTraceHandler().error(
+ new IOException("Cannot convert the right URL for "
+ + source, e));
+ }
+ }
+ return source;
+ }
+
+ /**
+ * Return the associated TXT source file if it can be found.
+ *
+ * @param source
+ * the source URL
+ *
+ * @return the supported source text file or NULL
+ */
+ private static File getTxt(URL source) {
try {
File fakeFile = new File(source.toURI());
if (fakeFile.getName().equals("index.html")) { // "story/index.html"
fakeFile = new File(fakeFile, fakeFile.getName() + ".txt"); // "story/story.txt"
}
- return fakeFile.toURI().toURL();
+ if (fakeFile.getName().endsWith(".txt")) {
+ return fakeFile;
+ }
} catch (Exception e) {
- Instance.getTraceHandler().error(
- new IOException("Cannot find the right URL for " + source,
- e));
}
- return source;
+ return null;
}
}