summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDave Davenport <qball@gmpclient.org>2016-08-07 13:02:55 +0200
committerDave Davenport <qball@gmpclient.org>2016-08-07 13:02:55 +0200
commit0666e4bdb9d88d0b174e76928a06ecd172fe7802 (patch)
treee6f846206e99db3762685b1c78ed1e670a7e7f0a
parenta9fcdf2d8c345fb98b6a5376ff3b1f4f9e0b59db (diff)
Don't use xcb_aux_get_visualtype it fails, create own loop.issue438
-rw-r--r--source/view.c25
-rw-r--r--source/x11-helper.c18
2 files changed, 36 insertions, 7 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 );
diff --git a/source/x11-helper.c b/source/x11-helper.c
index 36d7d1d4..a182a78e 100644
--- a/source/x11-helper.c
+++ b/source/x11-helper.c
@@ -605,12 +605,28 @@ void x11_setup ( xkb_stuff *xkb )
x11_create_frequently_used_atoms ( );
}
+static xcb_visualtype_t * x11_search_for_visual ( void )
+{
+ xcb_depth_iterator_t depth_iter = xcb_screen_allowed_depths_iterator ( xcb->screen );
+ if ( depth_iter.data ) {
+ for (; depth_iter.rem; xcb_depth_next ( &depth_iter ) ) {
+ for ( xcb_visualtype_iterator_t visual_iter = xcb_depth_visuals_iterator ( depth_iter.data );
+ visual_iter.rem; xcb_visualtype_next ( &visual_iter ) ) {
+ if ( xcb->screen->root_visual == visual_iter.data->visual_id ) {
+ return visual_iter.data;
+ }
+ }
+ }
+ }
+ return NULL;
+}
+
void x11_create_visual_and_colormap ( void )
{
if ( visual != NULL ) {
return;
}
- visual = xcb_aux_get_visualtype ( xcb->connection, xcb->screen_nbr, xcb->screen->root_visual );
+ visual = x11_search_for_visual ();
if ( !visual ) {
g_error ( "Failed to find visual, giving up.\n" );
}