Fixed 'Open Previuos' bug in FLUID.
'set_filename' in 'open_histroy_cb' would change the filename before the file was opened, hence opening the file one up in the list. git-svn-id: file:///fltk/svn/fltk/branches/branch-1.1@2169 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
This commit is contained in:
parent
c0670cdc55
commit
d5b98e56c0
@ -1,5 +1,5 @@
|
|||||||
//
|
//
|
||||||
// "$Id: fluid.cxx,v 1.15.2.13.2.21 2002/05/01 19:17:24 easysw Exp $"
|
// "$Id: fluid.cxx,v 1.15.2.13.2.22 2002/05/01 21:41:59 matthiaswm Exp $"
|
||||||
//
|
//
|
||||||
// FLUID main entry for the Fast Light Tool Kit (FLTK).
|
// FLUID main entry for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
@ -162,12 +162,15 @@ void open_cb(Fl_Widget *, void *v) {
|
|||||||
|
|
||||||
void open_history_cb(Fl_Widget *, void *v) {
|
void open_history_cb(Fl_Widget *, void *v) {
|
||||||
if (modflag && !fl_ask("Discard changes?")) return;
|
if (modflag && !fl_ask("Discard changes?")) return;
|
||||||
set_filename((char *)v);
|
char *localcopy = strdup( (char*)v );
|
||||||
if (!read_file((char *)v, 0)) {
|
if (!read_file(localcopy, 0)) {
|
||||||
fl_message("Can't read %s: %s", v, strerror(errno));
|
fl_message("Can't read %s: %s", v, strerror(errno));
|
||||||
|
free(localcopy);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
set_filename(localcopy);
|
||||||
modflag = 0;
|
modflag = 0;
|
||||||
|
free(localcopy);
|
||||||
}
|
}
|
||||||
|
|
||||||
void new_cb(Fl_Widget *, void *v) {
|
void new_cb(Fl_Widget *, void *v) {
|
||||||
@ -530,7 +533,7 @@ void update_history(const char *filename) {
|
|||||||
#if defined(WIN32) || defined(__APPLE__)
|
#if defined(WIN32) || defined(__APPLE__)
|
||||||
if (!strcasecmp(absolute, absolute_history[i])) break;
|
if (!strcasecmp(absolute, absolute_history[i])) break;
|
||||||
#else
|
#else
|
||||||
if (!strcasecmp(absolute, absolute_history[i])) break;
|
if (!strcmp(absolute, absolute_history[i])) break;
|
||||||
#endif // WIN32 || __APPLE__
|
#endif // WIN32 || __APPLE__
|
||||||
|
|
||||||
if (i == 0) return;
|
if (i == 0) return;
|
||||||
@ -777,5 +780,5 @@ int main(int argc,char **argv) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// End of "$Id: fluid.cxx,v 1.15.2.13.2.21 2002/05/01 19:17:24 easysw Exp $".
|
// End of "$Id: fluid.cxx,v 1.15.2.13.2.22 2002/05/01 21:41:59 matthiaswm Exp $".
|
||||||
//
|
//
|
||||||
|
Loading…
Reference in New Issue
Block a user