8 #include "workspaces.h"
10 xcb_intern_atom_cookie_t atom_cookies[NUM_ATOMS];
12 uint32_t get_colorpixel(const char *s) {
13 char strings[3][3] = { { s[0], s[1], '\0'} ,
15 { s[4], s[5], '\0'} };
16 uint8_t r = strtol(strings[0], NULL, 16);
17 uint8_t g = strtol(strings[1], NULL, 16);
18 uint8_t b = strtol(strings[2], NULL, 16);
19 return (r << 16 | g << 8 | b);
22 void handle_xcb_event(xcb_generic_event_t ev) {
27 /* FIXME: xcb_connect leaks Memory */
28 xcb_connection = xcb_connect(NULL, NULL);
29 if (xcb_connection_has_error(xcb_connection)) {
30 printf("Cannot open display\n");
33 printf("Connected to xcb\n");
35 /* We have to request the atoms we need */
36 #define ATOM_DO(name) atom_cookies[name] = xcb_intern_atom(xcb_connection, 0, strlen(#name), #name);
37 #include "xcb_atoms.def"
39 xcb_screens = xcb_setup_roots_iterator(xcb_get_setup(xcb_connection)).data;
40 xcb_root = xcb_screens->root;
42 /* FIXME: Maybe we can push that further backwards */
47 xcb_disconnect(xcb_connection);
51 xcb_intern_atom_reply_t* reply;
52 #define ATOM_DO(name) reply = xcb_intern_atom_reply(xcb_connection, atom_cookies[name], NULL); \
53 atoms[name] = reply->atom; \
56 #include "xcb_atoms.def"
57 printf("Got Atoms\n");
60 void destroy_windows() {
61 i3_output *walk = outputs;
63 if (walk->bar == XCB_NONE) {
66 xcb_destroy_window(xcb_connection, walk->bar);
71 void create_windows() {
75 i3_output* walk = outputs;
76 while (walk != NULL) {
81 printf("Creating Window for output %s\n", walk->name);
83 walk->bar = xcb_generate_id(xcb_connection);
84 mask = XCB_CW_BACK_PIXEL | XCB_CW_EVENT_MASK;
85 values[0] = xcb_screens->black_pixel;
86 values[1] = XCB_EVENT_MASK_EXPOSURE;
87 xcb_create_window(xcb_connection,
88 xcb_screens->root_depth,
91 walk->rect.x, walk->rect.y,
94 XCB_WINDOW_CLASS_INPUT_OUTPUT,
95 xcb_screens->root_visual,
99 xcb_change_property(xcb_connection,
100 XCB_PROP_MODE_REPLACE,
102 atoms[_NET_WM_WINDOW_TYPE],
106 (unsigned char*) &atoms[_NET_WM_WINDOW_TYPE_DOCK]);
108 walk->bargc = xcb_generate_id(xcb_connection);
109 xcb_create_gc(xcb_connection,
115 xcb_map_window(xcb_connection, walk->bar);
118 xcb_flush(xcb_connection);
121 void draw_buttons() {
122 printf("Drawing Buttons...\n");
123 i3_output *outputs_walk = outputs;
125 xcb_font_t button_font = xcb_generate_id(xcb_connection);
126 char *fontname = "-misc-fixed-medium-r-semicondensed--12-110-75-75-c-60-iso10646-1";
127 xcb_open_font(xcb_connection,
131 xcb_change_gc(xcb_connection,
135 while (outputs_walk != NULL) {
136 if (!outputs_walk->active) {
137 printf("Output %s inactive, skipping...\n", outputs_walk->name);
138 outputs_walk = outputs_walk->next;
141 if (outputs_walk->bar == XCB_NONE) {
144 uint32_t color = get_colorpixel("000000");
145 xcb_change_gc(xcb_connection,
149 xcb_rectangle_t rect = { 0, 0, outputs_walk->rect.w, 20 };
150 xcb_poly_fill_rectangle(xcb_connection,
155 i3_ws *ws_walk = workspaces;
156 while (ws_walk != NULL) {
157 if (ws_walk->output != outputs_walk) {
158 printf("WS %s on wrong output, skipping...\n", ws_walk->name);
159 ws_walk = ws_walk->next;
162 printf("Drawing Button for WS %s...\n", ws_walk->name);
163 uint32_t color = get_colorpixel("240000");
164 if (ws_walk->visible) {
165 color = get_colorpixel("480000");
167 if (ws_walk->urgent) {
168 color = get_colorpixel("002400");
170 xcb_change_gc(xcb_connection,
174 xcb_change_gc(xcb_connection,
178 xcb_rectangle_t rect = { i + 1, 1, 18, 18 };
179 xcb_poly_fill_rectangle(xcb_connection,
184 color = get_colorpixel("FFFFFF");
185 xcb_change_gc(xcb_connection,
189 xcb_image_text_8(xcb_connection,
190 strlen(ws_walk->name),
196 ws_walk = ws_walk->next;
198 outputs_walk = outputs_walk->next;
201 xcb_flush(xcb_connection);