diff options
author | Dave Davenport <qball@gmpclient.org> | 2016-08-07 13:02:55 +0200 |
---|---|---|
committer | Dave Davenport <qball@gmpclient.org> | 2016-08-07 13:02:55 +0200 |
commit | 0666e4bdb9d88d0b174e76928a06ecd172fe7802 (patch) | |
tree | e6f846206e99db3762685b1c78ed1e670a7e7f0a /source/view.c | |
parent | a9fcdf2d8c345fb98b6a5376ff3b1f4f9e0b59db (diff) |
Don't use xcb_aux_get_visualtype it fails, create own loop.issue438
Diffstat (limited to 'source/view.c')
-rw-r--r-- | source/view.c | 25 |
1 files changed, 19 insertions, 6 deletions
diff --git a/source/view.c b/source/view.c index 5e205d36..7f159807 100644 --- a/source/view.c +++ b/source/view.c @@ -558,8 +558,8 @@ static void rofi_view_setup_fake_transparency ( void ) } void __create_window ( MenuFlags menu_flags ) { - uint32_t selmask = XCB_CW_BACK_PIXEL | XCB_CW_BORDER_PIXEL | XCB_CW_EVENT_MASK; - uint32_t selval[] = { + uint32_t selmask = XCB_CW_BACK_PIXEL | XCB_CW_BORDER_PIXEL | XCB_CW_EVENT_MASK; + uint32_t selval[] = { 0, 0, XCB_EVENT_MASK_EXPOSURE | XCB_EVENT_MASK_BUTTON_PRESS | XCB_EVENT_MASK_BUTTON_RELEASE | @@ -567,12 +567,25 @@ void __create_window ( MenuFlags menu_flags ) XCB_EVENT_MASK_STRUCTURE_NOTIFY | XCB_EVENT_MASK_FOCUS_CHANGE | XCB_EVENT_MASK_BUTTON_1_MOTION }; - xcb_window_t box = xcb_generate_id ( xcb->connection ); - xcb_create_window ( xcb->connection, XCB_COPY_FROM_PARENT, box, xcb_stuff_get_root_window ( xcb ), - 0, 0, 200, 100, 0, XCB_WINDOW_CLASS_INPUT_OUTPUT, - visual->visual_id, selmask, selval ); + xcb_window_t box = xcb_generate_id ( xcb->connection ); + xcb_void_cookie_t c = xcb_create_window_checked ( xcb->connection, XCB_COPY_FROM_PARENT, box, xcb_stuff_get_root_window ( xcb ), + 0, 0, 200, 100, 0, XCB_WINDOW_CLASS_INPUT_OUTPUT, + visual->visual_id, selmask, selval ); + + xcb_generic_error_t *e = xcb_request_check ( xcb->connection, c ); + if ( e ) { + fprintf ( stderr, "Failed to create X window: Error Code: %u\n", e->error_code ); + free ( e ); + g_error ( "Giving up.\n" ); + } CacheState.surface = cairo_xcb_surface_create ( xcb->connection, box, visual, 200, 100 ); + + cairo_status_t st = cairo_surface_status ( CacheState.surface ); + if ( st != CAIRO_STATUS_SUCCESS ) { + g_error ( "Failed to create cairo drawing surface: '%s'\n", cairo_status_to_string ( st ) ); + } + // Create a drawable. CacheState.draw = cairo_create ( CacheState.surface ); g_assert ( CacheState.draw != NULL ); |