- // If that fails, and we're doing focus_last, try to focus the last window.
- if (! f && resource.focus_last && current_workspace->getLastFocusedWindow())
- f = current_workspace->getLastFocusedWindow()->setInputFocus();
+ // If that fails, and we're doing focus_last, try to focus the last window.
+ if (! f && resource.focus_last &&
+ (win = current_workspace->getLastFocusedWindow()))
+ f = win->setInputFocus();
+
+ /*
+ if we found a focus target, then we set the focused window explicitly
+ because it is possible to switch off this workspace before the x server
+ generates the FocusIn event for the window. if that happens, openbox would
+ lose track of what window was the 'LastFocused' window on the workspace.