Add monitor support
This commit is contained in:
parent
017b3859ee
commit
ff4fd40baa
1 changed files with 79 additions and 16 deletions
|
@ -10,6 +10,9 @@
|
||||||
#include <X11/Xlib.h>
|
#include <X11/Xlib.h>
|
||||||
#include <X11/Xatom.h>
|
#include <X11/Xatom.h>
|
||||||
#include <X11/Xutil.h>
|
#include <X11/Xutil.h>
|
||||||
|
#ifdef XINERAMA
|
||||||
|
#include <X11/extensions/Xinerama.h>
|
||||||
|
#endif
|
||||||
#include <X11/Xft/Xft.h>
|
#include <X11/Xft/Xft.h>
|
||||||
|
|
||||||
#include "drw.h"
|
#include "drw.h"
|
||||||
|
@ -42,14 +45,13 @@ static size_t cursor = 0;
|
||||||
static Atom clip, utf8;
|
static Atom clip, utf8;
|
||||||
static Window win;
|
static Window win;
|
||||||
static XIC xic;
|
static XIC xic;
|
||||||
static int mon = -1;
|
static int mon = 0;
|
||||||
|
|
||||||
static ClrScheme scheme[SchemeLast];
|
static ClrScheme scheme[SchemeLast];
|
||||||
static Display *dpy;
|
static Display *dpy;
|
||||||
static int screen;
|
static int screen;
|
||||||
static Window root;
|
static Window root;
|
||||||
static Drw *drw;
|
static Drw *drw;
|
||||||
static int sw, sh;
|
|
||||||
|
|
||||||
static int timed_out;
|
static int timed_out;
|
||||||
|
|
||||||
|
@ -105,7 +107,7 @@ insert(const char *str, ssize_t n) {
|
||||||
void
|
void
|
||||||
drawwin(void) {
|
drawwin(void) {
|
||||||
int curpos;
|
int curpos;
|
||||||
int x = 0, y = 0, bh, w;
|
int x = 0, y = 0, w;
|
||||||
char *sectext;
|
char *sectext;
|
||||||
int i;
|
int i;
|
||||||
int seccursor = 0;
|
int seccursor = 0;
|
||||||
|
@ -134,6 +136,7 @@ drawwin(void) {
|
||||||
|
|
||||||
for (i=0; text[i] != '\0'; i = nextrune(i, +1)) {
|
for (i=0; text[i] != '\0'; i = nextrune(i, +1)) {
|
||||||
strcat(sectext, secstring);
|
strcat(sectext, secstring);
|
||||||
|
|
||||||
if (i < cursor) {
|
if (i < cursor) {
|
||||||
for (n = seccursor + 1; n + 1 >= 0 && (sectext[n] & 0xc0) == 0x80;
|
for (n = seccursor + 1; n + 1 >= 0 && (sectext[n] & 0xc0) == 0x80;
|
||||||
n ++);
|
n ++);
|
||||||
|
@ -157,6 +160,14 @@ drawwin(void) {
|
||||||
void
|
void
|
||||||
setup(void){
|
setup(void){
|
||||||
int x, y;
|
int x, y;
|
||||||
|
Window pw;
|
||||||
|
XWindowAttributes wa;
|
||||||
|
#ifdef XINERAMA
|
||||||
|
unsigned int du;
|
||||||
|
int a, i, di, n, j, area = 0;
|
||||||
|
Window w, dw, *dws;
|
||||||
|
XineramaScreenInfo *info;
|
||||||
|
#endif
|
||||||
XSetWindowAttributes swa;
|
XSetWindowAttributes swa;
|
||||||
XIM xim;
|
XIM xim;
|
||||||
scheme[SchemeNorm].bg = drw_clr_create(drw, normbgcolor);
|
scheme[SchemeNorm].bg = drw_clr_create(drw, normbgcolor);
|
||||||
|
@ -166,11 +177,61 @@ setup(void){
|
||||||
clip = XInternAtom(dpy, "CLIPBOARD", False);
|
clip = XInternAtom(dpy, "CLIPBOARD", False);
|
||||||
utf8 = XInternAtom(dpy, "UTF8_STRING", False);
|
utf8 = XInternAtom(dpy, "UTF8_STRING", False);
|
||||||
bh = drw->fonts[0]->h + 2;
|
bh = drw->fonts[0]->h + 2;
|
||||||
mh = (pinentry->description && *(pinentry->description))? bh * 2 : bh;
|
mh = bh;
|
||||||
|
#ifdef XINERAMA
|
||||||
|
info = XineramaQueryScreens(dpy, &n);
|
||||||
|
|
||||||
|
if (info) {
|
||||||
|
XGetInputFocus(dpy, &w, &di);
|
||||||
|
if (mon >= 0 && mon < n) {
|
||||||
|
i = mon;
|
||||||
|
} else if (w != root && w != PointerRoot && w != None) {
|
||||||
|
/* find top-level window containing current input focus */
|
||||||
|
do {
|
||||||
|
if (XQueryTree(dpy, (pw = w), &dw, &w, &dws, &du) && dws) {
|
||||||
|
XFree(dws);
|
||||||
|
}
|
||||||
|
} while (w != root && w != pw);
|
||||||
|
/* find xinerama screen with which the window intersects most */
|
||||||
|
if (XGetWindowAttributes(dpy, pw, &wa)) {
|
||||||
|
for (j = 0; j < n; j++) {
|
||||||
|
a = INTERSECT(wa.x, wa.y, wa.width, wa.height, info[j]);
|
||||||
|
if (a > area) {
|
||||||
|
area = a;
|
||||||
|
i = j;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* no focused window is on screen, so use pointer location instead */
|
||||||
|
if (mon < 0 && !area
|
||||||
|
&& XQueryPointer(dpy, root, &dw, &dw, &x, &y, &di, &di, &du)) {
|
||||||
|
for (i = 0; i < n; i++) {
|
||||||
|
if (INTERSECT(x, y, 1, 1, info[i])) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
x = info[i].x_org;
|
||||||
|
y = info[i].y_org + (topbar ? 0 : info[i].height - mh);
|
||||||
|
mw = info[i].width;
|
||||||
|
XFree(info);
|
||||||
|
} else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
if (!XGetWindowAttributes(dpy, root, &wa)) {
|
||||||
|
die("could not get embedding window attributes: 0x%lx", root);
|
||||||
|
}
|
||||||
x = 0;
|
x = 0;
|
||||||
y = topbar ? 0 : sh - mh;
|
y = topbar ? 0 : wa.height - mh;
|
||||||
mw = sw;
|
mw = wa.width;
|
||||||
promptw = (pinentry->prompt && *(pinentry->prompt)) ? TEXTW(pinentry->prompt) : 0;
|
}
|
||||||
|
/* FIXME */
|
||||||
|
if (pinentry->prompt && *(pinentry->prompt)) {
|
||||||
|
promptw = TEXTW(pinentry->prompt);
|
||||||
|
} else {
|
||||||
|
promptw = 0;
|
||||||
|
}
|
||||||
inputw = mw-promptw;
|
inputw = mw-promptw;
|
||||||
swa.override_redirect = True;
|
swa.override_redirect = True;
|
||||||
swa.background_pixel = scheme[SchemeNorm].bg->pix;
|
swa.background_pixel = scheme[SchemeNorm].bg->pix;
|
||||||
|
@ -370,6 +431,7 @@ confirm(void) {
|
||||||
static int
|
static int
|
||||||
cmdhandler (pinentry_t recieved_pinentry) {
|
cmdhandler (pinentry_t recieved_pinentry) {
|
||||||
struct sigaction sa;
|
struct sigaction sa;
|
||||||
|
XWindowAttributes wa;
|
||||||
|
|
||||||
text[0]='\0';
|
text[0]='\0';
|
||||||
cursor = 0;
|
cursor = 0;
|
||||||
|
@ -383,9 +445,10 @@ cmdhandler (pinentry_t recieved_pinentry) {
|
||||||
}
|
}
|
||||||
screen = DefaultScreen(dpy);
|
screen = DefaultScreen(dpy);
|
||||||
root = RootWindow(dpy, screen);
|
root = RootWindow(dpy, screen);
|
||||||
sw = DisplayWidth(dpy, screen);
|
if (!XGetWindowAttributes(dpy, root, &wa)) {
|
||||||
sh = DisplayHeight(dpy, screen);
|
die("could not get embedding window attributes: 0x%lx", root);
|
||||||
drw = drw_create(dpy, screen, root, sw, sh);
|
}
|
||||||
|
drw = drw_create(dpy, screen, root, wa.width, wa.height);
|
||||||
drw_load_fonts(drw, fonts, LENGTH(fonts));
|
drw_load_fonts(drw, fonts, LENGTH(fonts));
|
||||||
if (!drw->fontcount) {
|
if (!drw->fontcount) {
|
||||||
die("No fonts could be loaded.\n");
|
die("No fonts could be loaded.\n");
|
||||||
|
|
Loading…
Reference in a new issue