]> Dogcows Code - chaz/openbox/commitdiff
only say xinerama is active if we can find some regions for it
authorDana Jansens <danakj@orodu.net>
Mon, 22 Jul 2002 05:37:10 +0000 (05:37 +0000)
committerDana Jansens <danakj@orodu.net>
Mon, 22 Jul 2002 05:37:10 +0000 (05:37 +0000)
src/BaseDisplay.cc

index 5aecac891772c891e1609d394c907c9b27f3adb9..305973ac183ec1a5681113728a20725f8f1275b4 100644 (file)
@@ -483,6 +483,8 @@ ScreenInfo::ScreenInfo(BaseDisplay *d, unsigned int num) {
     itostring(static_cast<unsigned long>(screen_number));
   
 #ifdef    XINERAMA
+  xinerama_active = False;
+
   if (d->hasXineramaExtensions()) {
     if (d->getXineramaMajorVersion() == 1) {
       // we know the version 1(.1?) protocol
@@ -492,8 +494,7 @@ ScreenInfo::ScreenInfo(BaseDisplay *d, unsigned int num) {
          in future versions we should be able, so the 'activeness' is checked
          on a pre-screen basis anyways.
       */
-      xinerama_active = XineramaIsActive(d->getXDisplay());
-      if (xinerama_active) {
+      if (XineramaIsActive(d->getXDisplay())) {
         /*
            If Xinerama is being used, there there is only going to be one screen
            present. We still, of course, want to use the screen class, but that
@@ -503,11 +504,16 @@ ScreenInfo::ScreenInfo(BaseDisplay *d, unsigned int num) {
         int num;
         XineramaScreenInfo *info = XineramaQueryScreens(d->getXDisplay(), &num);
         if (num > 0 && info) {
+          xinerama_areas.reserve(num);
           for (int i = 0; i < num; ++i) {
             xinerama_areas.push_back(Rect(info[i].x_org, info[i].y_org,
                                           info[i].width, info[i].height));
           }
           XFree(info);
+
+          // if we can't find any xinerama regions, then we act as if it is not
+          // active, even though it said it was
+          xinerama_active = True;
         }
       }
     }
This page took 0.024909 seconds and 4 git commands to generate.