diff options
Diffstat (limited to 'src/MinOverlapPlacement.cc')
-rw-r--r-- | src/MinOverlapPlacement.cc | 25 |
1 files changed, 19 insertions, 6 deletions
diff --git a/src/MinOverlapPlacement.cc b/src/MinOverlapPlacement.cc index 68301c6..510f66e 100644 --- a/src/MinOverlapPlacement.cc +++ b/src/MinOverlapPlacement.cc | |||
@@ -23,6 +23,7 @@ | |||
23 | 23 | ||
24 | #include "MinOverlapPlacement.hh" | 24 | #include "MinOverlapPlacement.hh" |
25 | 25 | ||
26 | #include "FocusControl.hh" | ||
26 | #include "Window.hh" | 27 | #include "Window.hh" |
27 | #include "Screen.hh" | 28 | #include "Screen.hh" |
28 | 29 | ||
@@ -34,19 +35,30 @@ MinOverlapPlacement::MinOverlapPlacement(ScreenPlacement::PlacementPolicy policy | |||
34 | s_policy = policy; | 35 | s_policy = policy; |
35 | } | 36 | } |
36 | 37 | ||
37 | bool MinOverlapPlacement::placeWindow( | 38 | bool MinOverlapPlacement::placeWindow(const FluxboxWindow &win, int head, |
38 | const std::list<FluxboxWindow *> &windowlist, | 39 | int &place_x, int &place_y) { |
39 | const FluxboxWindow &win, int &place_x, int &place_y) { | 40 | |
41 | std::list<FluxboxWindow *> windowlist; | ||
42 | const std::list<Focusable *> focusables = | ||
43 | win.screen().focusControl().focusedOrderWinList(); | ||
44 | std::list<Focusable *>::const_iterator foc_it = focusables.begin(), | ||
45 | foc_it_end = focusables.end(); | ||
46 | unsigned int workspace = win.workspaceNumber(); | ||
47 | for (; foc_it != foc_it_end; ++foc_it) { | ||
48 | // make sure it's a FluxboxWindow | ||
49 | if (*foc_it == (*foc_it)->fbwindow() && | ||
50 | (workspace == (*foc_it)->fbwindow()->workspaceNumber() || | ||
51 | (*foc_it)->fbwindow()->isStuck())) | ||
52 | windowlist.push_back((*foc_it)->fbwindow()); | ||
53 | } | ||
40 | 54 | ||
41 | // view (screen + head) constraints | 55 | // view (screen + head) constraints |
42 | int head = (signed) win.getOnHead(); | ||
43 | int head_left = (signed) win.screen().maxLeft(head); | 56 | int head_left = (signed) win.screen().maxLeft(head); |
44 | int head_right = (signed) win.screen().maxRight(head); | 57 | int head_right = (signed) win.screen().maxRight(head); |
45 | int head_top = (signed) win.screen().maxTop(head); | 58 | int head_top = (signed) win.screen().maxTop(head); |
46 | int head_bot = (signed) win.screen().maxBottom(head); | 59 | int head_bot = (signed) win.screen().maxBottom(head); |
47 | 60 | ||
48 | const ScreenPlacement &screen_placement = | 61 | const ScreenPlacement &screen_placement = win.screen().placementStrategy(); |
49 | dynamic_cast<const ScreenPlacement &>(win.screen().placementStrategy()); | ||
50 | s_row_dir = screen_placement.rowDirection(); | 62 | s_row_dir = screen_placement.rowDirection(); |
51 | s_col_dir = screen_placement.colDirection(); | 63 | s_col_dir = screen_placement.colDirection(); |
52 | 64 | ||
@@ -70,6 +82,7 @@ bool MinOverlapPlacement::placeWindow( | |||
70 | std::list<FluxboxWindow *>::const_reverse_iterator it = windowlist.rbegin(), | 82 | std::list<FluxboxWindow *>::const_reverse_iterator it = windowlist.rbegin(), |
71 | it_end = windowlist.rend(); | 83 | it_end = windowlist.rend(); |
72 | for (; it != it_end; ++it) { | 84 | for (; it != it_end; ++it) { |
85 | if (*it == &win) continue; | ||
73 | 86 | ||
74 | // get the dimensions of the window | 87 | // get the dimensions of the window |
75 | int left = (*it)->x() - (*it)->xOffset(); | 88 | int left = (*it)->x() - (*it)->xOffset(); |