xglcomp

changeset 9:245dd960f0b3

added xerror handling helpers
author John Tsiombikas <nuclear@member.fsf.org>
date Tue, 02 Feb 2016 12:54:02 +0200 (2016-02-02)
parents b0081a0c211f
children be18500d76d1
files src/main.cc src/xerr.cc src/xerr.h
diffstat 3 files changed, 58 insertions(+), 2 deletions(-) [+]
line diff
     1.1 --- a/src/main.cc	Sat Jan 30 07:58:07 2016 +0200
     1.2 +++ b/src/main.cc	Tue Feb 02 12:54:02 2016 +0200
     1.3 @@ -10,6 +10,8 @@
     1.4  #include "cwin.h"
     1.5  #include "opengl.h"
     1.6  #include "logger.h"
     1.7 +#include "xerr.h"
     1.8 +
     1.9  
    1.10  static bool query_extensions();
    1.11  static bool register_compositor();
    1.12 @@ -65,18 +67,20 @@
    1.13  		CompWindow *cwin;
    1.14  		switch(ev.type) {
    1.15  		case CreateNotify:
    1.16 +			log_debug("CreateNotify: %x\n", ev.xcreatewindow.window);
    1.17  			manage_window(ev.xcreatewindow.window);
    1.18  			break;
    1.19  
    1.20  		case ConfigureNotify:
    1.21  			// XXX is this right?
    1.22  			if((cwin = find_window_xid(ev.xconfigure.window))) {
    1.23 -				log_debug("updating window attributes\n");
    1.24 +				log_debug("updating window attributes for: %x\n", cwin->xwin);
    1.25  				XGetWindowAttributes(dpy, cwin->xwin, &cwin->attr);
    1.26  			}
    1.27  			break;
    1.28  
    1.29  		case DestroyNotify:
    1.30 +			log_debug("DestroyNotify: %x\n", ev.xdestroywindow.window);
    1.31  			unmanage_window(ev.xdestroywindow.window);
    1.32  			break;
    1.33  
    1.34 @@ -226,10 +230,13 @@
    1.35  {
    1.36  	XserverRegion region;
    1.37  	CompWindow *cwin = find_window_xid(ev->drawable);
    1.38 -	if(!cwin) return;
    1.39 +	if(!cwin || !cwin->damage) return;
    1.40  
    1.41  	region = XFixesCreateRegion(dpy, 0, 0);
    1.42 +
    1.43 +	push_xerr_handler(xerr_debug);
    1.44  	XDamageSubtract(dpy, cwin->damage, None, region);
    1.45 +	pop_xerr_handler();
    1.46  }
    1.47  
    1.48  static void redraw()
     2.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     2.2 +++ b/src/xerr.cc	Tue Feb 02 12:54:02 2016 +0200
     2.3 @@ -0,0 +1,35 @@
     2.4 +#include <stack>
     2.5 +#include "xerr.h"
     2.6 +#include "logger.h"
     2.7 +
     2.8 +static std::stack<xerr_handler_type> func_stack;
     2.9 +
    2.10 +void push_xerr_handler(xerr_handler_type func)
    2.11 +{
    2.12 +	func_stack.push(func);
    2.13 +	XSetErrorHandler(func);
    2.14 +}
    2.15 +
    2.16 +void pop_xerr_handler()
    2.17 +{
    2.18 +	if(func_stack.empty()) {
    2.19 +		log_error("attempt to pop_xerr_handler with an empty stack\n");
    2.20 +		return;
    2.21 +	}
    2.22 +	xerr_handler_type prev = func_stack.top();
    2.23 +	func_stack.pop();
    2.24 +	XSetErrorHandler(prev);
    2.25 +}
    2.26 +
    2.27 +int xerr_debug(Display *dpy, XErrorEvent *err)
    2.28 +{
    2.29 +	char errstr[512];
    2.30 +	XGetErrorText(dpy, err->error_code, errstr, sizeof errstr);
    2.31 +	printf("X error caught:\n%s\n", errstr);
    2.32 +	return 0;
    2.33 +}
    2.34 +
    2.35 +int xerr_ignore(Display *dpy, XErrorEvent *err)
    2.36 +{
    2.37 +	return 0;
    2.38 +}
     3.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     3.2 +++ b/src/xerr.h	Tue Feb 02 12:54:02 2016 +0200
     3.3 @@ -0,0 +1,14 @@
     3.4 +#ifndef XERR_H_
     3.5 +#define XERR_H_
     3.6 +
     3.7 +#include <X11/Xlib.h>
     3.8 +
     3.9 +typedef int (*xerr_handler_type)(Display*, XErrorEvent*);
    3.10 +
    3.11 +void push_xerr_handler(xerr_handler_type func);
    3.12 +void pop_xerr_handler();
    3.13 +
    3.14 +int xerr_debug(Display *dpy, XErrorEvent *err);
    3.15 +int xerr_ignore(Display *dpy, XErrorEvent *err);
    3.16 +
    3.17 +#endif	/* XERR_H_ */