diff options
Diffstat (limited to 'ajde')
-rw-r--r-- | ajde/src/org/aspectj/ajde/ui/internal/UserPreferencesStore.java | 61 |
1 files changed, 49 insertions, 12 deletions
diff --git a/ajde/src/org/aspectj/ajde/ui/internal/UserPreferencesStore.java b/ajde/src/org/aspectj/ajde/ui/internal/UserPreferencesStore.java index c5c001a0b..722e18577 100644 --- a/ajde/src/org/aspectj/ajde/ui/internal/UserPreferencesStore.java +++ b/ajde/src/org/aspectj/ajde/ui/internal/UserPreferencesStore.java @@ -27,6 +27,7 @@ import java.util.StringTokenizer; import org.aspectj.ajde.Ajde; import org.aspectj.ajde.ui.UserPreferencesAdapter; +import org.aspectj.util.LangUtil; public class UserPreferencesStore implements UserPreferencesAdapter { public static final String FILE_NAME = "/.ajbrowser"; @@ -34,14 +35,14 @@ public class UserPreferencesStore implements UserPreferencesAdapter { private Properties properties = new Properties(); public UserPreferencesStore() { - try { - if (new File(getPropertiesFilePath()).exists()) { - properties.load(new FileInputStream(getPropertiesFilePath())); - } - } catch (IOException ioe) { - Ajde.getDefault().getErrorHandler().handleError("Could not read properties", ioe); - } + this(true); } + + public UserPreferencesStore(boolean loadDefault) { + if (loadDefault) { + loadProperties(getPropertiesFilePath()); + } + } public String getProjectPreference(String name) { return properties.getProperty(name); @@ -60,7 +61,7 @@ public class UserPreferencesStore implements UserPreferencesAdapter { } public void setProjectPreference(String name, String value) { - properties.setProperty(name, value); + properties.setProperty(name, value); saveProperties(); } @@ -73,7 +74,7 @@ public class UserPreferencesStore implements UserPreferencesAdapter { saveProperties(); } - public String getPropertiesFilePath() { + public static String getPropertiesFilePath() { String path = System.getProperty("user.home"); if (path == null) { path = "."; @@ -96,12 +97,48 @@ public class UserPreferencesStore implements UserPreferencesAdapter { public void setGlobalMultivalPreference(String name, List values) { setProjectMultivalPreference(name, values); } - + private void loadProperties(String path) { + if (LangUtil.isEmpty(path)) { + return; + } + File file = new File(path); + if (!file.canRead()) { + return; + } + FileInputStream in = null; + try { + path = getPropertiesFilePath(); + in = new FileInputStream(file); + properties.load(in); + } catch (IOException ioe) { + Ajde.getDefault().getErrorHandler().handleError("Error reading properties from " + path, ioe); + } finally { + if (null != in) { + try { + in.close(); + } catch (IOException e) { + // ignore + } + } + } + } public void saveProperties() { + FileOutputStream out = null; + String path = null; try { - properties.store(new FileOutputStream(getPropertiesFilePath()), "AJDE Settings"); + path = getPropertiesFilePath(); + out = new FileOutputStream(path); + properties.store(out, "AJDE Settings"); } catch (IOException ioe) { - Ajde.getDefault().getErrorHandler().handleError("Could not write properties", ioe); + Ajde.getDefault().getErrorHandler().handleError("Error writing properties to " + path, ioe); + } finally { + if (null != out) { + try { + out.close(); + } catch (IOException e) { + // ignore + } + } } } } |