aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorfluxgen <fluxgen>2003-06-30 18:04:48 (GMT)
committerfluxgen <fluxgen>2003-06-30 18:04:48 (GMT)
commit952759281aab207016eaaac2b6cfc9e6b4a1ab71 (patch)
tree1640d678256f74208522beb6ac7187957c30f40c
parent3598527d190af3e1f0874b6fc47fed86e19faac4 (diff)
downloadfluxbox_paul-952759281aab207016eaaac2b6cfc9e6b4a1ab71.zip
fluxbox_paul-952759281aab207016eaaac2b6cfc9e6b4a1ab71.tar.bz2
fixed xinerama bug in maximization stop
-rw-r--r--src/Screen.cc28
1 files changed, 19 insertions, 9 deletions
diff --git a/src/Screen.cc b/src/Screen.cc
index fb6d518..ab1b707 100644
--- a/src/Screen.cc
+++ b/src/Screen.cc
@@ -22,7 +22,7 @@
22// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER 22// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
23// DEALINGS IN THE SOFTWARE. 23// DEALINGS IN THE SOFTWARE.
24 24
25// $Id: Screen.cc,v 1.197 2003/06/30 15:31:54 fluxgen Exp $ 25// $Id: Screen.cc,v 1.198 2003/06/30 18:04:48 fluxgen Exp $
26 26
27 27
28#include "Screen.hh" 28#include "Screen.hh"
@@ -565,30 +565,40 @@ Pixmap BScreen::rootPixmap() const {
565} 565}
566 566
567unsigned int BScreen::maxLeft(int head) const { 567unsigned int BScreen::maxLeft(int head) const {
568 // we ignore strut if we're doing full maximization
568 if (hasXinerama()) 569 if (hasXinerama())
569 return getHeadX(head); 570 return doFullMax() ? getHeadX(head) :
570 else // we ignore strut if we're doing full maximization 571 getHeadX(head) + m_available_workspace_area->left();
572 else
571 return doFullMax() ? 0 : m_available_workspace_area->left(); 573 return doFullMax() ? 0 : m_available_workspace_area->left();
572} 574}
573 575
574unsigned int BScreen::maxRight(int head) const { 576unsigned int BScreen::maxRight(int head) const {
577 // we ignore strut if we're doing full maximization
575 if (hasXinerama()) 578 if (hasXinerama())
576 return getHeadX(head) + getHeadWidth(head); 579 return doFullMax() ? getHeadX(head) + getHeadWidth(head) :
577 else // we ignore strut if we're doing full maximization 580 getHeadX(head) + getHeadWidth(head) - m_available_workspace_area->right();
581 else
578 return doFullMax() ? width() : width() - m_available_workspace_area->right(); 582 return doFullMax() ? width() : width() - m_available_workspace_area->right();
579} 583}
580 584
581unsigned int BScreen::maxTop(int head) const { 585unsigned int BScreen::maxTop(int head) const {
586
587 // we ignore strut if we're doing full maximization
588
582 if (hasXinerama()) 589 if (hasXinerama())
583 return getHeadY(head); 590 return doFullMax() ? getHeadY(head) : getHeadY(head) + m_available_workspace_area->top();
584 else // we ignore strut if we're doing full maximization 591 else
585 return doFullMax() ? 0 : m_available_workspace_area->top(); 592 return doFullMax() ? 0 : m_available_workspace_area->top();
586} 593}
587 594
588unsigned int BScreen::maxBottom(int head) const { 595unsigned int BScreen::maxBottom(int head) const {
596 // we ignore strut if we're doing full maximization
597
589 if (hasXinerama()) 598 if (hasXinerama())
590 return getHeadY(head) + getHeadHeight(head); 599 return doFullMax() ? getHeadY(head) + getHeadHeight(head) :
591 else // we ignore strut if we're doing full maximization 600 getHeadY(head) + getHeadHeight(head) - m_available_workspace_area->bottom();
601 else
592 return doFullMax() ? height() : height() - m_available_workspace_area->bottom(); 602 return doFullMax() ? height() : height() - m_available_workspace_area->bottom();
593} 603}
594 604