Some quick fixes
[fanfix.git] / src / be / nikiroo / fanfix / Instance.java
index 5c198ee73d9580f50773bfd3fcffe92c9751a3ab..71f42dd74103a68efc9cc6e78296d6d6ed0491ca 100644 (file)
@@ -20,15 +20,41 @@ public class Instance {
        private static Library lib;
        private static boolean debug;
        private static File coverDir;
+       private static File readerTmp;
 
        static {
+               // Most of the rest is dependant upon this:
                config = new ConfigBundle();
 
-               // config dependent:
                trans = new StringIdBundle(getLang());
                lib = new Library(getFile(Config.LIBRARY_DIR));
                debug = Instance.getConfig().getBoolean(Config.DEBUG_ERR, false);
                coverDir = getFile(Config.DEFAULT_COVERS_DIR);
+               File tmp = getFile(Config.CACHE_DIR);
+               readerTmp = getFile(Config.CACHE_DIR_LOCAL_READER);
+
+               if (checkEnv("NOUTF")) {
+                       trans.setUnicode(false);
+               }
+
+               if (checkEnv("DEBUG")) {
+                       debug = true;
+               }
+
+               if (tmp == null || readerTmp == null) {
+                       String tmpDir = System.getProperty("java.io.tmpdir");
+                       if (tmpDir != null) {
+                               if (tmp == null) {
+                                       tmp = new File(tmpDir, "fanfic-tmp");
+                               }
+                               if (readerTmp == null) {
+                                       readerTmp = new File(tmpDir, "fanfic-reader");
+                               }
+                       } else {
+                               syserr(new IOException(
+                                               "The system does not have a default temporary directory"));
+                       }
+               }
 
                if (coverDir != null && !coverDir.exists()) {
                        syserr(new IOException(
@@ -36,17 +62,6 @@ public class Instance {
                                                        + coverDir));
                        coverDir = null;
                }
-               //
-
-               String noutf = System.getenv("NOUTF");
-               if (noutf != null) {
-                       noutf = noutf.trim().toLowerCase();
-                       if ("yes".equals(noutf) || "true".equals(noutf)
-                                       || "on".equals(noutf) || "1".equals(noutf)
-                                       || "y".equals(noutf)) {
-                               trans.setUnicode(false);
-                       }
-               }
 
                String configDir = System.getenv("CONFIG_DIR");
                if (configDir != null) {
@@ -71,22 +86,11 @@ public class Instance {
                }
 
                try {
-                       File tmp = getFile(Config.CACHE_DIR);
                        String ua = config.getString(Config.USER_AGENT);
                        int hours = config.getInteger(Config.CACHE_MAX_TIME_CHANGING, -1);
                        int hoursLarge = config
                                        .getInteger(Config.CACHE_MAX_TIME_STABLE, -1);
 
-                       if (tmp == null) {
-                               String tmpDir = System.getProperty("java.io.tmpdir");
-                               if (tmpDir != null) {
-                                       tmp = new File(tmpDir, "fanfic-tmp");
-                               } else {
-                                       syserr(new IOException(
-                                                       "The system does not have a default temporary directory"));
-                               }
-                       }
-
                        cache = new Cache(tmp, ua, hours, hoursLarge);
                } catch (IOException e) {
                        syserr(new IOException(
@@ -139,6 +143,15 @@ public class Instance {
                return coverDir;
        }
 
+       /**
+        * Return the directory where to store temporary files for the local reader.
+        * 
+        * @return the directory
+        */
+       public static File getReaderDir() {
+               return readerTmp;
+       }
+
        /**
         * Report an error to the user
         * 
@@ -192,4 +205,26 @@ public class Instance {
 
                return lang;
        }
+
+       /**
+        * Check that the given environment variable is "enabled".
+        * 
+        * @param key
+        *            the variable to check
+        * 
+        * @return TRUE if it is
+        */
+       private static boolean checkEnv(String key) {
+               String value = System.getenv(key);
+               if (value != null) {
+                       value = value.trim().toLowerCase();
+                       if ("yes".equals(value) || "true".equals(value)
+                                       || "on".equals(value) || "1".equals(value)
+                                       || "y".equals(value)) {
+                               return true;
+                       }
+               }
+
+               return false;
+       }
 }