summaryrefslogtreecommitdiffstats
path: root/x11vnc/xdamage.c
diff options
context:
space:
mode:
Diffstat (limited to 'x11vnc/xdamage.c')
-rw-r--r--x11vnc/xdamage.c31
1 files changed, 25 insertions, 6 deletions
diff --git a/x11vnc/xdamage.c b/x11vnc/xdamage.c
index 7b8b9b2..27e6613 100644
--- a/x11vnc/xdamage.c
+++ b/x11vnc/xdamage.c
@@ -163,8 +163,8 @@ void add_region_xdamage(sraRegionPtr new_region) {
}
reg = xdamage_regions[prev_tick];
- if (reg != NULL) {
-if (debug_xdamage > 1) fprintf(stderr, "add_region_xdamage: prev_tick: %d reg %p\n", prev_tick, (void *)reg);
+ if (reg != NULL && new_region != NULL) {
+if (debug_xdamage > 1) fprintf(stderr, "add_region_xdamage: prev_tick: %d reg %p new_region %p\n", prev_tick, (void *)reg, (void *)new_region);
sraRgnOr(reg, new_region);
}
}
@@ -232,6 +232,9 @@ if (call && debug_xdamage > 1) fprintf(stderr, "collect_macosx_damage: %d %d %d
if (! use_xdamage) {
return 0;
}
+ if (! xdamage_regions) {
+ return 0;
+ }
dtime0(&tm);
@@ -241,10 +244,15 @@ if (call && debug_xdamage > 1) fprintf(stderr, "collect_macosx_damage: %d %d %d
xdamage_ticker = (xdamage_ticker+1) % nreg;
xdamage_direct_count = 0;
reg = xdamage_regions[xdamage_ticker];
- sraRgnMakeEmpty(reg);
+ if (reg != NULL) {
+ sraRgnMakeEmpty(reg);
+ }
} else {
reg = xdamage_regions[xdamage_ticker];
}
+ if (reg == NULL) {
+ return 0;
+ }
if (x_in < 0) {
return 0;
@@ -288,8 +296,8 @@ if (call && debug_xdamage > 1) fprintf(stderr, "collect_macosx_damage: %d %d %d
}
if (debug_xdamage > 2) {
fprintf(stderr, "xdamage: -> event %dx%d+%d+%d area:"
- " %d dups: %d %s\n", w, h, x, y, w*h, dcount,
- (w*h > xdamage_max_area) ? "TOO_BIG" : "");
+ " %d dups: %d %s reg: %p\n", w, h, x, y, w*h, dcount,
+ (w*h > xdamage_max_area) ? "TOO_BIG" : "", (void *)reg);
}
record_desired_xdamage_rect(x, y, w, h);
@@ -365,6 +373,9 @@ int collect_xdamage(int scancnt, int call) {
if (! xdamage_base_event_type) {
return 0;
}
+ if (! xdamage_regions) {
+ return 0;
+ }
dtime0(&tm);
@@ -374,10 +385,15 @@ int collect_xdamage(int scancnt, int call) {
xdamage_ticker = (xdamage_ticker+1) % nreg;
xdamage_direct_count = 0;
reg = xdamage_regions[xdamage_ticker];
- sraRgnMakeEmpty(reg);
+ if (reg != NULL) {
+ sraRgnMakeEmpty(reg);
+ }
} else {
reg = xdamage_regions[xdamage_ticker];
}
+ if (reg == NULL) {
+ return 0;
+ }
X_LOCK;
@@ -549,6 +565,9 @@ int xdamage_hint_skip(int y) {
/* go back thru the history starting at most recent */
n = (xdamage_ticker + nreg - i) % nreg;
reg = xdamage_regions[n];
+ if (reg == NULL) {
+ continue;
+ }
if (sraRgnEmpty(reg)) {
/* checking for emptiness is very fast */
continue;