OSDN Git Service

Set to version 0.97
[neighbornote/NeighborNote.git] / src / cx / fbn / nevernote / Global.java
index d9da6fb..ded5f8a 100644 (file)
@@ -29,6 +29,8 @@ import java.util.Calendar;
 import java.util.HashMap;\r
 import java.util.List;\r
 \r
+import org.apache.commons.lang.StringEscapeUtils;\r
+\r
 import com.evernote.edam.type.Accounting;\r
 import com.evernote.edam.type.PrivilegeLevel;\r
 import com.evernote.edam.type.User;\r
@@ -36,6 +38,7 @@ import com.evernote.edam.type.UserAttributes;
 import com.swabunga.spell.engine.Configuration;\r
 import com.trolltech.qt.core.QByteArray;\r
 import com.trolltech.qt.core.QSettings;\r
+import com.trolltech.qt.core.QSize;\r
 import com.trolltech.qt.gui.QPalette;\r
 \r
 import cx.fbn.nevernote.config.FileManager;\r
@@ -45,36 +48,35 @@ import cx.fbn.nevernote.gui.ContainsAttributeFilterTable;
 import cx.fbn.nevernote.gui.DateAttributeFilterTable;\r
 import cx.fbn.nevernote.gui.ShortcutKeys;\r
 import cx.fbn.nevernote.utilities.ApplicationLogger;\r
