summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/Fl_Screen_Driver.cxx31
1 files changed, 9 insertions, 22 deletions
diff --git a/src/Fl_Screen_Driver.cxx b/src/Fl_Screen_Driver.cxx
index 1bcd54727..b3cc70c88 100644
--- a/src/Fl_Screen_Driver.cxx
+++ b/src/Fl_Screen_Driver.cxx
@@ -383,23 +383,13 @@ void Fl_Screen_Driver::rescale_all_windows_from_screen(int screen, float f)
delete[] win_array;
}
-struct WinAndTracker {
- Fl_Window *win;
- Fl_Widget_Tracker *tracker;
-};
-static void del_transient_window(WinAndTracker *data) {
- delete (Fl_Image*)data->win->shape();
- delete data->win;
- if (data->tracker) {
- if (data->tracker->exists()) {
- data->tracker->widget()->take_focus();
- }
- delete data->tracker;
- }
- data->win = NULL;
+static void del_transient_window(Fl_Window **pwin) {
+ delete *pwin;
+ *pwin = NULL;
}
+
void Fl_Screen_Driver::transient_scale_display(float f, int nscreen)
{
if (!Fl::option(Fl::OPTION_SHOW_SCALING)) return;
@@ -440,18 +430,15 @@ void Fl_Screen_Driver::transient_scale_display(float f, int nscreen)
win->set_non_modal();
Fl_Window_Driver::driver(win)->screen_num(nscreen);
Fl_Window_Driver::driver(win)->force_position(1);
- static WinAndTracker data = {NULL, NULL};
- if (data.win) {
+ static Fl_Window *transient = NULL;
+ if (transient) {
Fl::remove_timeout((Fl_Timeout_Handler)del_transient_window);
- delete data.win;
+ delete transient;
}
- data.win = win;
- Fl_Widget *widget = Fl::focus();
- if (!widget) widget = Fl::first_window();
- data.tracker = (widget ? new Fl_Widget_Tracker(widget) : NULL);
+ transient = win;
win->show();
// delete transient win after 1 sec
- Fl::add_timeout(1, (Fl_Timeout_Handler)del_transient_window, &data);
+ Fl::add_timeout(1, (Fl_Timeout_Handler)del_transient_window, &transient);
}
// respond to Ctrl-'+' and Ctrl-'-' and Ctrl-'0' (Ctrl-'=' is same as Ctrl-'+') by rescaling all windows