diff options
| -rw-r--r-- | x11vnc/8to24.c | 1 | ||||
| -rw-r--r-- | x11vnc/README | 2 | ||||
| -rw-r--r-- | x11vnc/connections.c | 1 | ||||
| -rw-r--r-- | x11vnc/cursor.c | 4 | ||||
| -rw-r--r-- | x11vnc/gui.c | 4 | ||||
| -rw-r--r-- | x11vnc/keyboard.c | 1 | ||||
| -rw-r--r-- | x11vnc/macosx.c | 13 | ||||
| -rw-r--r-- | x11vnc/macosxCG.c | 2 | ||||
| -rw-r--r-- | x11vnc/pointer.c | 1 | ||||
| -rw-r--r-- | x11vnc/scan.c | 22 | ||||
| -rw-r--r-- | x11vnc/screen.c | 1 | ||||
| -rw-r--r-- | x11vnc/solid.c | 1 | ||||
| -rw-r--r-- | x11vnc/user.c | 2 | ||||
| -rw-r--r-- | x11vnc/userinput.c | 136 | ||||
| -rw-r--r-- | x11vnc/userinput.h | 3 | ||||
| -rw-r--r-- | x11vnc/win_utils.c | 2 | ||||
| -rw-r--r-- | x11vnc/xwrappers.c | 4 | ||||
| -rw-r--r-- | x11vnc/xwrappers.h | 4 | 
18 files changed, 120 insertions, 84 deletions
| diff --git a/x11vnc/8to24.c b/x11vnc/8to24.c index 19061e6..b07e468 100644 --- a/x11vnc/8to24.c +++ b/x11vnc/8to24.c @@ -4,6 +4,7 @@  #include "scan.h"  #include "util.h"  #include "win_utils.h" +#include "xwrappers.h"  int multivis_count = 0;  int multivis_24count = 0; diff --git a/x11vnc/README b/x11vnc/README index 152561d..d1e44a6 100644 --- a/x11vnc/README +++ b/x11vnc/README @@ -1,5 +1,5 @@ -x11vnc README file                         Date: Thu Dec 28 00:14:27 EST 2006 +x11vnc README file                         Date: Thu Dec 28 10:42:34 EST 2006  The following information is taken from these URLs: diff --git a/x11vnc/connections.c b/x11vnc/connections.c index fd44018..50cf6cf 100644 --- a/x11vnc/connections.c +++ b/x11vnc/connections.c @@ -17,6 +17,7 @@  #include "xwrappers.h"  #include "xevents.h"  #include "macosxCG.h" +#include "userinput.h"  /*   * routines for handling incoming, outgoing, etc connections diff --git a/x11vnc/cursor.c b/x11vnc/cursor.c index 0f3b2c6..ab9218c 100644 --- a/x11vnc/cursor.c +++ b/x11vnc/cursor.c @@ -1227,6 +1227,8 @@ unsigned long get_cursor_serial(int mode) {  		return last_cursor;  	} else if (mode == 1) {  		return (unsigned long) last_index; +	} else { +		return (unsigned long) last_index;  	}  } @@ -1320,7 +1322,7 @@ fprintf(stderr, "sc: %d  %d/%d %d - %d %d\n", serial, w, h, cbpp, xhot, yhot);  			oldest = i;  			oldtime = curs_times[i];  		} -		if (serial == curs_index[i]) { +		if (serial == (int) curs_index[i]) {  			/*  			 * got a hit with an existing cursor,  			 * use that one. diff --git a/x11vnc/gui.c b/x11vnc/gui.c index f5b8a8a..28f4109 100644 --- a/x11vnc/gui.c +++ b/x11vnc/gui.c @@ -267,7 +267,9 @@ if (0) fprintf(stderr, "run_gui: %s -- %d %d\n", gui_xdisplay, connect_to_x11vnc  			initialize_x11vnc_remote_prop();  		} +#ifdef MACOSX  		macjump: +#endif  		signal(SIGUSR1, sigusr1);  		got_sigusr1 = 0; @@ -630,7 +632,9 @@ void do_gui(char *opts, int sleep) {  	}  	XCloseDisplay_wr(test_dpy); +#ifdef MACOSX  	startit: +#endif  	if (start_x11vnc) { diff --git a/x11vnc/keyboard.c b/x11vnc/keyboard.c index aedc021..a13a1b0 100644 --- a/x11vnc/keyboard.c +++ b/x11vnc/keyboard.c @@ -14,6 +14,7 @@  #include "v4l.h"  #include "linuxfb.h"  #include "uinput.h" +#include "macosx.h"  void get_keystate(int *keystate);  void clear_modifiers(int init); diff --git a/x11vnc/macosx.c b/x11vnc/macosx.c index 86833b9..ccea8df 100644 --- a/x11vnc/macosx.c +++ b/x11vnc/macosx.c @@ -48,12 +48,15 @@ void macosx_event_loop(void) {  	return;  }  char *macosx_console_guess(char *str, int *fd) { +	if (!str || !fd) {}  	return NULL;  }  void macosx_key_command(rfbBool down, rfbKeySym keysym, rfbClientPtr client) { +	if (!down || !keysym || !client) {}  	return;  }  void macosx_pointer_command(int mask, int x, int y, rfbClientPtr client) { +	if (!mask || !x || !y || !client) {}  	return;  }  char *macosx_get_fb_addr(void) { @@ -63,35 +66,45 @@ int macosx_get_cursor(void) {  	return 0;  }  int macosx_get_cursor_pos(int *x, int *y) { +	if (!x || !y) {}  	return 0;  }  void macosx_send_sel(char * str, int len) { +	if (!str || !len) {}  	return;  }  void macosx_set_sel(char * str, int len) { +	if (!str || !len) {}  	return;  }  int macosx_valid_window(Window w, XWindowAttributes* a) { +	if (!w || !a) {}  	return 0;  }  Status macosx_xquerytree(Window w, Window *root_return, Window *parent_return,      Window **children_return, unsigned int *nchildren_return) { +	if (!w || !root_return || !parent_return || !children_return || !nchildren_return) {}  	return (Status) 0;  }  void macosx_add_mapnotify(Window win, int level, int map) { +	if (!win || !level || !map) {}  	return;  }  void macosx_add_create(Window win, int level) { +	if (!win || !level) {}  	return;  }  void macosx_add_destroy(Window win, int level) { +	if (!win || !level) {}  	return;  }  void macosx_add_visnotify(Window win, int level, int obscured) { +	if (!win || !level || !obscured) {}  	return;  }  int macosx_checkevent(XEvent *ev) { +	if (!ev) {}  	return 0;  } diff --git a/x11vnc/macosxCG.c b/x11vnc/macosxCG.c index b7dd2e8..81175a4 100644 --- a/x11vnc/macosxCG.c +++ b/x11vnc/macosxCG.c @@ -6,6 +6,8 @@   * will not work!!   */ +void macosxCG_dummy(void) {} +  #if (defined(__MACH__) && defined(__APPLE__))  #include <ApplicationServices/ApplicationServices.h> diff --git a/x11vnc/pointer.c b/x11vnc/pointer.c index df7064b..d550160 100644 --- a/x11vnc/pointer.c +++ b/x11vnc/pointer.c @@ -15,6 +15,7 @@  #include "linuxfb.h"  #include "uinput.h"  #include "scan.h" +#include "macosx.h"  int pointer_queued_sent = 0; diff --git a/x11vnc/scan.c b/x11vnc/scan.c index 1251742..633917f 100644 --- a/x11vnc/scan.c +++ b/x11vnc/scan.c @@ -13,6 +13,7 @@  #include "unixpw.h"  #include "screen.h"  #include "macosx.h" +#include "userinput.h"  /*   * routines for scanning and reading the X11 display for changes, and @@ -2351,7 +2352,6 @@ static void blackout_regions(void) {   * are other issues...  use -fs 1.0 to disable.   */  int copy_screen(void) { -	int pixelsize = bpp/8;  	char *fbp;  	int i, y, block_size; @@ -2462,7 +2462,7 @@ static void snap_all_rawfb(void) {  }  int copy_snap(void) { -	int db = 1, pixelsize = bpp/8; +	int db = 1;  	char *fbp;  	int i, y, block_size;  	double dt; @@ -2872,7 +2872,9 @@ if (ncache > 0) {  		}  	} else {  #if !NO_X11 -		if (XCheckTypedEvent(dpy, MapNotify, &ev)) { +		if (raw_fb_str) { +			; +		} else if (XCheckTypedEvent(dpy, MapNotify, &ev)) {  			gotone = 1;  		} else if (XCheckTypedEvent(dpy, UnmapNotify, &ev)) {  			gotone = 2; @@ -2995,7 +2997,7 @@ int scan_for_updates(int count_only) {  	double frac2 = 0.35;  /* or 3rd */  	double frac3 = 0.02;  /* do scan_display() again after copy_tiles() */  	static double last_poll = 0.0; -	double dtmp; +	double dtmp = 0.0;  	if (unixpw_in_progress) return 0; @@ -3190,9 +3192,14 @@ int scan_for_updates(int count_only) {  	}  	if (unixpw_in_progress) return 0; +  /* XXX Y */  if (0 && tile_count > 20) print_tiles(); -//dtmp = dnow(); +#if 0 +dtmp = dnow(); +#else +dtmp = 0.0; +#endif  	if (old_copy_tile) {  		tile_diffs = copy_all_tiles(); @@ -3200,7 +3207,10 @@ if (0 && tile_count > 20) print_tiles();  		tile_diffs = copy_all_tile_runs();  	}  	SCAN_FATAL(tile_diffs); -//if (tile_count) fprintf(stderr, "XX copytile: %.4f  tile_count: %d\n", dnow() - dtmp, tile_count); + +#if 0 +if (tile_count) fprintf(stderr, "XX copytile: %.4f  tile_count: %d\n", dnow() - dtmp, tile_count); +#endif  	/*  	 * This backward pass for upward and left tiles complements what diff --git a/x11vnc/screen.c b/x11vnc/screen.c index 7b583fa..f61a866 100644 --- a/x11vnc/screen.c +++ b/x11vnc/screen.c @@ -701,7 +701,6 @@ void free_old_fb(void) {  void do_new_fb(int reset_mem) {  	XImage *fb; -	int i;  	/* for threaded we really should lock libvncserver out. */  	if (use_threads) { diff --git a/x11vnc/solid.c b/x11vnc/solid.c index f43d69d..a2bb3cf 100644 --- a/x11vnc/solid.c +++ b/x11vnc/solid.c @@ -4,6 +4,7 @@  #include "win_utils.h"  #include "xwrappers.h"  #include "connections.h" +#include "cleanup.h"  char *guess_desktop(void);  void solid_bg(int restore); diff --git a/x11vnc/user.c b/x11vnc/user.c index 7349c8b..cf7cbe4 100644 --- a/x11vnc/user.c +++ b/x11vnc/user.c @@ -980,7 +980,7 @@ void check_new_passwds(int force) {  }  rfbBool custom_passwd_check(rfbClientPtr cl, const char *response, int len) { -	char *input, *q, *cmd; +	char *input, *cmd;  	char num[16];  	int j, i, n, rc; diff --git a/x11vnc/userinput.c b/x11vnc/userinput.c index 31f1864..14605b3 100644 --- a/x11vnc/userinput.c +++ b/x11vnc/userinput.c @@ -18,6 +18,8 @@  #include "unixpw.h"  #include "macosx.h"  #include "macosxCGS.h" +#include "cursor.h" +#include "screen.h"  /*   * user input handling heuristics @@ -57,6 +59,9 @@ int fb_update_sent(int *count);  int check_user_input(double dt, double dtr, int tile_diffs, int *cnt);  void do_copyregion(sraRegionPtr region, int dx, int dy, int mode); +int check_ncache(int reset, int mode); +int find_rect(int idx, int x, int y, int w, int h); +  static void get_client_regions(int *req, int *mod, int *cpy, int *num) ;  static void parse_scroll_copyrect_str(char *scr);  static void parse_wireframe_str(char *wf); @@ -1825,7 +1830,7 @@ if (debug_scroll > 1) fprintf(stderr, "<<<-rfbDoCopyRect req: %d mod: %d cpy: %d  	iter = sraRgnGetReverseIterator(region, dx < 0, dy < 0);  	while(sraRgnIteratorNext(iter, &rect)) { -		int j, c, t, Dx, Dy; +		int j, c, t;  		x1 = rect.x1;  		y1 = rect.y1; @@ -1962,7 +1967,6 @@ void batch_copyregion(sraRegionPtr* region, int *dx, int *dy, int ncr, double de  	rfbClientIteratorPtr i;  	rfbClientPtr cl;  	int k, direct, mode, nrects = 0; -	int hid_cursor = 0;  /* XXX Y */ @@ -3178,7 +3182,7 @@ fprintf(stderr, "bo: %d/%lx\n", k, swin);  				continue;  			}  #endif -			if (boff <= swin && swin < boff + bwin) { +			if (boff <= (int) swin && (int) swin < boff + bwin) {  				;	/* blackouts */  			} else if (! stack_list[k].fetched ||  			    stack_list[k].time > tm + 2.0) { @@ -3556,7 +3560,7 @@ void clear_win_events(void) {  				trapped_xerror = 0;  			}  			XSetErrorHandler(old_handler); -			fprintf(stderr, " 0x%x\n", NPP_nwin); +			fprintf(stderr, " 0x%x\n", (unsigned int) NPP_nwin);  		}  #endif  } @@ -3627,6 +3631,7 @@ void ncache_pre_portions(Window orig_frame, Window frame, int *nidx_in, int try_      int orig_x, int orig_y, int orig_w, int orig_h, int x, int y, int w, int h, double ntim) {  	int nidx, np = ncache_pad; +	if (!ntim) {}  	*use_batch = 0;  	*nidx_in = -1;  	NPP_nreg = 0; @@ -3754,7 +3759,7 @@ void ncache_pre_portions(Window orig_frame, Window frame, int *nidx_in, int try_  	}  } -ncache_post_portions(int nidx, int use_batch, int orig_x, int orig_y, int orig_w, int orig_h, +void ncache_post_portions(int nidx, int use_batch, int orig_x, int orig_y, int orig_w, int orig_h,      int x, int y, int w, int h, double batch_delay, double ntim) {  	int np = ncache_pad; @@ -3957,7 +3962,7 @@ ncache_post_portions(int nidx, int use_batch, int orig_x, int orig_y, int orig_w  				sraRgnDestroy(batch_reg[k]);  			}  fprintf(stderr, "FB_COPY: %.4f XX did batch 0x%x %3d su: %dx%d+%d+%d  bs: %dx%d+%d+%d\n", dnow() - ntim, -	cache_list[nidx].win, nidx, su_w, su_h, su_x, su_y, bs_w, bs_h, bs_x, bs_y); +	(unsigned int) cache_list[nidx].win, nidx, su_w, su_h, su_x, su_y, bs_w, bs_h, bs_x, bs_y);  		}  		cache_list[nidx].x = x + np;  		cache_list[nidx].y = y + np; @@ -3994,7 +3999,7 @@ fprintf(stderr, "FB_COPY: %.4f XX did batch 0x%x %3d su: %dx%d+%d+%d  bs: %dx%d+  void do_copyrect_drag_move(Window orig_frame, Window frame, int *nidx, int try_batch,      int now_x, int now_y, int orig_w, int orig_h, int x, int y, int w, int h, double batch_delay) { -	int sent_copyrect, obscured; +	int sent_copyrect = 1, obscured = 0;  	int dx, dy;  	int use_batch = 0;  	double ntim = dnow(); @@ -4028,7 +4033,6 @@ fprintf(stderr, "FB_COPY: %.4f 3) FAILED.\n", dnow() - ntim);  	}  	sraRgnDestroy(r0);  	sraRgnDestroy(r1); -	sent_copyrect = 1;  	if (sent_copyrect) {  		if (use_batch) { @@ -4098,6 +4102,8 @@ fprintf(stderr, "FAW orig_frame unmapped.\n");  		}  		check_ncache(0, 2);  	} +#else +	if (!orig_frame || !frame || !flush) {}  #endif  } @@ -4153,7 +4159,7 @@ int check_wireframe(void) {  	int frame_changed = 0, drew_box = 0, got_2nd_pointer = 0;  	int try_copyrect_drag = 1, do_copyrect_drag = -1; -	int now_x, now_y, nidx = -1; +	int now_x = 0, now_y = 0, nidx = -1;  	double copyrect_drag_delay = -1.0;  	int try_batch = 1;	/* XXX Y */  	int mac_skip = 0; @@ -4170,7 +4176,6 @@ int check_wireframe(void) {  	double max_spin = wireframe_t3;  	double min_draw = wireframe_t4;  	int try_it = 0; -	Window desc[6];  	DB_SET  	if (unixpw_in_progress) return 0; @@ -4376,15 +4381,15 @@ if (db) fprintf(stderr, "INTERIOR\n");  			rfbCFD(1000);  		}  		if (bdown0 == 2) { -			int freq = 1;  			/*  			 * This is to just update display_button_mask  			 * which will also update got_local_pointer_input.  			 */ -			int px, py, x, y, w, h; -			Window frame;  			check_x11_pointer();  #if 0 +			/* what was this for? */ +			Window frame; +			int px, py, x, y, w, h;  #ifdef MACOSX  			if (macosx_console) {  				macosx_get_cursor_pos(&x, &y); @@ -4604,10 +4609,9 @@ fprintf(stderr, "*** NO GPI DRAW_BOX\n");  							}  							if (idx >= 0) {  								if (cache_list[idx].su_time > 0.0) { -									double min_draw0 = min_draw; +									/* XXX Y */  									min_draw *= 0.66;  									do_copyrect_drag = 1; -//fprintf(stderr, "min_draw: %.4f -> %.4f\n", min_draw0, min_draw);  								}  								nidx = idx;  							} @@ -4710,7 +4714,6 @@ if (db || db2) fprintf(stderr, "NO button_mask\n");  	} else {  		int spin_ms = (int) (spin * 1000 * 1000);  		int obscured, sent_copyrect = 0; -		int np = ncache_pad;  		int nidx = -1;  		int use_batch = 0; @@ -4732,11 +4735,11 @@ fprintf(stderr, "\nSEND_COPYRECT  %.4f %.4f\n", dnowx(), dnow() - ntim);  		if (! fb_push_wait(0.15, FB_COPY|FB_MOD)) { -fprintf(stderr, "FB_COPY failed, try one more...", dnow() - ntim); +fprintf(stderr, "FB_COPY failed, try one more... %.4f", dnow() - ntim);  			if (! fb_push_wait(0.15, FB_COPY|FB_MOD)) { -fprintf(stderr, "FB_COPY failed again!", dnow() - ntim); +fprintf(stderr, "FB_COPY failed again! %.4f", dnow() - ntim);  			}  		} @@ -5450,12 +5453,15 @@ fprintf(stderr, "check_wireframe: 1\n");  #if defined(NO_NCACHE) || (NO_X11 && !defined(MACOSX))  int check_ncache(int a, int b) { +	if (!a || !b) {}  	return;  }  int lookup_win_index(Window win) { +	if (!win) {}  	return -1;  }  int find_rect(int idx, int x, int y, int w, int h) { +	if (!idx || !x || !y || !w || !h) {}  	return 0;  }  #else @@ -5620,7 +5626,7 @@ int lookup_win_index(Window win) {  		}  	}  	if (idx < 0) { -fprintf(stderr, "recentC(fail): %d  0x%x\n", idx, win); +fprintf(stderr, "recentC(fail): %d  0x%x\n", idx, (unsigned int) win);  		s3++;  	}  	if (s1 + s2 + s3 >= 100) { @@ -5840,9 +5846,7 @@ int fr_FAILt = 0;  void expire_rects1(int idx, int w, int h, int *x_hit, int *y_hit, int big1, int big2, int cram) {  	sraRegionPtr r1, r2, r3; -	sraRectangleIterator *iter; -	sraRect rt; -	int x, y, n; +	int x = -1, y = -1, n;  	if (*x_hit < 0) {  		int i, k, old[10], N = 4; @@ -5901,7 +5905,7 @@ void expire_rects1(int idx, int w, int h, int *x_hit, int *y_hit, int big1, int  				int k_h = cache_list[ik].bs_h;  fprintf(stderr, ">>**--**>> found rect via EXPIRE: %d 0x%x -- %dx%d+%d+%d %d %d --  %dx%d+%d+%d  A: %d/%d\n", -    ik, cache_list[ik].win, w, h, x, y, *x_hit, *y_hit, k_w, k_h, k_x, k_y, k_w * k_h, w * h); +    ik, (unsigned int) cache_list[ik].win, w, h, x, y, *x_hit, *y_hit, k_w, k_h, k_x, k_y, k_w * k_h, w * h);  				free_rect(ik);  				fr_EXPIRE++; @@ -5994,7 +5998,7 @@ fprintf(stderr, ">>**--**>> found rect via FORCE: %dx%d+%d+%d -- %d %d\n", w, h,  void expire_rects2(int idx, int w, int h, int *x_hit, int *y_hit, int big1, int big2, int cram) {  	sraRegionPtr r1, r2, r3; -	int x, y, n, i, j, k; +	int x = -1, y = -1, n, i, j, k;  	int nwgt_max = 128, nwgt = 0;  	int type[128];  	int val[4][128]; @@ -6075,7 +6079,6 @@ fprintf(stderr, "Expire[%02d]   %9.5f  age=%9.4f  area=%8d  need=%8d\n", nwgt, 1  	if (do_force) {  		int corner_x, corner_y;  		int x0, y0; -		double nfac = 1.0;  		for (n = 1; n < ncache; n += 2) {  		    if (big1 && ncache > 2 && n == 1) { @@ -6198,7 +6201,7 @@ fprintf(stderr, "j=%2d  acc=%.6f r=%.6f\n", j, norm, r);  		int k_h = cache_list[ik].bs_h;  fprintf(stderr, ">>**--**>> found rect [%d] via RAN EXPIRE: %d 0x%x -- %dx%d+%d+%d %d %d --  %dx%d+%d+%d  A: %d/%d\n", -	get_bs_n(*y_hit), ik, cache_list[ik].win, w, h, x, y, *x_hit, *y_hit, k_w, k_h, k_x, k_y, k_w * k_h, w * h); +	get_bs_n(*y_hit), ik, (unsigned int) cache_list[ik].win, w, h, x, y, *x_hit, *y_hit, k_w, k_h, k_x, k_y, k_w * k_h, w * h);  		free_rect(ik);  		fr_EXPIRE++; @@ -6264,7 +6267,7 @@ void expire_rects(int idx, int w, int h, int *x_hit, int *y_hit, int big1, int b  }  int find_rect(int idx, int x, int y, int w, int h) { -	sraRegionPtr r1, r2, r3; +	sraRegionPtr r1, r2;  	sraRectangleIterator *iter;  	sraRect rt;  	int n, x_hit = -1, y_hit = -1; @@ -6544,6 +6547,8 @@ int valid_wr(int idx, Window win, XWindowAttributes *attr) {  			return valid_window(win, attr, 1);  		}  	} +#else +	if (!idx) {}  #endif  	return valid_window(win, attr, 1);  } @@ -6562,11 +6567,11 @@ int bs_save(int idx, int *nbatch) {  	w1 = cache_list[idx].width;  	h1 = cache_list[idx].height; -fprintf(stderr, "backingstore save:       0x%x  %3d \n", win, idx); +fprintf(stderr, "backingstore save:       0x%x  %3d \n", (unsigned int) win, idx);  	X_LOCK;  	if (! valid_wr(idx, win, &attr)) { -fprintf(stderr, "bs_save:    not a valid X window: 0x%x\n", win); +fprintf(stderr, "bs_save:    not a valid X window: 0x%x\n", (unsigned int) win);  /* XXX Y */  //		DELETE(idx);  		X_UNLOCK; @@ -6644,7 +6649,7 @@ int su_save(int idx, int *nbatch) {  	int dx, dy, rc = 1;  	sraRegionPtr r, r0; -fprintf(stderr, "save-unders save:        0x%x  %3d \n", win, idx); +fprintf(stderr, "save-unders save:        0x%x  %3d \n", (unsigned int) win, idx);  	x1 = cache_list[idx].x;  	y1 = cache_list[idx].y; @@ -6653,7 +6658,7 @@ fprintf(stderr, "save-unders save:        0x%x  %3d \n", win, idx);  	X_LOCK;  	if (! valid_wr(idx, win, &attr)) { -fprintf(stderr, "su_save:    not a valid X window: 0x%x\n", win); +fprintf(stderr, "su_save:    not a valid X window: 0x%x\n", (unsigned int) win);  /* XXX Y */  //		DELETE(idx);  		X_UNLOCK; @@ -6730,7 +6735,7 @@ int bs_restore(int idx, int *nbatch, int nopad) {  	int dx, dy;  	sraRegionPtr r, r0; -fprintf(stderr, "backingstore restore:    0x%x  %3d \n", win, idx); +fprintf(stderr, "backingstore restore:    0x%x  %3d \n", (unsigned int) win, idx);  	x1 = cache_list[idx].x;  	y1 = cache_list[idx].y; @@ -6739,7 +6744,7 @@ fprintf(stderr, "backingstore restore:    0x%x  %3d \n", win, idx);  	X_LOCK;  	if (! valid_wr(idx, win, &attr)) { -fprintf(stderr, "BS_restore: not a valid X window: 0x%x\n", win); +fprintf(stderr, "BS_restore: not a valid X window: 0x%x\n", (unsigned int) win);  		DELETE(idx);  		X_UNLOCK;  		return 0; @@ -6821,7 +6826,7 @@ int su_restore(int idx, int *nbatch, int nopad) {  	sraRegionPtr r, r0;  	int invalid = 0; -fprintf(stderr, "save-unders  restore:    0x%x  %3d \n", win, idx); +fprintf(stderr, "save-unders  restore:    0x%x  %3d \n", (unsigned int) win, idx);  	x1 = cache_list[idx].x;  	y1 = cache_list[idx].y; @@ -6830,7 +6835,7 @@ fprintf(stderr, "save-unders  restore:    0x%x  %3d \n", win, idx);  	X_LOCK;  	if (! valid_wr(idx, win, &attr)) { -fprintf(stderr, "SU_restore: not a valid X window: 0x%x\n", win); +fprintf(stderr, "SU_restore: not a valid X window: 0x%x\n", (unsigned int) win);  		invalid = 1;  		x2 = x1;  		y2 = y1; @@ -6931,7 +6936,7 @@ void check_zero_rects(void) {  }  void block_stats(void) { -	int n, k, area, s1, s2; +	int n, k, s1, s2;  	static int t = -1;  	int vcnt, icnt, tcnt, vtot = 0, itot = 0, ttot = 0;  	t++; @@ -6946,7 +6951,7 @@ void block_stats(void) {  			int y = cache_list[k].bs_y;  			int w = cache_list[k].bs_w;  			int h = cache_list[k].bs_h; -			int rc; +			int rc = 0;  			Window win = cache_list[k].win;  			if (win == None) {  				continue; @@ -6987,7 +6992,7 @@ void block_stats(void) {  			if (! rc && ! macosx_console) {  				char *u = getenv("USER");  				if (u && !strcmp(u, "runge"))	fprintf(stderr, "\a"); -				fprintf(stderr, "\n   *** UNRECLAIMED WINDOW: 0x%x  %dx%d+%d+%d\n\n", win, w, h, x, y); +				fprintf(stderr, "\n   *** UNRECLAIMED WINDOW: 0x%x  %dx%d+%d+%d\n\n", (unsigned int) win, w, h, x, y);  				DELETE(k);  			}  			if (t < 3 || (t % 4) == 0 || hack_val || macosx_console) { @@ -6996,7 +7001,7 @@ void block_stats(void) {  				if (t1 > 0.0) {t1 = dnow() - t1;} else {t1 = -1.0;}  				if (t2 > 0.0) {t2 = dnow() - t2;} else {t2 = -1.0;}  				fprintf(stderr, "     [%02d] %04d 0x%08x bs: %04dx%04d+%04d+%05d vw: %04dx%04d+%04d+%04d cl: %04dx%04d+%04d+%04d map=%d su=%9.3f bs=%9.3f\n", -				    n, k, win, w, h, x, y, attr.width, attr.height, attr.x, attr.y, +				    n, k, (unsigned int) win, w, h, x, y, attr.width, attr.height, attr.x, attr.y,  				    cache_list[k].width, cache_list[k].height, cache_list[k].x, cache_list[k].y,  				    attr.map_state == IsViewable, t1, t2);   			} @@ -7088,7 +7093,7 @@ void xselectinput(Window w, unsigned long evmask, int sync) {  	if (trapped_xioerror) {  		fprintf(stderr, "XSELECTINPUT: trapped XIO Error.");  	} -if (sync) fprintf(stderr, "XSELECTINPUT: 0x%x  sync=%d err=%d/%d\n", w, sync, trapped_xerror, trapped_xioerror); +if (sync) fprintf(stderr, "XSELECTINPUT: 0x%x  sync=%d err=%d/%d\n", (unsigned int) w, sync, trapped_xerror, trapped_xioerror);  }  Bool xcheckmaskevent(Display *d, long mask, XEvent *ev) { @@ -7122,23 +7127,19 @@ Window Ev_unmap[EVMAX];  sraRect Ev_rects[EVMAX];  int check_ncache(int reset, int mode) { -	static int last_map = -1;  	static double last_root = 0.0;  	static int first = 1;  	static int last_client_count = -1; -	int i, j, k, n, t;  +	int i, k, n;   	int n_CN = 0, n_RN = 0, n_DN = 0, n_ON = 0, n_MN = 0, n_UN = 0;  	int n_VN = 0, n_VN_p = 0, n_VN_u = 0;  	double now, refresh = 60.0;  	Window win, win2;  	XWindowAttributes attr; -	XEvent ev;  	unsigned long all_ev = SubstructureNotifyMask|StructureNotifyMask|VisibilityChangeMask;  	unsigned long win_ev = StructureNotifyMask|VisibilityChangeMask; -	Window awin0, awin1, awin2; -	int area0, area1, area2;  	int try_batch = 1; /* XXX Y */  	int use_batch = 0;  	int nreg = 0, *nbatch; @@ -7148,12 +7149,6 @@ int check_ncache(int reset, int mode) {  	int nrects = 0; -	Window resize_inc[16]; -	Window resize_dec[16]; -	XWindowAttributes attr_inc[16]; -	XWindowAttributes attr_dec[16]; -	int nresize = 16; -  #ifdef MACOSX  	if (! macosx_console) {  		RAWFB_RET(-1) @@ -7338,7 +7333,7 @@ fprintf(stderr, "DELETE(%d) %dx%d+%d+%d\n", k, cache_list[k].width, cache_list[k  			if (valid) {  				if (cache_list[k].create_cnt && attr.map_state != IsViewable && cache_list[k].map_cnt == 0) {  					if (cache_list[k].bs_x >= 0) { -fprintf(stderr, "Created window never mapped: freeing(%d) 0x%x\n", k, win); +fprintf(stderr, "Created window never mapped: freeing(%d) 0x%x\n", k, (unsigned int) win);  						free_rect(k);  					}  				} @@ -7384,7 +7379,7 @@ fprintf(stderr, "Created window never mapped: freeing(%d) 0x%x\n", k, win);  					} else if (aw * ah < 64 * 64) {  						;  					} else { -fprintf(stderr, "*NEW BS_save: 0x%x %d %d %d\n", win, aw, ah, cache_list[idx].map_state);  +fprintf(stderr, "*NEW BS_save: 0x%x %d %d %d\n", (unsigned int) win, aw, ah, cache_list[idx].map_state);   						bs_save(idx, bat);  					}  				} @@ -7438,15 +7433,15 @@ fprintf(stderr, "*NEW BS_save: 0x%x %d %d %d\n", win, aw, ah, cache_list[idx].ma  				n++;  				n_RN++;  			} else { -				Window w = None;  				/* skip rest */  #if 0 +				Window w = None;  if (type == DestroyNotify) w = Ev[n].xdestroywindow.window;  if (type == UnmapNotify)   w = Ev[n].xunmap.window;  if (type == MapNotify)     w = Ev[n].xmap.window;  if (type == Expose)        w = Ev[n].xexpose.window;  if (type == ConfigureNotify) w = Ev[n].xconfigure.window; -if (type != ConfigureNotify) fprintf(stderr, "root: skip %s  for 0x%x\n", Etype(type), w); +if (type != ConfigureNotify) fprintf(stderr, "root: skip %s  for 0x%x\n", Etype(type), (unsigned int) w);  #endif  			} @@ -7492,12 +7487,7 @@ fprintf(stderr, "\n"); rfbLog("IN  check_ncache() %d events.\n", n);  	for (i=0; i < n; i++) {  		XEvent ev = Ev[i]; -		int a, w, h, type, idx = -1; - -		type = ev.type; -		win  = ev.xany.window; -		Ev_win[i] = win; - +		Ev_win[i] = ev.xany.window;  	}  	if (try_batch) { @@ -7523,7 +7513,7 @@ fprintf(stderr, "\n"); rfbLog("IN  check_ncache() %d events.\n", n);  	X_LOCK;  	for (i=0; i < n; i++) {  		XEvent ev; -		int a, w, h, type, idx = -1; +		int type, idx = -1;  		if (Ev_done[i]) continue;  		win = Ev_win[i]; @@ -7573,14 +7563,14 @@ fprintf(stderr, "\n"); rfbLog("IN  check_ncache() %d events.\n", n);  						DELETE(idx);  					}  				} -fprintf(stderr, "root%02d: ** CreateNotify  0x%x  %3d  -- %dx%d+%d+%d valid=%d\n", i, win2, idx, w, h, x, y, valid); +fprintf(stderr, "root%02d: ** CreateNotify  0x%x  %3d  -- %dx%d+%d+%d valid=%d\n", i, (unsigned int) win2, idx, w, h, x, y, valid);  			} else if (type == ReparentNotify) {  				if (ev.xreparent.parent != rootwin) {  					win2 = ev.xreparent.window;  					if (win2 != rootwin) {  						idx = lookup_win_index(win2); -fprintf(stderr, "root%02d: ReparentNotifyRM 0x%x  %3d\n", i, win2, idx); +fprintf(stderr, "root%02d: ReparentNotifyRM 0x%x  %3d\n", i, (unsigned int) win2, idx);  						if (idx >= 0) {  							DELETE(idx);  						} @@ -7600,8 +7590,8 @@ fprintf(stderr, "root%02d: ReparentNotifyRM 0x%x  %3d\n", i, win2, idx);  					oabove = cache_list[idx].above;  				} -fprintf(stderr, "----%02d: ConfigureNotify  0x%x  %3d  -- above: 0x%x -> 0x%x  %dx%d+%d+%d\n", i, win, idx, -    oabove, ev.xconfigure.above, ev.xconfigure.width, ev.xconfigure.height, ev.xconfigure.x, ev.xconfigure.y); +fprintf(stderr, "----%02d: ConfigureNotify  0x%x  %3d  -- above: 0x%x -> 0x%x  %dx%d+%d+%d\n", i, (unsigned int) win, idx, +    (unsigned int) oabove, (unsigned int) ev.xconfigure.above, ev.xconfigure.width, ev.xconfigure.height, ev.xconfigure.x, ev.xconfigure.y);  				if (idx < 0) {  					continue; @@ -7619,12 +7609,12 @@ fprintf(stderr, "----%02d: ConfigureNotify  0x%x  %3d  -- above: 0x%x -> 0x%x  %  				if (x_old != x_new || y_old != y_new) {  					/* invalidate su */  					cache_list[idx].su_time = 0.0; -fprintf(stderr, "          invalidate su: 0x%x xy: %d/%d  %d/%d \n", win, x_old, y_old, x_new, y_new); +fprintf(stderr, "          invalidate su: 0x%x xy: %d/%d  %d/%d \n", (unsigned int) win, x_old, y_old, x_new, y_new);  				}  				if (w_old != w_new || h_old != h_new) {  					/* invalidate bs */  					cache_list[idx].bs_time = 0.0; -fprintf(stderr, "          invalidate bs: 0x%x wh: %d/%d  %d/%d \n", win, w_old, h_old, w_new, h_new); +fprintf(stderr, "          invalidate bs: 0x%x wh: %d/%d  %d/%d \n", (unsigned int) win, w_old, h_old, w_new, h_new);  				}  				cache_list[idx].x = x_new; @@ -7637,7 +7627,7 @@ fprintf(stderr, "          invalidate bs: 0x%x wh: %d/%d  %d/%d \n", win, w_old,  			} else if (type == VisibilityNotify) {  				int state = ev.xvisibility.state;  				idx = lookup_win_index(win); -fprintf(stderr, "----%02d: VisibilityNotify 0x%x  %3d  state: %s U/P %d/%d\n", i, win, idx, VState(state), n_VN_u, n_VN_p); +fprintf(stderr, "----%02d: VisibilityNotify 0x%x  %3d  state: %s U/P %d/%d\n", i, (unsigned int) win, idx, VState(state), n_VN_u, n_VN_p);  				if (idx < 0) {  					continue; @@ -7674,7 +7664,7 @@ fprintf(stderr, "----%02d: VisibilityNotify 0x%x  %3d  state: %s U/P %d/%d\n", i  			} else if (type == MapNotify) {  				idx = lookup_win_index(win); -fprintf(stderr, "----%02d: MapNotify        0x%x  %3d\n", i, win, idx); +fprintf(stderr, "----%02d: MapNotify        0x%x  %3d\n", i, (unsigned int) win, idx);  				if (idx < 0) {  					continue; @@ -7712,7 +7702,7 @@ fprintf(stderr, "----%02d: MapNotify        0x%x  %3d\n", i, win, idx);  			} else if (type == UnmapNotify) {  				idx = lookup_win_index(win); -fprintf(stderr, "----%02d: UnmapNotify      0x%x  %3d\n", i, win, idx); +fprintf(stderr, "----%02d: UnmapNotify      0x%x  %3d\n", i, (unsigned int) win, idx);  				if (idx < 0) {  					continue; @@ -7745,7 +7735,7 @@ fprintf(stderr, "----%02d: UnmapNotify      0x%x  %3d\n", i, win, idx);  					win2 = ev.xreparent.window;  					if (win2 != rootwin) {  						idx = lookup_win_index(win2); -fprintf(stderr, "----%02d: ReparentNotifyRM 0x%x  %3d\n", i, win2, idx); +fprintf(stderr, "----%02d: ReparentNotifyRM 0x%x  %3d\n", i, (unsigned int) win2, idx);  						if (idx >= 0) {  							DELETE(idx);  						} @@ -7756,7 +7746,7 @@ fprintf(stderr, "----%02d: ReparentNotifyRM 0x%x  %3d\n", i, win2, idx);  			} else if (type == DestroyNotify) {  				win2 = ev.xdestroywindow.window;  				idx = lookup_win_index(win2); -fprintf(stderr, "----%02d: DestroyNotify    0x%x  %3d\n", i, win2, idx); +fprintf(stderr, "----%02d: DestroyNotify    0x%x  %3d\n", i, (unsigned int) win2, idx);  				if (idx >= 0) {  					DELETE(idx); diff --git a/x11vnc/userinput.h b/x11vnc/userinput.h index 19185f0..d8b3313 100644 --- a/x11vnc/userinput.h +++ b/x11vnc/userinput.h @@ -37,4 +37,7 @@ extern int fb_update_sent(int *count);  extern int check_user_input(double dt, double dtr, int tile_diffs, int *cnt);  extern void do_copyregion(sraRegionPtr region, int dx, int dy, int mode); +extern int check_ncache(int reset, int mode); +extern int find_rect(int idx, int x, int y, int w, int h); +  #endif /* _X11VNC_USERINPUT_H */ diff --git a/x11vnc/win_utils.c b/x11vnc/win_utils.c index 27d3f5d..52e012e 100644 --- a/x11vnc/win_utils.c +++ b/x11vnc/win_utils.c @@ -290,7 +290,7 @@ void update_stack_list(void) {  	X_LOCK;  	for (k=0; k < stack_list_num; k++) {  		Window win = stack_list[k].win; -		if (win != None && boff <= win && win < boff + bwin) { +		if (win != None && boff <= (int) win && (int) win < boff + bwin) {  			;	/* special, blackout */  		} else if (!valid_window(win, &attr, 1)) {  			stack_list[k].valid = 0; diff --git a/x11vnc/xwrappers.c b/x11vnc/xwrappers.c index 5822ddc..14635a4 100644 --- a/x11vnc/xwrappers.c +++ b/x11vnc/xwrappers.c @@ -79,6 +79,10 @@ Bool XQueryPointer_wr(Display *display, Window w, Window *root_return,      Window *child_return, int *root_x_return, int *root_y_return,      int *win_x_return, int *win_y_return, unsigned int *mask_return); +Status XQueryTree_wr(Display *display, Window w, Window *root_return, +    Window *parent_return, Window **children_return, +    unsigned int *nchildren_return); +  int XFree_wr(void *data);  int XSelectInput_wr(Display *display, Window w, long event_mask); diff --git a/x11vnc/xwrappers.h b/x11vnc/xwrappers.h index 22ac1fc..488f211 100644 --- a/x11vnc/xwrappers.h +++ b/x11vnc/xwrappers.h @@ -76,6 +76,10 @@ extern Bool XQueryPointer_wr(Display *display, Window w, Window *root_return,      Window *child_return, int *root_x_return, int *root_y_return,      int *win_x_return, int *win_y_return, unsigned int *mask_return); +extern Status XQueryTree_wr(Display *display, Window w, Window *root_return, +    Window *parent_return, Window **children_return, +    unsigned int *nchildren_return); +  extern int XFree_wr(void *data);  extern int XSelectInput_wr(Display *display, Window w, long event_mask); | 
