Merge branch 'subtree'
[nikiroo-utils.git] / src / be / nikiroo / fanfix / supported / InfoText.java
index 786e771a40c2f8c6cee016c7f0aeb14c2bd365f8..2af8c7e2f4880139540aa6f7f4e4895fd6e4742d 100644 (file)
@@ -2,8 +2,6 @@ package be.nikiroo.fanfix.supported;
 
 import java.io.File;
 import java.io.IOException;
-import java.io.InputStream;
-import java.net.URISyntaxException;
 import java.net.URL;
 
 import be.nikiroo.fanfix.data.MetaData;
@@ -18,45 +16,13 @@ import be.nikiroo.fanfix.data.MetaData;
  * @author niki
  */
 class InfoText extends Text {
-       @Override
-       public String getSourceName() {
-               return "info-text";
+       protected File getInfoFile() {
+               return new File(assureNoTxt(getSourceFile()).getPath() + ".info");
        }
 
        @Override
-       protected MetaData getMeta(URL source, InputStream in) throws IOException {
-               try {
-                       File sourceFile = new File(source.toURI());
-                       sourceFile = assureNoTxt(sourceFile);
-
-                       MetaData meta = InfoReader.readMeta(new File(sourceFile.getPath()
-                                       + ".info"), true);
-
-                       // Some old .info files don't have those now required fields...
-                       String test = meta.getTitle() == null ? "" : meta.getTitle();
-                       test += meta.getAuthor() == null ? "" : meta.getAuthor();
-                       test += meta.getDate() == null ? "" : meta.getDate();
-                       test += meta.getUrl() == null ? "" : meta.getUrl();
-                       if (test.isEmpty()) {
-                               MetaData superMeta = super.getMeta(source, reset(in));
-                               if (meta.getTitle() == null || meta.getTitle().isEmpty()) {
-                                       meta.setTitle(superMeta.getTitle());
-                               }
-                               if (meta.getAuthor() == null || meta.getAuthor().isEmpty()) {
-                                       meta.setAuthor(superMeta.getAuthor());
-                               }
-                               if (meta.getDate() == null || meta.getDate().isEmpty()) {
-                                       meta.setDate(superMeta.getDate());
-                               }
-                               if (meta.getUrl() == null || meta.getUrl().isEmpty()) {
-                                       meta.setUrl(superMeta.getUrl());
-                               }
-                       }
-
-                       return meta;
-               } catch (URISyntaxException e) {
-                       throw new IOException("Cannot parse URL to file: " + source, e);
-               }
+       protected MetaData getMeta() throws IOException {
+               return InfoReader.readMeta(getInfoFile(), true);
        }
 
        @Override