Added initial support for Xlib cursor themes

I hope this time i got all right with git format-patch.

Signed-off-by: Tumin Alexander <iamtakingiteasy@eientei.org>
Signed-off-by: Uli Schlachter <psychon@znc.in>
This commit is contained in:
Tumin Alexander 2012-10-06 19:40:11 +04:00 committed by Uli Schlachter
parent ed9f218669
commit 531f8b415c
8 changed files with 24 additions and 25 deletions

View File

@ -32,6 +32,8 @@
#include <xcb/xinerama.h> #include <xcb/xinerama.h>
#include <xcb/xtest.h> #include <xcb/xtest.h>
#include <X11/Xlib-xcb.h>
#include "awesome.h" #include "awesome.h"
#include "spawn.h" #include "spawn.h"
#include "objects/client.h" #include "objects/client.h"
@ -369,7 +371,15 @@ main(int argc, char **argv)
sigaction(SIGSEGV, &sa, 0); sigaction(SIGSEGV, &sa, 0);
/* X stuff */ /* X stuff */
globalconf.connection = xcb_connect(NULL, &globalconf.default_screen); globalconf.display = XOpenDisplay(NULL);
if (globalconf.display == NULL) {
fatal("cannot open display");
}
globalconf.default_screen = XDefaultScreen(globalconf.display);
globalconf.connection = XGetXCBConnection(globalconf.display);
/* Double checking that connection is good and operatable with xcb */
if(xcb_connection_has_error(globalconf.connection)) if(xcb_connection_has_error(globalconf.connection))
fatal("cannot open display"); fatal("cannot open display");

View File

@ -132,6 +132,7 @@ pkg_check_modules(AWESOME_REQUIRED REQUIRED
glib-2.0 glib-2.0
cairo cairo
x11 x11
xcursor
xcb-randr xcb-randr
xcb-xtest xcb-xtest
xcb-xinerama xcb-xinerama

View File

@ -19,9 +19,6 @@
* *
*/ */
/* CURSORFONT */
#include <X11/Xlibint.h>
#include "common/xcursor.h" #include "common/xcursor.h"
#include "common/util.h" #include "common/util.h"
@ -137,25 +134,12 @@ xcursor_font_tostr(uint16_t c)
* \return Allocated cursor font. * \return Allocated cursor font.
*/ */
xcb_cursor_t xcb_cursor_t
xcursor_new(xcb_connection_t *conn, uint16_t cursor_font) xcursor_new(Display *conn, uint16_t cursor_font)
{ {
static xcb_font_t font = XCB_NONE;
static xcb_cursor_t xcursor[countof(xcursor_font)]; static xcb_cursor_t xcursor[countof(xcursor_font)];
/* Get the font for the cursor */ if (!xcursor[cursor_font]) {
if(!font) xcursor[cursor_font] = XcursorLibraryLoadCursor(conn, xcursor_font_tostr(cursor_font));
{
font = xcb_generate_id(conn);
xcb_open_font(conn, font, sizeof(CURSORFONT) - 1, CURSORFONT);
}
if(!xcursor[cursor_font])
{
xcursor[cursor_font] = xcb_generate_id(conn);
xcb_create_glyph_cursor(conn, xcursor[cursor_font], font, font,
cursor_font, cursor_font + 1,
0, 0, 0,
65535, 65535, 65535);
} }
return xcursor[cursor_font]; return xcursor[cursor_font];

View File

@ -25,9 +25,11 @@
#include <X11/cursorfont.h> #include <X11/cursorfont.h>
#include <xcb/xcb.h> #include <xcb/xcb.h>
#include <X11/Xcursor/Xcursor.h>
uint16_t xcursor_font_fromstr(const char *); uint16_t xcursor_font_fromstr(const char *);
const char * xcursor_font_tostr(uint16_t); const char * xcursor_font_tostr(uint16_t);
xcb_cursor_t xcursor_new(xcb_connection_t *, uint16_t); xcb_cursor_t xcursor_new(Display *, uint16_t);
#endif #endif
// vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80 // vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80

View File

@ -63,6 +63,8 @@ ARRAY_TYPE(drawin_t *, drawin)
/** Main configuration structure */ /** Main configuration structure */
typedef struct typedef struct
{ {
/** Xlib Display */
Display * display;
/** Connection ref */ /** Connection ref */
xcb_connection_t *connection; xcb_connection_t *connection;
/** Default screen number */ /** Default screen number */

View File

@ -82,7 +82,7 @@ luaA_mousegrabber_run(lua_State *L)
if(cfont) if(cfont)
{ {
xcb_cursor_t cursor = xcursor_new(globalconf.connection, cfont); xcb_cursor_t cursor = xcursor_new(globalconf.display, cfont);
luaA_registerfct(L, 1, &globalconf.mousegrabber); luaA_registerfct(L, 1, &globalconf.mousegrabber);

View File

@ -154,7 +154,7 @@ drawin_init(drawin_t *w)
| XCB_EVENT_MASK_POINTER_MOTION | XCB_EVENT_MASK_EXPOSURE | XCB_EVENT_MASK_POINTER_MOTION | XCB_EVENT_MASK_EXPOSURE
| XCB_EVENT_MASK_PROPERTY_CHANGE, | XCB_EVENT_MASK_PROPERTY_CHANGE,
globalconf.default_cmap, globalconf.default_cmap,
xcursor_new(globalconf.connection, xcursor_font_fromstr(w->cursor)) xcursor_new(globalconf.display, xcursor_font_fromstr(w->cursor))
}); });
/* Set the right properties */ /* Set the right properties */
@ -502,7 +502,7 @@ luaA_drawin_set_cursor(lua_State *L, drawin_t *drawin)
uint16_t cursor_font = xcursor_font_fromstr(buf); uint16_t cursor_font = xcursor_font_fromstr(buf);
if(cursor_font) if(cursor_font)
{ {
xcb_cursor_t cursor = xcursor_new(globalconf.connection, cursor_font); xcb_cursor_t cursor = xcursor_new(globalconf.display, cursor_font);
p_delete(&drawin->cursor); p_delete(&drawin->cursor);
drawin->cursor = a_strdup(buf); drawin->cursor = a_strdup(buf);
xwindow_set_cursor(drawin->window, cursor); xwindow_set_cursor(drawin->window, cursor);

2
root.c
View File

@ -298,7 +298,7 @@ luaA_root_cursor(lua_State *L)
if(cursor_font) if(cursor_font)
{ {
uint32_t change_win_vals[] = { xcursor_new(globalconf.connection, cursor_font) }; uint32_t change_win_vals[] = { xcursor_new(globalconf.display, cursor_font) };
xcb_change_window_attributes(globalconf.connection, xcb_change_window_attributes(globalconf.connection,
globalconf.screen->root, globalconf.screen->root,