Use FFMpeg instead of Avconv
[meviz.git] / src / main / java / eu / svjatoslav / meviz / htmlindexer / AbstractIndexer.java
index 762fcad..22ec825 100644 (file)
@@ -1,65 +1,63 @@
 package eu.svjatoslav.meviz.htmlindexer;
 
-import java.io.File;
-import java.io.UnsupportedEncodingException;
-
 import eu.svjatoslav.meviz.htmlindexer.metadata.Dimension;
 import eu.svjatoslav.meviz.htmlindexer.metadata.DirectoryMetadata;
-import eu.svjatoslav.meviz.htmlindexer.metadata.fileTypes.AbstractFile;
-import eu.svjatoslav.meviz.htmlindexer.metadata.fileTypes.DirectoryFile;
-import eu.svjatoslav.meviz.htmlindexer.metadata.fileTypes.GeneralFile;
-import eu.svjatoslav.meviz.htmlindexer.metadata.fileTypes.Picture;
-
-public abstract class AbstractIndexer {
-
-       public void compileHtml(final Layout layout,
-                       final DirectoryMetadata directory)
-                       throws UnsupportedEncodingException {
-
-               for (final AbstractFile file : directory.getFiles())
-                       if (file instanceof GeneralFile) {
-                               final String fileExtension = file.getFileExtension();
-
-                               if ("ogv".equals(fileExtension))
-                                       layout.enlistOgv(file);
-                               else
-                                       layout.enlistFile(file);
-
-                       } else if (file instanceof Picture)
-                               layout.enlistImage(file);
-                       else if (file instanceof DirectoryFile)
-                               layout.enlistDirectory(file);
+import eu.svjatoslav.meviz.htmlindexer.metadata.fileTypes.*;
 
-       }
-
-       public abstract String getDirectoryUrl(final AbstractFile directory,
-                       IndexingContext context);
-
-       public abstract String getParentDirectoryUrl(IndexingContext context);
-
-       public abstract String getThumbnailUrl(Picture picture,
-                       final Dimension desiredDimension, IndexingContext context);
-
-       public static boolean isImage(final String fileExtension) {
-               for (final String ext : Constants.SUPPORTED_IMAGE_EXTENSIONS)
-                       if (ext.equals(fileExtension))
-                               return true;
-               return false;
-       }
-
-       public static boolean isOgv(final String fileExtension) {
-               return fileExtension.equalsIgnoreCase("ogv");
-       }
+import java.io.File;
+import java.io.UnsupportedEncodingException;
 
-       public static boolean shallFileBeIndexed(final File file) {
+import static eu.svjatoslav.meviz.htmlindexer.Constants.SUPPORTED_IMAGE_EXTENSIONS;
+import static eu.svjatoslav.meviz.htmlindexer.Constants.SUPPORTED_VIDEO_EXTENSIONS;
 
-               if (file.getName().startsWith("."))
-                       return false;
-               if (file.getName().startsWith("index"))
-                       if (file.getName().endsWith(".html"))
-                               return false;
+public abstract class AbstractIndexer {
 
-               return true;
-       }
+    public static boolean isImage(final String fileExtension) {
+        for (final String ext : SUPPORTED_IMAGE_EXTENSIONS)
+            if (ext.equals(fileExtension))
+                return true;
+        return false;
+    }
+
+    public static boolean isVideo(final String fileExtension) {
+        for (final String ext : SUPPORTED_VIDEO_EXTENSIONS)
+            if (ext.equals(fileExtension))
+                return true;
+        return false;
+    }
+
+    static boolean shallFileBeIndexed(final File file) {
+
+        if (file.getName().startsWith("."))
+            return false;
+        if (file.getName().startsWith("index"))
+            if (file.getName().endsWith(".html"))
+                return false;
+
+        return true;
+    }
+
+    void compileHtml(final Layout layout,
+                     final DirectoryMetadata directory)
+            throws UnsupportedEncodingException {
+
+        for (final AbstractFile file : directory.getFiles())
+            if (file instanceof GeneralFile) {
+                layout.enlistFile(file, directory);
+            } else if (file instanceof Picture){
+                layout.enlistImage((Picture) file, directory);
+            } else if (file instanceof Video){
+                layout.enlistVideo((Video) file);
+            } else if (file instanceof DirectoryFile)
+                layout.enlistDirectory(file, directory);
+    }
+
+    public abstract String getDirectoryUrl(final AbstractFile directory,
+                                           IndexingContext context);
+
+    public abstract String getParentDirectoryUrl(IndexingContext context);
+
+    public abstract String getThumbnailUrl(Picture picture,
+                                           final Dimension desiredDimension, IndexingContext context);
 
 }