summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorengelsman <engelsman@users.noreply.github.com>2020-11-02 11:38:30 +0100
committerGitHub <noreply@github.com>2020-11-02 11:38:30 +0100
commitf0af606708a5ede2bb99880c9ffb68f29a2439c0 (patch)
treee990046ea5d2d61b365f12dd9401166f5516701c /src
parent7d126461ef1a4dc8b9dda7f3f4e2603c638d40dd (diff)
Save fl_file_chooser directory on cancel (STR 3225) (#110)
* save fl_file_chooser directory on cancel (STR3225) by default, the fl_file_chooser() starts in the current directory if no filename is given, but the directory is reset to the "system directory" if the dialog is cancelled without choosing a file. This patch saves and restores the directory if no file is chosen. See also https://www.fltk.org/str.php?L3225 * add fl_file_chooser() reinitialization comments
Diffstat (limited to 'src')
-rw-r--r--src/fl_file_dir.cxx31
1 files changed, 24 insertions, 7 deletions
diff --git a/src/fl_file_dir.cxx b/src/fl_file_dir.cxx
index dc740f9e5..680f55556 100644
--- a/src/fl_file_dir.cxx
+++ b/src/fl_file_dir.cxx
@@ -93,11 +93,16 @@ fl_file_chooser(const char *message, // I - Message in titlebar
static char retname[FL_PATH_MAX]; // Returned filename
if (!fc) {
+ // first time, so create file chooser, remember pointer,
+ // and if no filename given, set it to current directory
+
if (!fname || !*fname) fname = ".";
fc = new Fl_File_Chooser(fname, pat, Fl_File_Chooser::CREATE, message);
fc->callback(callback, 0);
} else {
+ // file chooser exists, so check old/new directory, pattern, filename
+
fc->type(Fl_File_Chooser::CREATE);
// see, if we use the same pattern between calls
char same_pattern = 0;
@@ -110,16 +115,16 @@ fl_file_chooser(const char *message, // I - Message in titlebar
fc->filter(pat);
fc->label(message);
- if (!fname) { // null pointer reuses same filename if pattern didn't change
+ if (!fname) {
+ // new filename is null, so reuse old one if pattern unchanged
+
if (!same_pattern && fc->value()) {
// if pattern is different, remove name but leave old directory:
strlcpy(retname, fc->value(), sizeof(retname));
char *p = strrchr(retname, '/');
-
if (p) {
- // If the filename is "/foo", then the directory will be "/", not
- // ""...
+ // If old filename as "/foo", then directory will be "/", not ""
if (p == retname)
retname[1] = '\0';
else
@@ -130,7 +135,9 @@ fl_file_chooser(const char *message, // I - Message in titlebar
} else {
// re-use the previously selected name
}
- } else if (!*fname) { // empty filename reuses directory with empty name
+ } else if (!*fname) {
+ // new filename is empty, so reuse old directory with empty file
+
const char *fcv = fc->value();
if (fcv)
strlcpy(retname, fc->value(), sizeof(retname));
@@ -138,12 +145,22 @@ fl_file_chooser(const char *message, // I - Message in titlebar
*retname = 0;
const char *n = fl_filename_name(retname);
if (n) *((char*)n) = 0;
- fc->value("");
- fc->directory(retname);
+
+ // retname is either old directory, or empty if user cancelled
+ if (*retname) {
+ fc->value("");
+ fc->directory(retname); // reset old directory
+ } else {
+ char dirsave[FL_PATH_MAX];
+ strlcpy(dirsave, fc->directory(), sizeof(dirsave));
+ fc->value(""); // also resets directory to "system default"
+ fc->directory(dirsave); // so reset directory back where we were
+ }
} else {
fc->value(fname);
}
}
+ // end [re]initialization
fc->ok_label(current_label);
popup(fc);