Skip to content

Commit

Permalink
Implement Xinerama support (not used yet)
Browse files Browse the repository at this point in the history
  • Loading branch information
stapelberg committed Jan 3, 2012
1 parent 02655d2 commit fd64bde
Show file tree
Hide file tree
Showing 5 changed files with 109 additions and 4 deletions.
8 changes: 4 additions & 4 deletions Makefile
Expand Up @@ -12,12 +12,12 @@ CFLAGS += -pipe
CFLAGS += -Wall
CPPFLAGS += -D_GNU_SOURCE
ifndef NOLIBCAIRO
CFLAGS += $(shell pkg-config --cflags cairo xcb-keysyms xcb-dpms)
LIBS += $(shell pkg-config --libs cairo xcb-keysyms xcb-dpms xcb-image)
CFLAGS += $(shell pkg-config --cflags cairo xcb-keysyms xcb-dpms xcb-xinerama)
LIBS += $(shell pkg-config --libs cairo xcb-keysyms xcb-dpms xcb-xinerama xcb-image)
else
CPPFLAGS += -DNOLIBCAIRO
CFLAGS += $(shell pkg-config --cflags xcb-keysyms xcb-dpms)
LIBS += $(shell pkg-config --libs xcb-keysyms xcb-dpms xcb-image)
CFLAGS += $(shell pkg-config --cflags xcb-keysyms xcb-dpms xcb-xinerama)
LIBS += $(shell pkg-config --libs xcb-keysyms xcb-dpms xcb-image xcb-xinerama)
endif
LIBS += -lpam
LIBS += -lev
Expand Down
4 changes: 4 additions & 0 deletions i3lock.c
Expand Up @@ -36,6 +36,7 @@
#include "xcb.h"
#include "cursors.h"
#include "unlock_indicator.h"
#include "xinerama.h"

char color[7] = "ffffff";
uint32_t last_resolution[2];
Expand Down Expand Up @@ -618,6 +619,9 @@ int main(int argc, char *argv[]) {
xcb_connection_has_error(conn))
errx(EXIT_FAILURE, "Could not connect to X11, maybe you need to set DISPLAY?");

xinerama_init();
xinerama_query_screens();

/* if DPMS is enabled, check if the X server really supports it */
if (dpms) {
xcb_dpms_capable_cookie_t dpmsc = xcb_dpms_capable(conn);
Expand Down
1 change: 1 addition & 0 deletions xcb.h
Expand Up @@ -2,6 +2,7 @@
#define _XCB_H

#include <xcb/xcb.h>
#include <xcb/xcb_keysyms.h>

extern xcb_connection_t *conn;
extern xcb_screen_t *screen;
Expand Down
86 changes: 86 additions & 0 deletions xinerama.c
@@ -0,0 +1,86 @@
/*
* vim:ts=4:sw=4:expandtab
*
* © 2010-2012 Michael Stapelberg
*
* See LICENSE for licensing information
*
*/
#include <stdbool.h>
#include <stdlib.h>
#include <stdio.h>
#include <math.h>
#include <xcb/xcb.h>
#include <xcb/xinerama.h>

#include "xcb.h"
#include "xinerama.h"

/* Number of Xinerama screens which are currently present. */
int xr_screens = 0;

/* The resolutions of the currently present Xinerama screens. */
Rect *xr_resolutions;

static bool xinerama_active;

void xinerama_init() {
if (!xcb_get_extension_data(conn, &xcb_xinerama_id)->present) {
printf("Xinerama extension not found, disabling.\n");
return;
}

xcb_xinerama_is_active_cookie_t cookie;
xcb_xinerama_is_active_reply_t *reply;

cookie = xcb_xinerama_is_active(conn);
reply = xcb_xinerama_is_active_reply(conn, cookie, NULL);
if (!reply)
return;

if (!reply->state) {
free(reply);
return;
}

xinerama_active = true;
}

void xinerama_query_screens() {
if (!xinerama_active)
return;

xcb_xinerama_query_screens_cookie_t cookie;
xcb_xinerama_query_screens_reply_t *reply;
xcb_xinerama_screen_info_t *screen_info;

cookie = xcb_xinerama_query_screens_unchecked(conn);
reply = xcb_xinerama_query_screens_reply(conn, cookie, NULL);
if (!reply) {
fprintf(stderr, "Couldn't get Xinerama screens\n");
return;
}
screen_info = xcb_xinerama_query_screens_screen_info(reply);
int screens = xcb_xinerama_query_screens_screen_info_length(reply);

Rect *resolutions = malloc(screens * sizeof(Rect));
/* No memory? Just keep on using the old information. */
if (!resolutions) {
free(reply);
return;
}
xr_resolutions = resolutions;
xr_screens = screens;

for (int screen = 0; screen < xr_screens; screen++) {
xr_resolutions[screen].x = screen_info[screen].x_org;
xr_resolutions[screen].y = screen_info[screen].y_org;
xr_resolutions[screen].width = screen_info[screen].width;
xr_resolutions[screen].height = screen_info[screen].height;
printf("found Xinerama screen: %d x %d at %d x %d\n",
screen_info[screen].width, screen_info[screen].height,
screen_info[screen].x_org, screen_info[screen].y_org);
}

free(reply);
}
14 changes: 14 additions & 0 deletions xinerama.h
@@ -0,0 +1,14 @@
#ifndef _XINERAMA_H
#define _XINERAMA_H

typedef struct Rect {
int16_t x;
int16_t y;
uint16_t width;
uint16_t height;
} Rect;

void xinerama_init();
void xinerama_query_screens();

#endif

0 comments on commit fd64bde

Please sign in to comment.