+import cx.fbn.nevernote.utilities.Pair;\r
 \r
 public class Global {\r
-       public static String version = "0.91";\r
+       public static String version = "0.97";\r
+       public static String[] validVersions = {"0.97", "0.96"};\r
     public static String username = ""; \r
     public static String password = "";     \r
     \r
 \r
     public static final int mainThreadId=0;\r
-    \r
     public static final int syncThreadId=1;\r
-    \r
     public static final int tagCounterThreadId=2;\r
-    \r
     public static final int trashCounterThreadId=3;   // This should always be the highest thread ID\r
-\r
     public static final int indexThreadId=4;           // Thread for indexing words\r
-\r
     public static final int saveThreadId=5;    // Thread used for processing data to saving content\r
-\r
     public static final int notebookCounterThreadId=6;   // Notebook Thread\r
-\r
     public static final int indexThread03Id=7;   // unused\r
-\r
     public static final int indexThread04Id=8;   // unused\r
-    \r
     public static final int dbThreadId=9;   // This should always be the highest thread ID\r
     \r
     \r
-    public static HashMap<String,String> passwordSafe = new HashMap<String, String>();\r
-    public static List<String> passwordRemember = new ArrayList<String>();\r
+    public static int View_List_Wide = 1;\r
+    public static int View_List_Narrow = 2;\r
+    public static QSize smallThumbnailSize = new QSize(100,75);\r
+    public static QSize largeThumbnailSize = new QSize(300,225);\r
+//    public static boolean listView = true;\r
+    \r
+    public static HashMap<String,Pair<String,String>> passwordSafe = new HashMap<String, Pair<String,String>>();\r
+    public static List<Pair<String,String>> passwordRemember = new ArrayList<Pair<String,String>>();\r
     public static String currentNotebookGuid;\r
     public static User user; \r
     public static long authTimeRemaining;\r
@@ -96,7 +98,8 @@ public class Global {
     public static int noteTableSourceUrlPosition = 7;\r
     public static int noteTableSubjectDatePosition = 8;\r
     public static int noteTableSynchronizedPosition = 9;\r
-    public static int noteTableColumnCount = 10;\r
+    public static int noteTableThumbnailPosition = 10;\r
+    public static int noteTableColumnCount = 11;\r
     public static Integer cryptCounter = 0;\r
     \r
     public static int minimumWordCount = 2;\r
@@ -113,6 +116,8 @@ public class Global {
        public static String attachmentNameDelimeter = "------";\r
        \r
        public static String    databaseName = new String("NeverNote");\r
+       public static String    indexDatabaseName = new String("Index");\r
+       public static String    resourceDatabaseName = new String("Resources");\r
        public static DateAttributeFilterTable createdSinceFilter;\r
        public static DateAttributeFilterTable createdBeforeFilter;\r
        public static DateAttributeFilterTable changedSinceFilter;\r
@@ -129,6 +134,7 @@ public class Global {
        public static boolean mimicEvernoteInterface;\r
        public static HashMap<String,String> resourceMap;\r
        public static String cipherPassword = "";\r
+       public static String databaseCache = "16384";\r
        \r
        static Calendar startTraceTime;\r
        static Calendar intervalTraceTime;\r
@@ -163,6 +169,8 @@ public class Global {
                        shortcutKeys = new ShortcutKeys();\r
                        mimicEvernoteInterface = getMimicEvernoteInterface();\r
                        resourceMap = new HashMap<String,String>();\r
+                       \r
+                       databaseCache = getDatabaseCacheSize();\r
                                \r
     }\r
 \r
@@ -325,11 +333,18 @@ public class Global {
     }\r
     public static boolean showTrayIcon() {\r
                settings.beginGroup("General");\r
-               String max = (String) settings.value("showTrayIcon", "true");\r
-               settings.endGroup();\r
-               if (!max.equalsIgnoreCase("true"))\r
-                       return false;\r
-               return true;    \r
+               try {\r
+                       String max = (String) settings.value("showTrayIcon", "true");\r
+                       settings.endGroup();\r
+                       if (!max.equalsIgnoreCase("true"))\r
+                               return false;\r
+                       else\r
+                               return true;    \r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("showTrayIcon", true);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
     }\r
     public static void setShowTrayIcon(boolean val) {\r
                settings.beginGroup("General");\r
@@ -340,12 +355,18 @@ public class Global {
                settings.endGroup();\r
     }\r
     public static boolean wasWindowMaximized() {\r
-               settings.beginGroup("General");\r
-               String max = (String) settings.value("isMaximized", "true");\r
-               settings.endGroup();\r
-               if (!max.equalsIgnoreCase("true"))\r
-                       return false;\r
-               return true;    \r
+       try {\r
+                       settings.beginGroup("General");\r
+                       String max = (String) settings.value("isMaximized", "true");\r
+                       settings.endGroup();\r
+                       if (!max.equalsIgnoreCase("true"))\r
+                               return false;\r
+                       return true;    \r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("isMaximized", true);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
     }\r
     public static void saveWindowMaximized(boolean isMax) {\r
                settings.beginGroup("General");\r
@@ -370,19 +391,29 @@ public class Global {
                settings.endGroup();\r
     }\r
     public static void setSortColumn(int i) {\r
+       int view = Global.getListView();\r
                settings.beginGroup("General");\r
-               settings.setValue("sortColumn", i);\r
+       if (view == Global.View_List_Wide)\r
+               settings.setValue("sortColumn", i);\r
+       else\r
+               settings.setValue("sortColumn-Narrow", i);\r
                settings.endGroup();\r
     }\r
     public static int getSortColumn() {;\r
+    String key;\r
+       if (Global.getListView() == Global.View_List_Wide)\r
+               key = "sortColumn";\r
+       else\r
+               key = "sortColumn-Narrow";\r
+\r
        settings.beginGroup("General");\r
        int order;      \r
        try {\r
-               String val  = settings.value("sortColumn", new Integer(0)).toString();\r
+               String val  = settings.value(key, new Integer(0)).toString();\r
                order = new Integer(val.trim());\r
        } catch (Exception e) {\r
                try {\r
-                       order = (Integer)settings.value("sortColumn", 0);\r
+                       order = (Integer)settings.value(key, 0);\r
                } catch (Exception e1) {\r
                    order = 0;\r
                }\r
@@ -392,19 +423,30 @@ public class Global {
        return order;\r
     }\r
     public static void setSortOrder(int i) {\r
+       int view = Global.getListView();\r
                settings.beginGroup("General");\r
-               settings.setValue("sortOrder", i);\r
+       if (view == Global.View_List_Wide)\r
+               settings.setValue("sortOrder", i);\r
+       else\r
+               settings.setValue("sortOrder-Narrow", i);\r
                settings.endGroup();\r
     }\r
     public static int getSortOrder() {\r
+       int view = Global.getListView();\r
                settings.beginGroup("General");\r
+               String key;\r
+       if (view == Global.View_List_Wide)\r
+               key = "sortOrder";\r
+               else\r
+                       key = "sortOrder-Narrow";\r
+\r
                int order;      \r
                try {\r
-                       String val  = settings.value("sortOrder", new Integer(0)).toString();\r
+                       String val  = settings.value(key, new Integer(0)).toString();\r
                        order = new Integer(val.trim());\r
                } catch (Exception e) {\r
                        try {\r
-                               order = (Integer)settings.value("sortOrder", 0);\r
+                               order = (Integer)settings.value(key, 0);\r
                        } catch (Exception e1) {\r
                            order = 0;\r
                        }\r
@@ -414,13 +456,19 @@ public class Global {
                return order;\r
     }\r
     public static boolean automaticLogin() {\r
-               settings.beginGroup("General");\r
-               String text = (String)settings.value("automaticLogin", "false");\r
-               settings.endGroup();\r
-               if (text.equalsIgnoreCase("true"))\r
-                       return true;\r
-               else\r
-                       return false;           \r
+       try {\r
+               settings.beginGroup("General");\r
+               String text = (String)settings.value("automaticLogin", "false");\r
+               settings.endGroup();\r
+               if (text.equalsIgnoreCase("true"))\r
+                       return true;\r
+               else\r
+                       return false;           \r
+       } catch (java.lang.ClassCastException e) {\r
+               Boolean value = (Boolean) settings.value("automaticLogin", false);\r
+               settings.endGroup();\r
+               return value;\r
+       }\r
     }\r
     public static void setAutomaticLogin(boolean val) {\r
                settings.beginGroup("General");\r
@@ -431,13 +479,19 @@ public class Global {
                settings.endGroup();\r
     }\r
     public static boolean rememberPassword() {\r
-               settings.beginGroup("General");\r
-               String text = (String)settings.value("rememberPassword", "false");\r
-               settings.endGroup();\r
-               if (text.equalsIgnoreCase("true"))\r
-                       return true;\r
-               else\r
-                       return false;           \r
+       try {\r
+                       settings.beginGroup("General");\r
+                       String text = (String)settings.value("rememberPassword", "false");\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
+                       else\r
+                               return false;   \r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("rememberPassword", false);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
     }\r
     public static void setRememberPassword(boolean val) {\r
                settings.beginGroup("General");\r
@@ -463,20 +517,26 @@ public class Global {
                        noteStoreUrlBase = "sandbox.evernote.com/edam/note/";\r
                }\r
                settings.endGroup();\r
-               if (isPremium())\r
+//             if (isPremium())\r
                        noteStoreUrlBase = "https://" + noteStoreUrlBase;\r
-               else\r
-                       noteStoreUrlBase = "http://" + noteStoreUrlBase;\r
+//             else\r
+//                     noteStoreUrlBase = "http://" + noteStoreUrlBase;\r
                return text;\r
     }\r
     public static boolean disableUploads() {\r
-               settings.beginGroup("General");\r
-               String text = (String)settings.value("disableUploads", "false");\r
-               settings.endGroup();\r
-               if (text.equalsIgnoreCase("true"))\r
-                       return true;\r
-               else\r
-                       return false;\r
+       settings.beginGroup("General");\r
+       try {\r
+               String text = (String)settings.value("disableUploads", "false");\r
+               settings.endGroup();\r
+               if (text.equalsIgnoreCase("true"))\r
+                       return true;\r
+               else\r
+                       return false;\r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("disableUploads", false);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
     }\r
     public static void setDisableUploads(boolean val) {\r
                settings.beginGroup("General");\r
@@ -489,12 +549,18 @@ public class Global {
     }\r
     public static boolean pdfPreview() {\r
                settings.beginGroup("General");\r
-               String text = (String)settings.value("pdfPreview", "true");\r
-               settings.endGroup();\r
-               if (text.equalsIgnoreCase("true"))\r
-                       return true;\r
-               else\r
-                       return false;\r
+               try {\r
+                       String text = (String)settings.value("pdfPreview", "true");\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
+                       else\r
+                               return false;\r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("pdfPreview", true);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
     }\r
     public static void setPdfPreview(boolean val) {\r
                settings.beginGroup("General");\r
@@ -506,12 +572,18 @@ public class Global {
     }\r
     public static boolean newNoteWithSelectedTags() {\r
                settings.beginGroup("General");\r
-               String text = (String)settings.value("newNoteWithSelectedTags", "false");\r
-               settings.endGroup();\r
-               if (text.equalsIgnoreCase("true"))\r
-                       return true;\r
-               else\r
-                       return false;\r
+               try {\r
+                       String text = (String)settings.value("newNoteWithSelectedTags", "false");\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
+                       else\r
+                               return false;\r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("newNoteWithSelectedTags", false);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
     }\r
     public static void setNewNoteWithSelectedTags(boolean val) {\r
                settings.beginGroup("General");\r
@@ -521,28 +593,6 @@ public class Global {
                        settings.setValue("newNoteWithSelectedTags", "false");\r
                settings.endGroup();\r
     }\r
-    public static void setMinimumWordLength(int len) {\r
-               settings.beginGroup("General");\r
-               settings.setValue("minimumWordLength", len);\r
-               settings.endGroup();            \r
-    }\r
-    public static int getMinimumWordLength() {\r
-               settings.beginGroup("General");\r
-               Integer len = 4;\r
-               try {\r
-                       String val  = (String)settings.value("minimumWordLength", "4");\r
-                       len = new Integer(val);\r
-               } catch (Exception e) {\r
-                       try {\r
-                               len = (Integer)settings.value("minimumWordLength", 4);\r
-                       } catch (Exception e1) {\r
-                               len = 4;\r
-                       }\r
-               }\r
-               settings.endGroup();\r
-               return len;\r
-               \r
-    }\r
     public static void setRecognitionWeight(int len) {\r
                settings.beginGroup("General");\r
                settings.setValue("recognitionWeight", len);\r
@@ -552,7 +602,7 @@ public class Global {
                settings.beginGroup("General");\r
                Integer len;\r
                try {\r
-                       len = (Integer)settings.value("recognitionWeight", 80);\r
+                       len = (Integer)settings.value("recognitionWeight", 30);\r
                } catch (Exception e) {\r
                        len = 80;\r
                }\r
@@ -599,12 +649,19 @@ public class Global {
                settings.endGroup();            \r
     }\r
     public static void setColumnWidth(String col, int width) {\r
-               settings.beginGroup("ColumnWidths");\r
-               settings.setValue(col, width);\r
-               settings.endGroup();\r
-    }\r
+       if (Global.getListView() == Global.View_List_Wide)\r
+               settings.beginGroup("ColumnWidths");\r
+       else \r
+               settings.beginGroup("ColumnWidths-Narrow");\r
+               settings.setValue(col, width);\r
+               settings.endGroup();\r
+       }\r
     public static int getColumnWidth(String col) {\r
-               settings.beginGroup("ColumnWidths");\r
+       int view = Global.getListView();\r
+       if (view == Global.View_List_Wide)\r
+               settings.beginGroup("ColumnWidths");\r
+       else\r
+               settings.beginGroup("ColumnWidths-Narrow");\r
                Integer width;\r
                try {\r
                        String val  = (String)settings.value(col, "0");\r
@@ -620,12 +677,18 @@ public class Global {
                return width;\r
     }\r
     public static void setColumnPosition(String col, int width) {\r
-               settings.beginGroup("ColumnPosition");\r
+       if (Global.getListView() == Global.View_List_Wide)\r
+               settings.beginGroup("ColumnPosition");\r
+       else\r
+               settings.beginGroup("ColumnPosition-Narrow");\r
                settings.setValue(col, width);\r
                settings.endGroup();\r
     }\r
     public static int getColumnPosition(String col) {\r
-               settings.beginGroup("ColumnPosition");\r
+       if (Global.getListView() == Global.View_List_Wide)\r
+               settings.beginGroup("ColumnPosition");\r
+       else\r
+               settings.beginGroup("ColumnPosition-Narrow");\r
                Integer width;\r
                try {\r
                        String val  = (String)settings.value(col, "-1");\r
@@ -642,12 +705,18 @@ public class Global {
     }\r
     public static boolean verifyDelete() {\r
                settings.beginGroup("General");\r
-               String text = (String)settings.value("verifyDelete", "true");\r
-               settings.endGroup();\r
-               if (text.equalsIgnoreCase("true"))\r
-                       return true;\r
-               else\r
-                       return false;           \r
+               try {\r
+                       String text = (String)settings.value("verifyDelete", "true");\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
+                       else\r
+                               return false;\r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("verifyDelete", true);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
     }\r
     public static void setVerifyDelete(boolean val) {\r
                settings.beginGroup("General");\r
@@ -659,12 +728,18 @@ public class Global {
     }\r
     public static boolean startMinimized() {\r
                settings.beginGroup("General");\r
-               String text = (String)settings.value("startMinimized", "false");\r
-               settings.endGroup();\r
-               if (text.equalsIgnoreCase("true"))\r
-                       return true;\r
-               else\r
-                       return false;           \r
+               try {\r
+                       String text = (String)settings.value("startMinimized", "false");\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
+                       else\r
+                               return false;\r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("startMinimized", false);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
     }\r
     public static void setStartMinimized(boolean val) {\r
                settings.beginGroup("General");\r
@@ -676,13 +751,19 @@ public class Global {
     }\r
     public static boolean synchronizeDeletedContent() {\r
                settings.beginGroup("General");\r
-               String text = (String)settings.value("syncDeletedContent", "false");\r
-               settings.endGroup();\r
-               if (text.equalsIgnoreCase("true"))\r
-                       return true;\r
-               else\r
-                       return false;           \r
-    }\r
+               try {\r
+                       String text = (String)settings.value("syncDeletedContent", "false");\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
+                       else\r
+                               return false;\r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("syncDeletedContent", false);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
+    }  \r
     public static void setSynchronizeDeletedContent(boolean val) {\r
                settings.beginGroup("General");\r
                if (val)\r
@@ -693,15 +774,24 @@ public class Global {
     }\r
     public static boolean isWindowVisible(String window) {\r
                settings.beginGroup("WindowsVisible");\r
-               String defaultValue = "true";\r
-               if (window.equalsIgnoreCase("noteInformation"))\r
-                       defaultValue = "false";\r
-               String text = (String)settings.value(window, defaultValue);\r
-               settings.endGroup();\r
-               if (text.equalsIgnoreCase("true"))\r
-                       return true;\r
+               try {\r
+                       String defaultValue = "true";\r
+                       if (window.equalsIgnoreCase("noteInformation"))\r
+                               defaultValue = "false";\r
+                       String text = (String)settings.value(window, defaultValue);\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
                else\r
                        return false;           \r
+               } catch (java.lang.ClassCastException e) {\r
+                       boolean defaultValue = true;\r
+                       if (window.equalsIgnoreCase("noteInformation"))\r
+                               defaultValue = false;\r
+                       Boolean value = (Boolean) settings.value("showTrayIcon", defaultValue);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
     }\r
     public static void saveWindowVisible(String window, boolean val) {\r
                settings.beginGroup("WindowsVisible");\r
@@ -712,16 +802,41 @@ public class Global {
                settings.endGroup();\r
     }\r
     public static boolean isColumnVisible(String window) {\r
-               settings.beginGroup("ColumnsVisible");\r
-               String text = (String)settings.value(window, "true");\r
-               settings.endGroup();\r
-               if (text.equalsIgnoreCase("true"))\r
-                       return true;\r
-               else\r
-                       return false;   \r
+       String defaultValue = "true";\r
+       int view = Global.getListView();\r
+       if (Global.getListView() == Global.View_List_Wide)\r
+               settings.beginGroup("ColumnsVisible");\r
+       else\r
+               settings.beginGroup("ColumnsVisible-Narrow"); \r
+               if (window.equalsIgnoreCase("thumbnail") && view == Global.View_List_Wide)\r
+                       defaultValue = "false";\r
+               if (window.equalsIgnoreCase("thumbnail"))\r
+                       defaultValue = "false";\r
+               if (window.equalsIgnoreCase("Guid"))\r
+                       defaultValue = "false";\r
+               try {\r
+                       String text = (String)settings.value(window, defaultValue);\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
+                       else\r
+                               return false;\r
+               } catch (java.lang.ClassCastException e) {\r
+                       boolean defBool = false;\r
+                       if (window.equalsIgnoreCase("true"))\r
+                               defBool = true;\r
+                       else\r
+                               defBool = false;\r
+                       Boolean value = (Boolean) settings.value(window, defBool);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
     }\r
     public static void saveColumnVisible(String column, boolean val) {\r
-               settings.beginGroup("ColumnsVisible");\r
+       if (Global.getListView() == Global.View_List_Wide)\r
+               settings.beginGroup("ColumnsVisible");\r
+       else\r
+               settings.beginGroup("ColumnsVisible-Narrow");                   \r
                if (val)\r
                        settings.setValue(column, "true");\r
                else\r
@@ -730,12 +845,18 @@ public class Global {
     }\r
     public static boolean isEditorButtonVisible(String window) {\r
                settings.beginGroup("EditorButtonsVisible");\r
-               String text = (String)settings.value(window, "true");\r
-               settings.endGroup();\r
-               if (text.equalsIgnoreCase("true"))\r
-                       return true;\r
-               else\r
-                       return false;   \r
+               try {\r
+                       String text = (String)settings.value(window, "true");\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
+                       else\r
+                               return false;\r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value(window, true);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
     }\r
     public static void saveEditorButtonsVisible(String column, boolean val) {\r
                settings.beginGroup("EditorButtonsVisible");\r
@@ -746,13 +867,19 @@ public class Global {
                settings.endGroup();\r
     }\r
     public static boolean enableCarriageReturnFix() {\r
-               settings.beginGroup("Debug");\r
-               String text = (String)settings.value("enableCarriageReturnFix", "false");\r
-               settings.endGroup();\r
-               if (text.equalsIgnoreCase("true"))\r
-                       return true;\r
-               else\r
-                       return false;   \r
+       try {\r
+               settings.beginGroup("Debug");\r
+               String text = (String)settings.value("enableCarriageReturnFix", "false");\r
+               settings.endGroup();\r
+               if (text.equalsIgnoreCase("true"))\r
+                       return true;\r
+               else\r
+                       return false;\r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("enableCarriageReturnFix", false);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
     }\r
     public static void saveCarriageReturnFix(boolean val) {\r
                settings.beginGroup("Debug");\r
@@ -826,15 +953,21 @@ public class Global {
                settings.endGroup();\r
                return threads;\r
     }\r
-\r
+    \r
     public static boolean getMimicEvernoteInterface() {\r
                settings.beginGroup("General");\r
-               String text = (String)settings.value("mimicEvernoteInterface", "true");\r
-               settings.endGroup();\r
-               if (text.equalsIgnoreCase("true"))\r
-                       return true;\r
-               else\r
-                       return false;\r
+               try {\r
+                       String text = (String)settings.value("mimicEvernoteInterface", "true");\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
+                       else\r
+                               return false;\r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("mimicEvernoteInterface", true);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
     }\r
     public static void setMimicEvernoteInterface(boolean value) {\r
        settings.beginGroup("General");\r
@@ -847,12 +980,18 @@ public class Global {
     \r
     public static boolean synchronizeOnClose() {\r
                settings.beginGroup("General");\r
-               String text = (String)settings.value("synchronizeOnClose", "false");\r
-               settings.endGroup();\r
-               if (text.equalsIgnoreCase("true"))\r
-                       return true;\r
-               else\r
-                       return false;\r
+               try {\r
+                       String text = (String)settings.value("synchronizeOnClose", "false");\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
+                       else\r
+                               return false;\r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("synchronizeOnClose", false);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
     }\r
     public static void setSynchronizeOnClose(boolean val) {\r
                settings.beginGroup("General");\r
@@ -881,6 +1020,22 @@ public class Global {
                        val = "jdbc:h2:"+Global.getFileManager().getDbDirPath(Global.databaseName);\r
                return val;\r
     }\r
+    public static String getIndexDatabaseUrl() {\r
+               settings.beginGroup("General");\r
+               String val  = (String)settings.value("DatabaseURL", "");\r
+               settings.endGroup();\r
+               if (val.equals(""))\r
+                       val = "jdbc:h2:"+Global.getFileManager().getDbDirPath(Global.indexDatabaseName);\r
+               return val;\r
+    }\r
+    public static String getResourceDatabaseUrl() {\r
+               settings.beginGroup("General");\r
+               String val  = (String)settings.value("DatabaseURL", "");\r
+               settings.endGroup();\r
+               if (val.equals(""))\r
+                       val = "jdbc:h2:"+Global.getFileManager().getDbDirPath(Global.resourceDatabaseName);\r
+               return val;\r
+    }\r
     public static void setDatabaseUrl(String value) {\r
                settings.beginGroup("General");\r
                settings.setValue("DatabaseURL", value);\r
@@ -911,12 +1066,18 @@ public class Global {
     }\r
     public static boolean useStandardPalette() {\r
                settings.beginGroup("General");\r
-               String text = (String)settings.value("standardPalette", "true");\r
-               settings.endGroup();\r
-               if (text.equalsIgnoreCase("true"))\r
-                       return true;\r
-               else\r
-                       return false;\r
+               try {\r
+                       String text = (String)settings.value("standardPalette", "true");\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
+                       else\r
+                               return false;\r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("standardPalette", true);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
     }\r
     public static void setStandardPalette(boolean val) {\r
                settings.beginGroup("General");\r
@@ -951,25 +1112,39 @@ public class Global {
     }\r
     \r
     public static void saveState(String name, QByteArray state) {\r
+       int view = Global.getListView();\r
+       if (view == Global.View_List_Narrow)\r
+               name = name +"Narrow";\r
                settings.beginGroup("SaveState");\r
                settings.setValue(name, state);\r
                settings.endGroup();\r
     }\r
     \r
     public static QByteArray restoreState(String name) {\r
+       int view = Global.getListView();\r
+       if (view == Global.View_List_Narrow)\r
+               name = name +"Narrow";\r
                settings.beginGroup("SaveState");\r
                QByteArray state = (QByteArray)settings.value(name);\r
                settings.endGroup();\r
                return state;\r
     }\r
     public static void saveGeometry(String name, QByteArray state) {\r
-               settings.beginGroup("SaveGeometry");\r
+       int view = Global.getListView();\r
+       if (view == Global.View_List_Narrow)\r
+               settings.beginGroup("SaveGeometryNarrow");\r
+       else\r
+               settings.beginGroup("SaveGeometry");\r
                settings.setValue(name, state);\r
                settings.endGroup();\r
     }\r
     \r
     public static QByteArray restoreGeometry(String name) {\r
-               settings.beginGroup("SaveGeometry");\r
+       int view = Global.getListView();\r
+       if (view == Global.View_List_Narrow)\r
+               settings.beginGroup("SaveGeometryNarrow");\r
+       else\r
+               settings.beginGroup("SaveGeometry");\r
                QByteArray state = (QByteArray)settings.value(name);\r
                settings.endGroup();\r
                return state;\r
@@ -990,7 +1165,7 @@ public class Global {
                        try {\r
                                value = (Integer)settings.value("autoSaveInterval", 5);\r
                        } catch (Exception e1) {\r
-                               value = 0;\r
+                               value = 5;\r
                        }\r
                }\r
                settings.endGroup();\r
@@ -1031,6 +1206,20 @@ public class Global {
        invalidElements.add(element);\r
     }\r
     \r
+    // Proxy settings\r
+    public static String getProxyValue(String key) {\r
+               settings.beginGroup("Proxy");\r
+               String val  = (String)settings.value(key, "");\r
+               settings.endGroup();\r
+               return val;\r
+    }\r
+    public static void setProxyValue(String key, String value) {\r
+               settings.beginGroup("Proxy");\r
+               settings.setValue(key, value);\r
+               settings.endGroup();\r
+    }\r
+    \r
+    \r
     // Convert a byte array to a hex string\r
        public static String byteArrayToHexString(byte data[]) {\r
                StringBuffer buf = new StringBuffer();\r
@@ -1090,6 +1279,54 @@ public class Global {
                settings.endGroup();\r
        }\r
 \r
+    public static boolean isToolbarButtonVisible(String window) {\r
+               settings.beginGroup("ToolbarButtonsVisible");\r
+               try {\r
+                       String text = (String)settings.value(window, "true");\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
+                       else\r
+                               return false;   \r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value(window, true);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
+    }\r
+    public static void saveToolbarButtonsVisible(String column, boolean val) {\r
+               settings.beginGroup("ToolbarButtonsVisible");\r
+               if (val)\r
+                       settings.setValue(column, "true");\r
+               else\r
+                       settings.setValue(column, "false");\r
+               settings.endGroup();\r
+    }\r
+       \r
+    \r
+    public static boolean enableThumbnails() {\r
+               settings.beginGroup("Debug");\r
+               try {\r
+                       String text = (String)settings.value("thumbnails", "true");\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
+                       else\r
+                               return false;\r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("thumbnails", true);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
+    }\r
+    public static void setEnableThumbnails(boolean val) {\r
+               settings.beginGroup("Debug");\r
+               if (val)\r
+                       settings.setValue("thumbnails", "true");\r
+               else\r
+                       settings.setValue("thumbnails", "false");\r
+               settings.endGroup();\r
+    }\r
        \r
        // Print date/time.  Used mainly for performance tracing\r
        public static void trace(boolean resetInterval) {\r
@@ -1130,7 +1367,205 @@ public class Global {
     public static boolean getDisableViewing() {\r
         return disableViewing;\r
     }\r
+\r
+    //**********************\r
+    //* Thumbnail zoom level\r
+    //**********************\r
+    public static int calculateThumbnailZoom(String content) {\r
+       int zoom = 1;\r
+               if (content.indexOf("application/pdf") == -1) {\r
+                       if (content.indexOf("image/") == -1) {\r
+                               String text =  StringEscapeUtils.unescapeHtml(content.replaceAll("\\<.*?\\>", ""));\r
+                               zoom = 2;\r
+                               if (text.length() < 500) \r
+                                       zoom = 2;\r
+                               if (text.length() < 250)\r
+                                       zoom = 3;\r
+                               if (text.length() < 100)\r
+                                       zoom = 4;\r
+                               if (text.length() < 50)\r
+                                       zoom = 5;\r
+                               if (text.length() < 10)\r
+                                       zoom = 6;\r
+                       }\r
+               }\r
+               return zoom;\r
+    }\r
+    \r
+    //**********************\r
+    //* List View settings \r
+    //**********************\r
+    public static void setListView(int view) {\r
+               settings.beginGroup("General");\r
+               settings.setValue("listView", view);\r
+               settings.endGroup();\r
+    }\r
+    public static int getListView() {\r
+               settings.beginGroup("General");\r
+               Integer value;\r
+               try {\r
+                       String val  = (String)settings.value("listView", View_List_Wide);\r
+                       value = new Integer(val.trim());\r
+               } catch (Exception e) {\r
+                       try {\r
+                               value = (Integer)settings.value("listView", View_List_Wide);\r
+                       } catch (Exception e1) {\r
+                               value = View_List_Wide;\r
+                       }\r
+               }\r
+               settings.endGroup();\r
+               return value;\r
+    }\r
+\r
+    \r
+    \r
+    //*******************\r
+    // Font Settings\r
+    //*******************\r
+    public static boolean overrideDefaultFont() {\r
+               settings.beginGroup("Font");\r
+               try {\r
+                       String text = (String)settings.value("overrideFont", "false");\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
+                       else\r
+                               return false;   \r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("overrideFont", false);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
+\r
+    }\r
+    public static void setOverrideDefaultFont(boolean value) {\r
+               settings.beginGroup("Font");\r
+               settings.setValue("overrideFont", value);\r
+               settings.endGroup();    \r
+    }\r
+    public static String getDefaultFont() {\r
+               settings.beginGroup("Font");\r
+               String val  = (String)settings.value("font", "");\r
+               settings.endGroup();\r
+               return val;\r
+    }\r
+    public static void setDefaultFont(String value) {\r
+               settings.beginGroup("Font");\r
+               settings.setValue("font", value);\r
+               settings.endGroup();\r
+    }\r
+    public static String getDefaultFontSize() {\r
+               settings.beginGroup("Font");\r
+               String val  = (String)settings.value("fontSize", "");\r
+               settings.endGroup();\r
+               return val;\r
+    }\r
+    public static void setDefaultFontSize(String value) {\r
+               settings.beginGroup("Font");\r
+               settings.setValue("fontSize", value);\r
+               settings.endGroup();\r
+    }\r
+    \r
     \r
+    //*******************\r
+    // Close/Minimize\r
+    //*******************\r
+    public static boolean minimizeOnClose() {\r
+               settings.beginGroup("General");\r
+               try {\r
+                       String text = (String)settings.value("minimizeOnClose", "false");\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
+                       else\r
+                               return false;\r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("minimizeOnClose", false);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
+    }\r
+    public static void setMinimizeOnClose(boolean value) {\r
+               settings.beginGroup("General");\r
+               settings.setValue("minimizeOnClose", value);\r
+               settings.endGroup();    \r
+    }\r
+\r
+    //*******************\r
+    // Check version information\r
+    //*******************\r
+    public static boolean checkVersionUpgrade() {\r
+               settings.beginGroup("Upgrade");\r
+               try {\r
+                       String text = (String)settings.value("checkForUpdates", "true");\r
+                       settings.endGroup();\r
+                       if (text.equalsIgnoreCase("true"))\r
+                               return true;\r
+                       else\r
+                               return false;\r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("checkForUpdates", true);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
+    }\r
+    public static void setCheckVersionUpgrade(boolean value) {\r
+               settings.beginGroup("Upgrade");\r
+               settings.setValue("checkForUpdates", value);\r
+               settings.endGroup();    \r
+    }\r
+    public static String getUpdatesAvailableUrl() {\r
+               settings.beginGroup("Upgrade");\r
+               String text = (String)settings.value("avialableUrl", "http://nevernote.sourceforge.net/versions.txt");\r
+               settings.endGroup();    \r
+               return text;\r
+    }\r
+    public static String getUpdateAnnounceUrl() {\r
+               settings.beginGroup("Upgrade");\r
+               String text = (String)settings.value("announceUrl", "http://nevernote.sourceforge.net/upgrade.html");\r
+               settings.endGroup();    \r
+               return text;\r
+    }\r
+    \r
+    //*******************\r
+    // Index attachments\r
+    //*******************\r
+    public static boolean indexAttachmentsLocally() {\r
+               settings.beginGroup("Debug");\r
+               try {\r
+                       String value = (String)settings.value("indexAttachmentsLocally", "true");\r
+                       settings.endGroup();\r
+                       if (value.equals("true"))\r
+                               return true;\r
+                       else\r
+                               return false;\r
+               } catch (java.lang.ClassCastException e) {\r
+                       Boolean value = (Boolean) settings.value("indexAttachmentsLocally", true);\r
+                       settings.endGroup();\r
+                       return value;\r
+               }\r
+    }\r
+    public static void setIndexAttachmentsLocally(boolean value) {\r
+               settings.beginGroup("Debug");\r
+               settings.setValue("indexAttachmentsLocally", value);\r
+               settings.endGroup();    \r
+    }\r
+\r
+    //***********************\r
+    //* Database cache size\r
+    //***********************\r
+    public static String getDatabaseCacheSize() {\r
+               settings.beginGroup("Debug");\r
+               String text = (String)settings.value("databaseCache", "16384");\r
+               settings.endGroup();    \r
+               return text;\r
+    }\r
+    public static void setDatabaseCache(String value) {\r
+               settings.beginGroup("Debug");\r
+               settings.setValue("databaseCache", value);\r
+               settings.endGroup();    \r
+    }\r
+\r
 \r
 }\r
 \r