diff --git a/CHANGELOG.md b/CHANGELOG.md index 8b28720dc79..e142162d26d 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -16,6 +16,7 @@ If fetched article is already in database the ImportInspectionDialog is started ### Fixed We fixed an issue where the fetcher for the Astrophysics Data System (ADS) added some non-bibtex data to the entry returned from the search [#3035](https://github.com/JabRef/jabref/issues/3035) We fixed an issue where assigning an entry via drag and drop to a group caused JabRef to stop/freeze completely [#3036](https://github.com/JabRef/jabref/issues/3036) +We fixed an issue where the preferences could not be imported without a restart of JabRef [#3064](https://github.com/JabRef/jabref/issues/3064) ### Removed diff --git a/src/main/java/org/jabref/gui/util/FileDialogConfiguration.java b/src/main/java/org/jabref/gui/util/FileDialogConfiguration.java index 87ebbdb025e..219b919d28e 100644 --- a/src/main/java/org/jabref/gui/util/FileDialogConfiguration.java +++ b/src/main/java/org/jabref/gui/util/FileDialogConfiguration.java @@ -80,7 +80,8 @@ public Builder withInitialDirectory(Path directory) { } //The lines above work also if the dir does not exist at all! //NULL is accepted by the filechooser as no inital path - if (!Files.exists(directory)) { + //Explicit null check, if somehow the parent is null, as Files.exists throws an NPE otherwise + if ((directory != null) && !Files.exists(directory)) { directory = null; } initialDirectory = directory; diff --git a/src/main/java/org/jabref/preferences/JabRefPreferences.java b/src/main/java/org/jabref/preferences/JabRefPreferences.java index 469478e6ae0..98acb38c4f1 100644 --- a/src/main/java/org/jabref/preferences/JabRefPreferences.java +++ b/src/main/java/org/jabref/preferences/JabRefPreferences.java @@ -536,7 +536,7 @@ private JabRefPreferences() { defaults.put(EXPORT_WORKING_DIRECTORY, USER_HOME); // Remembers working directory of last import defaults.put(IMPORT_WORKING_DIRECTORY, USER_HOME); - defaults.put(PREFS_EXPORT_PATH, WORKING_DIRECTORY); + defaults.put(PREFS_EXPORT_PATH, USER_HOME); defaults.put(AUTO_OPEN_FORM, Boolean.TRUE); defaults.put(BACKUP, Boolean.TRUE); defaults.put(OPEN_LAST_EDITED, Boolean.TRUE); diff --git a/src/test/java/org/jabref/gui/util/FileDialogConfigurationTest.java b/src/test/java/org/jabref/gui/util/FileDialogConfigurationTest.java index d4f0df99318..df4173bff24 100644 --- a/src/test/java/org/jabref/gui/util/FileDialogConfigurationTest.java +++ b/src/test/java/org/jabref/gui/util/FileDialogConfigurationTest.java @@ -60,6 +60,15 @@ public void testWithNullPathDirectory() { assertEquals(Optional.ofNullable(tempFolder), fileDialogConfiguration.getInitialDirectory()); } + @Test + public void testWithNonExistingDirectoryAndParentNull() { + String tempFolder = "workingDirectory"; + FileDialogConfiguration fileDialogConfiguration = new FileDialogConfiguration.Builder() + .withInitialDirectory(tempFolder).build(); + + assertEquals(Optional.ofNullable(null), fileDialogConfiguration.getInitialDirectory()); + } + @Test public void testSingleExtension() { FileDialogConfiguration fileDialogConfiguration = new FileDialogConfiguration.Builder()