mirror of
https://github.com/fltk/fltk.git
synced 2026-05-28 03:15:21 +08:00
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
This commit is contained in:
+24
-7
@@ -93,11 +93,16 @@ fl_file_chooser(const char *message, // I - Message in titlebar
|
|||||||
static char retname[FL_PATH_MAX]; // Returned filename
|
static char retname[FL_PATH_MAX]; // Returned filename
|
||||||
|
|
||||||
if (!fc) {
|
if (!fc) {
|
||||||
|
// first time, so create file chooser, remember pointer,
|
||||||
|
// and if no filename given, set it to current directory
|
||||||
|
|
||||||
if (!fname || !*fname) fname = ".";
|
if (!fname || !*fname) fname = ".";
|
||||||
|
|
||||||
fc = new Fl_File_Chooser(fname, pat, Fl_File_Chooser::CREATE, message);
|
fc = new Fl_File_Chooser(fname, pat, Fl_File_Chooser::CREATE, message);
|
||||||
fc->callback(callback, 0);
|
fc->callback(callback, 0);
|
||||||
} else {
|
} else {
|
||||||
|
// file chooser exists, so check old/new directory, pattern, filename
|
||||||
|
|
||||||
fc->type(Fl_File_Chooser::CREATE);
|
fc->type(Fl_File_Chooser::CREATE);
|
||||||
// see, if we use the same pattern between calls
|
// see, if we use the same pattern between calls
|
||||||
char same_pattern = 0;
|
char same_pattern = 0;
|
||||||
@@ -110,16 +115,16 @@ fl_file_chooser(const char *message, // I - Message in titlebar
|
|||||||
fc->filter(pat);
|
fc->filter(pat);
|
||||||
fc->label(message);
|
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 (!same_pattern && fc->value()) {
|
||||||
// if pattern is different, remove name but leave old directory:
|
// if pattern is different, remove name but leave old directory:
|
||||||
strlcpy(retname, fc->value(), sizeof(retname));
|
strlcpy(retname, fc->value(), sizeof(retname));
|
||||||
|
|
||||||
char *p = strrchr(retname, '/');
|
char *p = strrchr(retname, '/');
|
||||||
|
|
||||||
if (p) {
|
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)
|
if (p == retname)
|
||||||
retname[1] = '\0';
|
retname[1] = '\0';
|
||||||
else
|
else
|
||||||
@@ -130,7 +135,9 @@ fl_file_chooser(const char *message, // I - Message in titlebar
|
|||||||
} else {
|
} else {
|
||||||
// re-use the previously selected name
|
// 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();
|
const char *fcv = fc->value();
|
||||||
if (fcv)
|
if (fcv)
|
||||||
strlcpy(retname, fc->value(), sizeof(retname));
|
strlcpy(retname, fc->value(), sizeof(retname));
|
||||||
@@ -138,12 +145,22 @@ fl_file_chooser(const char *message, // I - Message in titlebar
|
|||||||
*retname = 0;
|
*retname = 0;
|
||||||
const char *n = fl_filename_name(retname);
|
const char *n = fl_filename_name(retname);
|
||||||
if (n) *((char*)n) = 0;
|
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 {
|
} else {
|
||||||
fc->value(fname);
|
fc->value(fname);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// end [re]initialization
|
||||||
|
|
||||||
fc->ok_label(current_label);
|
fc->ok_label(current_label);
|
||||||
popup(fc);
|
popup(fc);
|
||||||
|
|||||||
Reference in New Issue
Block a user