Index: trunk/src/org/openstreetmap/josm/data/Preferences.java
===================================================================
--- trunk/src/org/openstreetmap/josm/data/Preferences.java	(revision 14147)
+++ trunk/src/org/openstreetmap/josm/data/Preferences.java	(revision 14148)
@@ -219,5 +219,5 @@
      * @return the base name of the JOSM directories for preferences, cache and user data
      */
-    public String getJOSMDirectoryBaseName() {
+    public static String getJOSMDirectoryBaseName() {
         String name = getSystemProperty("josm.dir.name");
         if (name != null)
Index: trunk/src/org/openstreetmap/josm/tools/PlatformHookOsx.java
===================================================================
--- trunk/src/org/openstreetmap/josm/tools/PlatformHookOsx.java	(revision 14147)
+++ trunk/src/org/openstreetmap/josm/tools/PlatformHookOsx.java	(revision 14148)
@@ -30,4 +30,5 @@
 
 import org.openstreetmap.josm.Main;
+import org.openstreetmap.josm.data.Preferences;
 import org.openstreetmap.josm.io.CertificateAmendment.NativeCertAmend;
 
@@ -423,5 +424,5 @@
     public File getDefaultCacheDirectory() {
         return new File(getSystemProperty("user.home")+"/Library/Caches",
-                Main.pref.getJOSMDirectoryBaseName());
+                Preferences.getJOSMDirectoryBaseName());
     }
 
@@ -429,5 +430,5 @@
     public File getDefaultPrefDirectory() {
         return new File(getSystemProperty("user.home")+"/Library/Preferences",
-                Main.pref.getJOSMDirectoryBaseName());
+                Preferences.getJOSMDirectoryBaseName());
     }
 
@@ -435,5 +436,5 @@
     public File getDefaultUserDataDirectory() {
         return new File(getSystemProperty("user.home")+"/Library",
-                Main.pref.getJOSMDirectoryBaseName());
+                Preferences.getJOSMDirectoryBaseName());
     }
 
Index: trunk/src/org/openstreetmap/josm/tools/PlatformHookUnixoid.java
===================================================================
--- trunk/src/org/openstreetmap/josm/tools/PlatformHookUnixoid.java	(revision 14147)
+++ trunk/src/org/openstreetmap/josm/tools/PlatformHookUnixoid.java	(revision 14148)
@@ -30,5 +30,5 @@
 import java.util.concurrent.ExecutionException;
 
-import org.openstreetmap.josm.Main;
+import org.openstreetmap.josm.data.Preferences;
 import org.openstreetmap.josm.io.CertificateAmendment.NativeCertAmend;
 import org.openstreetmap.josm.spi.preferences.Config;
@@ -349,5 +349,5 @@
      */
     private static File getDotDirectory() {
-        String dirName = "." + Main.pref.getJOSMDirectoryBaseName().toLowerCase(Locale.ENGLISH);
+        String dirName = "." + Preferences.getJOSMDirectoryBaseName().toLowerCase(Locale.ENGLISH);
         return new File(getSystemProperty("user.home"), dirName);
     }
@@ -370,8 +370,8 @@
             String xdgCacheDir = getSystemEnv("XDG_CACHE_HOME");
             if (xdgCacheDir != null && !xdgCacheDir.isEmpty()) {
-                return new File(xdgCacheDir, Main.pref.getJOSMDirectoryBaseName());
+                return new File(xdgCacheDir, Preferences.getJOSMDirectoryBaseName());
             } else {
                 return new File(getSystemProperty("user.home") + File.separator +
-                        ".cache" + File.separator + Main.pref.getJOSMDirectoryBaseName());
+                        ".cache" + File.separator + Preferences.getJOSMDirectoryBaseName());
             }
         }
@@ -385,8 +385,8 @@
             String xdgConfigDir = getSystemEnv("XDG_CONFIG_HOME");
             if (xdgConfigDir != null && !xdgConfigDir.isEmpty()) {
-                return new File(xdgConfigDir, Main.pref.getJOSMDirectoryBaseName());
+                return new File(xdgConfigDir, Preferences.getJOSMDirectoryBaseName());
             } else {
                 return new File(getSystemProperty("user.home") + File.separator +
-                        ".config" + File.separator + Main.pref.getJOSMDirectoryBaseName());
+                        ".config" + File.separator + Preferences.getJOSMDirectoryBaseName());
             }
         }
@@ -400,8 +400,8 @@
             String xdgDataDir = getSystemEnv("XDG_DATA_HOME");
             if (xdgDataDir != null && !xdgDataDir.isEmpty()) {
-                return new File(xdgDataDir, Main.pref.getJOSMDirectoryBaseName());
+                return new File(xdgDataDir, Preferences.getJOSMDirectoryBaseName());
             } else {
                 return new File(getSystemProperty("user.home") + File.separator +
-                        ".local" + File.separator + "share" + File.separator + Main.pref.getJOSMDirectoryBaseName());
+                        ".local" + File.separator + "share" + File.separator + Preferences.getJOSMDirectoryBaseName());
             }
         }
Index: trunk/src/org/openstreetmap/josm/tools/PlatformHookWindows.java
===================================================================
--- trunk/src/org/openstreetmap/josm/tools/PlatformHookWindows.java	(revision 14147)
+++ trunk/src/org/openstreetmap/josm/tools/PlatformHookWindows.java	(revision 14148)
@@ -78,4 +78,5 @@
 
 import org.openstreetmap.josm.Main;
+import org.openstreetmap.josm.data.Preferences;
 import org.openstreetmap.josm.data.StructUtils;
 import org.openstreetmap.josm.data.StructUtils.StructEntry;
@@ -484,10 +485,10 @@
             p = getSystemEnv("APPDATA");
         }
-        return new File(new File(p, Main.pref.getJOSMDirectoryBaseName()), "cache");
+        return new File(new File(p, Preferences.getJOSMDirectoryBaseName()), "cache");
     }
 
     @Override
     public File getDefaultPrefDirectory() {
-        return new File(getSystemEnv("APPDATA"), Main.pref.getJOSMDirectoryBaseName());
+        return new File(getSystemEnv("APPDATA"), Preferences.getJOSMDirectoryBaseName());
     }
 
