New FimFiction.net API downloading:
[fanfix.git] / src / be / nikiroo / fanfix / Instance.java
index 28849b325510ccec2b17b813de99d8fef9036650..9b6448ecb1cb89d490dfe6642d404069382a8868 100644 (file)
@@ -9,6 +9,8 @@ import be.nikiroo.fanfix.bundles.ConfigBundle;
 import be.nikiroo.fanfix.bundles.StringIdBundle;
 import be.nikiroo.fanfix.bundles.UiConfig;
 import be.nikiroo.fanfix.bundles.UiConfigBundle;
+import be.nikiroo.fanfix.library.BasicLibrary;
+import be.nikiroo.fanfix.library.LocalLibrary;
 import be.nikiroo.fanfix.output.BasicOutput.OutputType;
 import be.nikiroo.utils.IOUtils;
 import be.nikiroo.utils.resources.Bundles;
@@ -23,10 +25,11 @@ public class Instance {
        private static UiConfigBundle uiconfig;
        private static StringIdBundle trans;
        private static Cache cache;
-       private static Library lib;
+       private static LocalLibrary lib;
        private static boolean debug;
        private static File coverDir;
        private static File readerTmp;
+       private static File remoteDir;
        private static String configDir;
 
        static {
@@ -73,7 +76,7 @@ public class Instance {
                uiconfig = new UiConfigBundle();
                trans = new StringIdBundle(getLang());
                try {
-                       lib = new Library(getFile(Config.LIBRARY_DIR),
+                       lib = new LocalLibrary(getFile(Config.LIBRARY_DIR),
                                        OutputType.INFO_TEXT, OutputType.CBZ);
                } catch (Exception e) {
                        syserr(new IOException("Cannot create library for directory: "
@@ -84,6 +87,7 @@ public class Instance {
                coverDir = getFile(Config.DEFAULT_COVERS_DIR);
                File tmp = getFile(Config.CACHE_DIR);
                readerTmp = getFile(UiConfig.CACHE_DIR_LOCAL_READER);
+               remoteDir = new File(getFile(Config.LIBRARY_DIR), "remote");
 
                if (checkEnv("NOUTF")) {
                        trans.setUnicode(false);
@@ -159,11 +163,11 @@ public class Instance {
        }
 
        /**
-        * Get the (unique) {@link Library} for the program.
+        * Get the (unique) {@link LocalLibrary} for the program.
         * 
-        * @return the {@link Library}
+        * @return the {@link LocalLibrary}
         */
-       public static Library getLibrary() {
+       public static BasicLibrary getLibrary() {
                return lib;
        }
 
@@ -185,6 +189,25 @@ public class Instance {
                return readerTmp;
        }
 
+       /**
+        * Return the directory where to store temporary files for the remote
+        * {@link LocalLibrary}.
+        * 
+        * @param host
+        *            the remote for this host
+        * 
+        * @return the directory
+        */
+       public static File getRemoteDir(String host) {
+               remoteDir.mkdirs();
+
+               if (host != null) {
+                       return new File(remoteDir, host);
+               }
+
+               return remoteDir;
+       }
+
        /**
         * Check if we need to check that a new version of Fanfix is available.
         * 
@@ -239,6 +262,15 @@ public class Instance {
                }
        }
 
+       /**
+        * The program is in DEBUG mode (more verbose).
+        * 
+        * @return TRUE if it is
+        */
+       public static boolean isDebug() {
+               return debug;
+       }
+
        /**
         * Return a path, but support the special $HOME variable.
         *