mirror of
https://github.com/gryf/wmaker.git
synced 2025-12-23 06:38:05 +01:00
wmaker: Restore multi screen functionality by reverting wrong commits
Revert patches that moved variables from WMScreen to global level because this broke X displays with multiple independent screens and caused dock and clip icons to become mixed up. When managing multiple screens each screen used to have it's own state/dock and clip. This commit restores that by reverting mainly the commits listed below (and those that are invalidated by reverting these) and fixing up later commits to apply after the revert. Reverted commits:f60e65001bMoved 'workspace_name_font' from the Screen to a Workspace object in the global namespace9e103a46e9Variable workspace_count moved to the workspace object in the global namespacee5ae684d02Variable last_workspace moved to workspace object in global namespacec610b8d7ceVariable current_workspace moved to workspace object in global namespacef0c5073600Array of workspaces moved to the workspace object in the global namespace9c252988f8Variable workspace_menu moved to workspace object in global namespacee86b8dcb2fClip, Dock and Drawers menu moved to appropriate global namespace074092f319Removed WScreen args not used4a7daf2322AppIcon list moved out of WScreen2103fe390bVariable clip_icon moved to clip object in the global namespace014bc52531wClipIconPaint appicon argument removed40e1ea08b8Varible session_state moved to global namespace6987d4aa40Removed WScreen argument0de3e590ceshortcutWindows moved to w_global2e64831fb6Removed unused variable wapp_listb6423a7b4fwmaker: Moved variable Screen Count into the global namespace Signed-off-by: Carlos R. Mafra <crmafra@gmail.com>
This commit is contained in:
committed by
Carlos R. Mafra
parent
e3dcadde30
commit
cb3702559a
@@ -611,8 +611,8 @@ static void find_Maximus_geometry(WWindow *wwin, WArea usableArea, int *new_x, i
|
||||
/* The focused window is always the last in the list */
|
||||
while (tmp->prev) {
|
||||
/* ignore windows in other workspaces etc */
|
||||
if (tmp->prev->frame->workspace != w_global.workspace.current ||
|
||||
tmp->prev->flags.miniaturized || tmp->prev->flags.hidden) {
|
||||
if (tmp->prev->frame->workspace != wwin->screen_ptr->current_workspace
|
||||
|| tmp->prev->flags.miniaturized || tmp->prev->flags.hidden) {
|
||||
tmp = tmp->prev;
|
||||
continue;
|
||||
}
|
||||
@@ -638,8 +638,8 @@ static void find_Maximus_geometry(WWindow *wwin, WArea usableArea, int *new_x, i
|
||||
|
||||
tmp = wwin;
|
||||
while (tmp->prev) {
|
||||
if (tmp->prev->frame->workspace != w_global.workspace.current ||
|
||||
tmp->prev->flags.miniaturized || tmp->prev->flags.hidden) {
|
||||
if (tmp->prev->frame->workspace != wwin->screen_ptr->current_workspace
|
||||
|| tmp->prev->flags.miniaturized || tmp->prev->flags.hidden) {
|
||||
tmp = tmp->prev;
|
||||
continue;
|
||||
}
|
||||
@@ -1105,7 +1105,7 @@ void wIconifyWindow(WWindow *wwin)
|
||||
return;
|
||||
}
|
||||
|
||||
present = wwin->frame->workspace == w_global.workspace.current;
|
||||
present = wwin->frame->workspace == wwin->screen_ptr->current_workspace;
|
||||
|
||||
/* if the window is in another workspace, simplify process */
|
||||
if (present) {
|
||||
@@ -1189,7 +1189,7 @@ void wIconifyWindow(WWindow *wwin)
|
||||
wwin->flags.skip_next_animation = 0;
|
||||
|
||||
if (!wPreferences.disable_miniwindows && !wwin->flags.net_handle_icon) {
|
||||
if (w_global.workspace.current == wwin->frame->workspace ||
|
||||
if (wwin->screen_ptr->current_workspace == wwin->frame->workspace ||
|
||||
IS_OMNIPRESENT(wwin) || wPreferences.sticky_icons)
|
||||
XMapWindow(dpy, wwin->icon->core->window);
|
||||
|
||||
@@ -1251,17 +1251,17 @@ void wIconifyWindow(WWindow *wwin)
|
||||
void wDeiconifyWindow(WWindow *wwin)
|
||||
{
|
||||
/* Let's avoid changing workspace while deiconifying */
|
||||
w_global.workspace.ignore_change = True;
|
||||
w_global.ignore_workspace_change = True;
|
||||
|
||||
/* we're hiding for show_desktop */
|
||||
int netwm_hidden = wwin->flags.net_show_desktop &&
|
||||
wwin->frame->workspace != w_global.workspace.current;
|
||||
wwin->frame->workspace != wwin->screen_ptr->current_workspace;
|
||||
|
||||
if (!netwm_hidden)
|
||||
wWindowChangeWorkspace(wwin, w_global.workspace.current);
|
||||
wWindowChangeWorkspace(wwin, wwin->screen_ptr->current_workspace);
|
||||
|
||||
if (!wwin->flags.miniaturized) {
|
||||
w_global.workspace.ignore_change = False;
|
||||
w_global.ignore_workspace_change = False;
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -1272,7 +1272,7 @@ void wDeiconifyWindow(WWindow *wwin)
|
||||
wDeiconifyWindow(owner);
|
||||
wSetFocusTo(wwin->screen_ptr, wwin);
|
||||
wRaiseFrame(wwin->frame->core);
|
||||
w_global.workspace.ignore_change = False;
|
||||
w_global.ignore_workspace_change = False;
|
||||
return;
|
||||
}
|
||||
}
|
||||
@@ -1339,7 +1339,7 @@ void wDeiconifyWindow(WWindow *wwin)
|
||||
|
||||
/* the window can disappear while ProcessPendingEvents() runs */
|
||||
if (!wWindowFor(clientwin)) {
|
||||
w_global.workspace.ignore_change = False;
|
||||
w_global.ignore_workspace_change = False;
|
||||
return;
|
||||
}
|
||||
}
|
||||
@@ -1355,7 +1355,7 @@ void wDeiconifyWindow(WWindow *wwin)
|
||||
if (!netwm_hidden)
|
||||
wUnshadeWindow(wwin);
|
||||
|
||||
w_global.workspace.ignore_change = False;
|
||||
w_global.ignore_workspace_change = False;
|
||||
}
|
||||
|
||||
static void hideWindow(WIcon *icon, int icon_x, int icon_y, WWindow *wwin, int animate)
|
||||
@@ -1428,7 +1428,7 @@ void wHideAll(WScreen *scr)
|
||||
|
||||
for (i = 0; i < wcount; i++) {
|
||||
wwin = windows[i];
|
||||
if (wwin->frame->workspace == w_global.workspace.current
|
||||
if (wwin->frame->workspace == scr->current_workspace
|
||||
&& !(wwin->flags.miniaturized || wwin->flags.hidden)
|
||||
&& !wwin->flags.internal_window
|
||||
&& !WFLAGP(wwin, no_miniaturizable)
|
||||
@@ -1452,7 +1452,7 @@ void wHideOtherApplications(WWindow *awin)
|
||||
|
||||
while (wwin) {
|
||||
if (wwin != awin
|
||||
&& wwin->frame->workspace == w_global.workspace.current
|
||||
&& wwin->frame->workspace == awin->screen_ptr->current_workspace
|
||||
&& !(wwin->flags.miniaturized || wwin->flags.hidden)
|
||||
&& !wwin->flags.internal_window
|
||||
&& wGetWindowOfInspectorForWindow(wwin) != awin && !WFLAGP(wwin, no_hide_others)) {
|
||||
@@ -1554,7 +1554,7 @@ void wHideApplication(WApplication *wapp)
|
||||
static void unhideWindow(WIcon *icon, int icon_x, int icon_y, WWindow *wwin, int animate, int bringToCurrentWS)
|
||||
{
|
||||
if (bringToCurrentWS)
|
||||
wWindowChangeWorkspace(wwin, w_global.workspace.current);
|
||||
wWindowChangeWorkspace(wwin, wwin->screen_ptr->current_workspace);
|
||||
|
||||
wwin->flags.hidden = 0;
|
||||
|
||||
@@ -1567,7 +1567,7 @@ static void unhideWindow(WIcon *icon, int icon_x, int icon_y, WWindow *wwin, int
|
||||
}
|
||||
#endif
|
||||
wwin->flags.skip_next_animation = 0;
|
||||
if (w_global.workspace.current == wwin->frame->workspace) {
|
||||
if (wwin->screen_ptr->current_workspace == wwin->frame->workspace) {
|
||||
XMapWindow(dpy, wwin->client_win);
|
||||
XMapWindow(dpy, wwin->frame->core->window);
|
||||
wClientSetState(wwin, NormalState, None);
|
||||
@@ -1612,7 +1612,7 @@ void wUnhideApplication(WApplication *wapp, Bool miniwindows, Bool bringToCurren
|
||||
|
||||
if (wlist->flags.miniaturized) {
|
||||
if ((bringToCurrentWS || wPreferences.sticky_icons ||
|
||||
wlist->frame->workspace == w_global.workspace.current) && wlist->icon) {
|
||||
wlist->frame->workspace == scr->current_workspace) && wlist->icon) {
|
||||
if (!wlist->icon->mapped) {
|
||||
int x, y;
|
||||
|
||||
@@ -1627,17 +1627,17 @@ void wUnhideApplication(WApplication *wapp, Bool miniwindows, Bool bringToCurren
|
||||
wRaiseFrame(wlist->icon->core);
|
||||
}
|
||||
if (bringToCurrentWS)
|
||||
wWindowChangeWorkspace(wlist, w_global.workspace.current);
|
||||
wWindowChangeWorkspace(wlist, scr->current_workspace);
|
||||
wlist->flags.hidden = 0;
|
||||
if (miniwindows && wlist->frame->workspace == w_global.workspace.current)
|
||||
if (miniwindows && wlist->frame->workspace == scr->current_workspace)
|
||||
wDeiconifyWindow(wlist);
|
||||
WMPostNotificationName(WMNChangedState, wlist, "hide");
|
||||
} else if (wlist->flags.shaded) {
|
||||
if (bringToCurrentWS)
|
||||
wWindowChangeWorkspace(wlist, w_global.workspace.current);
|
||||
wWindowChangeWorkspace(wlist, scr->current_workspace);
|
||||
wlist->flags.hidden = 0;
|
||||
wRaiseFrame(wlist->frame->core);
|
||||
if (wlist->frame->workspace == w_global.workspace.current) {
|
||||
if (wlist->frame->workspace == scr->current_workspace) {
|
||||
XMapWindow(dpy, wlist->frame->core->window);
|
||||
if (miniwindows)
|
||||
wUnshadeWindow(wlist);
|
||||
@@ -1648,8 +1648,8 @@ void wUnhideApplication(WApplication *wapp, Bool miniwindows, Bool bringToCurren
|
||||
wapp->app_icon->y_pos, wlist, animate, bringToCurrentWS);
|
||||
animate = False;
|
||||
} else {
|
||||
if (bringToCurrentWS && wlist->frame->workspace != w_global.workspace.current)
|
||||
wWindowChangeWorkspace(wlist, w_global.workspace.current);
|
||||
if (bringToCurrentWS && wlist->frame->workspace != scr->current_workspace)
|
||||
wWindowChangeWorkspace(wlist, scr->current_workspace);
|
||||
|
||||
wRaiseFrame(wlist->frame->core);
|
||||
}
|
||||
@@ -1683,7 +1683,7 @@ void wShowAllWindows(WScreen *scr)
|
||||
old_foc = wwin = scr->focused_window;
|
||||
while (wwin) {
|
||||
if (!wwin->flags.internal_window &&
|
||||
(w_global.workspace.current == wwin->frame->workspace || IS_OMNIPRESENT(wwin))) {
|
||||
(scr->current_workspace == wwin->frame->workspace || IS_OMNIPRESENT(wwin))) {
|
||||
if (wwin->flags.miniaturized) {
|
||||
wwin->flags.skip_next_animation = 1;
|
||||
wDeiconifyWindow(wwin);
|
||||
@@ -1802,7 +1802,7 @@ void wArrangeIcons(WScreen *scr, Bool arrangeAll)
|
||||
: vars[head].yo + vars[head].ys*(vars[head].si*isize))
|
||||
|
||||
/* arrange application icons */
|
||||
aicon = w_global.app_icon_list;
|
||||
aicon = scr->app_icon_list;
|
||||
/* reverse them to avoid unnecessarily sliding of icons */
|
||||
while (aicon && aicon->next)
|
||||
aicon = aicon->next;
|
||||
@@ -1838,7 +1838,7 @@ void wArrangeIcons(WScreen *scr, Bool arrangeAll)
|
||||
|
||||
while (wwin) {
|
||||
if (wwin->icon && wwin->flags.miniaturized && !wwin->flags.hidden &&
|
||||
(wwin->frame->workspace == w_global.workspace.current ||
|
||||
(wwin->frame->workspace == scr->current_workspace ||
|
||||
IS_OMNIPRESENT(wwin) || wPreferences.sticky_icons)) {
|
||||
|
||||
head = wGetHeadForWindow(wwin);
|
||||
@@ -1907,7 +1907,7 @@ void wSelectWindow(WWindow *wwin, Bool flag)
|
||||
|
||||
void wMakeWindowVisible(WWindow *wwin)
|
||||
{
|
||||
if (wwin->frame->workspace != w_global.workspace.current)
|
||||
if (wwin->frame->workspace != wwin->screen_ptr->current_workspace)
|
||||
wWorkspaceChange(wwin->screen_ptr, wwin->frame->workspace);
|
||||
|
||||
if (wwin->flags.shaded)
|
||||
|
||||
Reference in New Issue
Block a user