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 = new File(file, file.getName());
-
- return super.supports(file.toURI().toURL());
- } catch (URISyntaxException e) {
- } catch (MalformedURLException e) {
- }
-
- return false;
+ File txt = getTxt(url);
+ return txt != null && txt.exists();
}
@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));
+ }
+ } else {
+ Instance.getTraceHandler().error(
+ new IOException("Cannot find the right URL for " + source));
+ }
+
+ 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;
}
}
import java.util.Collections;
import java.util.List;
import java.util.Map.Entry;
+import java.util.SortedMap;
+import java.util.TreeMap;
import org.jsoup.helper.DataUtil;
import org.jsoup.nodes.Element;
protected List<Entry<String, URL>> getChapters(Progress pg) {
List<Entry<String, URL>> urls = new ArrayList<Entry<String, URL>>();
+ String prefix = null; // each chapter starts with this prefix, then a
+ // chapter number (including "x.5"), then name
+
Element doc = getSourceNode();
for (Element li : doc.getElementsByTag("li")) {
Element el = li.getElementsByTag("h4").first();
url += "/";
}
+ if (prefix == null || !prefix.isEmpty()) {
+ StringBuilder possiblePrefix = new StringBuilder(
+ StringUtils.unhtml(a.text()).trim());
+ while (possiblePrefix.length() > 0) {
+ char car = possiblePrefix.charAt(possiblePrefix
+ .length() - 1);
+ boolean punctuation = (car == '.' || car == ' ');
+ boolean digit = (car >= '0' && car <= '9');
+ if (!punctuation && !digit) {
+ break;
+ }
+
+ possiblePrefix.setLength(possiblePrefix
+ .length() - 1);
+ }
+
+ if (prefix == null) {
+ prefix = possiblePrefix.toString();
+ }
+
+ if (!prefix.equalsIgnoreCase(possiblePrefix
+ .toString())) {
+ prefix = ""; // prefix not ok
+ }
+ }
+
urls.add(new AbstractMap.SimpleEntry<String, URL>(
title, new URL(url)));
} catch (Exception e) {
}
}
- // the chapters are in reversed order
- Collections.reverse(urls);
+ if (prefix != null && !prefix.isEmpty()) {
+ try {
+ // We found a prefix, so everything should be sortable
+ SortedMap<Double, Entry<String, URL>> map = new TreeMap<Double, Entry<String, URL>>();
+ for (Entry<String, URL> entry : urls) {
+ String num = entry.getKey().substring(prefix.length() + 1)
+ .trim();
+ String name = "";
+ int pos = num.indexOf(' ');
+ if (pos >= 0) {
+ name = num.substring(pos).trim();
+ num = num.substring(0, pos).trim();
+ }
+
+ if (!name.isEmpty()) {
+ name = "Tome " + num + ": " + name;
+ } else {
+ name = "Tome " + num;
+ }
+
+ double key = Double.parseDouble(num);
+
+ map.put(key, new AbstractMap.SimpleEntry<String, URL>(name,
+ entry.getValue()));
+ }
+ urls = new ArrayList<Entry<String, URL>>(map.values());
+ } catch (NumberFormatException e) {
+ Instance.getTraceHandler()
+ .error(new IOException(
+ "Cannot find a tome number, revert to default sorting",
+ e));
+ // by default, the chapters are in reversed order
+ Collections.reverse(urls);
+ }
+ } else {
+ // by default, the chapters are in reversed order
+ Collections.reverse(urls);
+ }
return urls;
}
}
/**
- * Refresh the {@link URL} by calling {@link MangaFoxNew#openEx(String)}.
+ * Refresh the {@link URL} by calling {@link MangaFox#openEx(String)}.
*
* @param url
* the URL to refresh