Merge remote-tracking branch '4z3/set-user-specified-sizehints' into sizehints

Conflicts:
	window.c
This commit is contained in:
Bert Münnich 2013-02-09 01:21:57 +01:00
commit bf41012493
3 changed files with 53 additions and 19 deletions

1
main.c
View file

@ -26,7 +26,6 @@
#include <sys/select.h> #include <sys/select.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <sys/time.h> #include <sys/time.h>
#include <X11/Xutil.h>
#include <X11/keysym.h> #include <X11/keysym.h>
#include "types.h" #include "types.h"

View file

@ -127,6 +127,9 @@ void win_init(win_t *win)
win->bar.bgcol = win_alloc_color(win, BAR_BG_COLOR); win->bar.bgcol = win_alloc_color(win, BAR_BG_COLOR);
win->bar.fgcol = win_alloc_color(win, BAR_FG_COLOR); win->bar.fgcol = win_alloc_color(win, BAR_FG_COLOR);
win->sizehints.flags = PWinGravity;
win->sizehints.win_gravity = NorthWestGravity;
if (setlocale(LC_CTYPE, "") == NULL || XSupportsLocale() == 0) if (setlocale(LC_CTYPE, "") == NULL || XSupportsLocale() == 0)
warn("no locale support"); warn("no locale support");
@ -137,17 +140,24 @@ void win_init(win_t *win)
void win_set_sizehints(win_t *win) void win_set_sizehints(win_t *win)
{ {
XSizeHints sizehints;
if (win == NULL || win->xwin == None) if (win == NULL || win->xwin == None)
return; return;
sizehints.flags = PMinSize | PMaxSize; if ((win->sizehints.flags & PMinSize) == 1) {
sizehints.min_width = win->w; win->sizehints.min_width = win->w;
sizehints.max_width = win->w; win->sizehints.min_height = win->h + win->bar.h;
sizehints.min_height = win->h + win->bar.h; }
sizehints.max_height = win->h + win->bar.h; if ((win->sizehints.flags & PMaxSize) == 1) {
XSetWMNormalHints(win->env.dpy, win->xwin, &sizehints); win->sizehints.max_width = win->w;
win->sizehints.max_height = win->h + win->bar.h;
}
if ((win->sizehints.flags & USPosition) == 1) {
win->sizehints.x = win->x;
win->sizehints.y = win->y;
}
XSetWMNormalHints(win->env.dpy, win->xwin, &win->sizehints);
} }
void win_open(win_t *win) void win_open(win_t *win)
@ -170,22 +180,42 @@ void win_open(win_t *win)
else else
gmask = XParseGeometry(options->geometry, &win->x, &win->y, gmask = XParseGeometry(options->geometry, &win->x, &win->y,
&win->w, &win->h); &win->w, &win->h);
if ((gmask & WidthValue) == 0) if ((gmask & WidthValue) == 0) {
win->w = WIN_WIDTH; win->w = WIN_WIDTH;
} else {
win->sizehints.flags |= USSize;
}
if (win->w > e->scrw) if (win->w > e->scrw)
win->w = e->scrw; win->w = e->scrw;
if ((gmask & HeightValue) == 0) if ((gmask & HeightValue) == 0) {
win->h = WIN_HEIGHT; win->h = WIN_HEIGHT;
} else {
win->sizehints.flags |= USSize;
}
if (win->h > e->scrh) if (win->h > e->scrh)
win->h = e->scrh; win->h = e->scrh;
if ((gmask & XValue) == 0) if ((gmask & XValue) == 0) {
win->x = (e->scrw - win->w) / 2; win->x = (e->scrw - win->w) / 2;
else if ((gmask & XNegative) != 0) } else {
if ((gmask & XNegative) != 0) {
win->x += e->scrw - win->w; win->x += e->scrw - win->w;
if ((gmask & YValue) == 0) win->sizehints.win_gravity = NorthEastGravity;
}
win->sizehints.flags |= USPosition;
}
if ((gmask & YValue) == 0) {
win->y = (e->scrh - win->h) / 2; win->y = (e->scrh - win->h) / 2;
else if ((gmask & YNegative) != 0) } else {
if ((gmask & YNegative) != 0) {
win->y += e->scrh - win->h; win->y += e->scrh - win->h;
if (win->sizehints.win_gravity == NorthEastGravity) {
win->sizehints.win_gravity = SouthEastGravity;
} else {
win->sizehints.win_gravity = SouthWestGravity;
}
}
win->sizehints.flags |= USPosition;
}
win->xwin = XCreateWindow(e->dpy, RootWindow(e->dpy, e->scr), win->xwin = XCreateWindow(e->dpy, RootWindow(e->dpy, e->scr),
win->x, win->y, win->w, win->h, 0, win->x, win->y, win->w, win->h, 0,
@ -225,6 +255,8 @@ void win_open(win_t *win)
} }
if (options->fixed_win) if (options->fixed_win)
win->sizehints.flags |= PMinSize | PMaxSize;
win_set_sizehints(win); win_set_sizehints(win);
XMapWindow(e->dpy, win->xwin); XMapWindow(e->dpy, win->xwin);
@ -300,7 +332,7 @@ bool win_moveresize(win_t *win, int x, int y, unsigned int w, unsigned int h)
win->w = w; win->w = w;
win->h = h - win->bar.h; win->h = h - win->bar.h;
if (options->fixed_win)
win_set_sizehints(win); win_set_sizehints(win);
XMoveResizeWindow(win->env.dpy, win->xwin, x, y, w, h); XMoveResizeWindow(win->env.dpy, win->xwin, x, y, w, h);

View file

@ -20,6 +20,7 @@
#define WINDOW_H #define WINDOW_H
#include <X11/Xlib.h> #include <X11/Xlib.h>
#include <X11/Xutil.h>
#include "types.h" #include "types.h"
@ -48,6 +49,8 @@ typedef struct {
unsigned int h; /* = win height - bar height */ unsigned int h; /* = win height - bar height */
unsigned int bw; unsigned int bw;
XSizeHints sizehints;
bool fullscreen; bool fullscreen;
struct { struct {