summaryrefslogtreecommitdiffstats
path: root/x11vnc/xinerama.c
diff options
context:
space:
mode:
Diffstat (limited to 'x11vnc/xinerama.c')
-rw-r--r--x11vnc/xinerama.c75
1 files changed, 75 insertions, 0 deletions
diff --git a/x11vnc/xinerama.c b/x11vnc/xinerama.c
index 9097771..c54e7c4 100644
--- a/x11vnc/xinerama.c
+++ b/x11vnc/xinerama.c
@@ -227,6 +227,76 @@ static void blackout_tiles(void) {
}
}
+static int did_xinerama_clip = 0;
+
+void check_xinerama_clip(void) {
+#if LIBVNCSERVER_HAVE_LIBXINERAMA
+ int n, k, i, ev, er, juse = -1;
+ int score[32], is = 0;
+ XineramaScreenInfo *x;
+
+ if (!clip_str || !dpy) {
+ return;
+ }
+ if (sscanf(clip_str, "xinerama%d", &k) == 1) {
+ ;
+ } else if (sscanf(clip_str, "screen%d", &k) == 1) {
+ ;
+ } else {
+ return;
+ }
+
+ free(clip_str);
+ clip_str = NULL;
+
+ if (! XineramaQueryExtension(dpy, &ev, &er)) {
+ return;
+ }
+ if (! XineramaIsActive(dpy)) {
+ return;
+ }
+ x = XineramaQueryScreens(dpy, &n);
+ if (k < 0 || k >= n) {
+ XFree_wr(x);
+ return;
+ }
+ for (i=0; i < n; i++) {
+ score[is++] = nabs(x[i].x_org) + nabs(x[i].y_org);
+ if (is >= 32) {
+ break;
+ }
+ }
+ for (i=0; i <= k; i++) {
+ int j, jmon, mon = -1, mox = -1;
+ for (j=0; j < is; j++) {
+ if (mon < 0 || score[j] < mon) {
+ mon = score[j];
+ jmon = j;
+ }
+ if (mox < 0 || score[j] > mox) {
+ mox = score[j];
+ }
+ }
+ juse = jmon;
+ score[juse] = mox+1+i;
+ }
+
+ if (juse >= 0 && juse < n) {
+ char str[64];
+ sprintf(str, "%dx%d+%d+%d", x[juse].width, x[juse].height,
+ x[juse].x_org, x[juse].y_org);
+ clip_str = strdup(str);
+ did_xinerama_clip = 1;
+ } else {
+ clip_str = strdup("");
+ }
+ XFree_wr(x);
+ if (!quiet) {
+ rfbLog("set -clip to '%s' for xinerama%d\n", clip_str, k);
+ }
+#endif
+}
+
static void initialize_xinerama (void) {
#if !LIBVNCSERVER_HAVE_LIBXINERAMA
rfbLog("Xinerama: Library libXinerama is not available to determine\n");
@@ -305,6 +375,7 @@ static void initialize_xinerama (void) {
}
XFree_wr(xineramas);
+
if (sraRgnEmpty(black_region)) {
rfbLog("Xinerama: no blackouts needed (screen fills"
" rectangle)\n");
@@ -312,6 +383,10 @@ static void initialize_xinerama (void) {
sraRgnDestroy(black_region);
return;
}
+ if (did_xinerama_clip) {
+ rfbLog("Xinerama: no blackouts due to -clip xinerama.\n");
+ return;
+ }
/* max len is 10000x10000+10000+10000 (23 chars) per geometry */
rcnt = (int) sraRgnCountRects(black_region);