$(PROG): main.o util.o sys-$(SYS).o wm-$(WM).o
$(CC) $(CFLAGS) -o $@ $+ $(LIBS)
-%.o: %.c $(wildcard *.h)
+%.o: %.c $(wildcard *.h) makefile
$(CC) --std=gnu99 $(CFLAGS) -c -o $@ $<
clean:
/* Internal structures */
struct win_sys {
HWND hwnd;
+ state_t state;
};
typedef struct {
return 1;
case HSHELL_WINDOWDESTROYED:
printf("ShlProc: %p - window destroyed\n", hwnd);
- if ((win = win_find(hwnd,0))) {
+ if ((win = win_find(hwnd,0)) &&
+ win->sys->state == st_show) {
wm_remove(win);
win_remove(win);
}
void sys_move(win_t *win, int x, int y, int w, int h)
{
printf("sys_move: %p - %d,%d %dx%d\n", win, x, y, w, h);
- win->x = MAX(x,0); win->y = MAX(y,0);
+ win->x = x; win->y = y;
win->w = MAX(w,1); win->h = MAX(h,1);
MoveWindow(win->sys->hwnd, win->x, win->y, win->w, win->h, TRUE);
}
AttachThreadInput(oldId, newId, FALSE);
}
+void sys_show(win_t *win, state_t state)
+{
+ static struct {
+ char *str;
+ int cmd;
+ } map[] = {
+ [st_show ] {"show" , SW_SHOW },
+ [st_full ] {"full" , SW_MAXIMIZE},
+ [st_shade] {"shade", SW_SHOW },
+ [st_icon ] {"icon" , SW_MINIMIZE},
+ [st_hide ] {"hide" , SW_HIDE },
+ };
+ win->sys->state = state;
+ printf("sys_show: %s\n", map[state].str);
+ ShowWindow(win->sys->hwnd, map[state].cmd);
+}
+
void sys_watch(win_t *win, Key_t key, mod_t mod)
{
(void)key2w; // TODO
printf("sys_unwatch: %p\n", win);
}
+BOOL CALLBACK Mon(HMONITOR mon, HDC dc, LPRECT rect, LPARAM _screens)
+{
+ MONITORINFO info = {.cbSize=sizeof(MONITORINFO)};
+ GetMonitorInfo(mon, &info);
+ RECT *work = &info.rcWork;
+
+ list_t **screens = (list_t**)_screens;
+ win_t *screen = new0(win_t);
+ screen->x = work->left;
+ screen->y = work->top;
+ screen->w = work->right - work->left;
+ screen->h = work->bottom - work->top;
+ *screens = list_append(*screens, screen);
+ printf("mon_proc: %d,%d %dx%d\n",
+ screen->x, screen->y, screen->w, screen->h);
+ return TRUE;
+}
+
+list_t *sys_info(win_t *win)
+{
+ list_t *screens = NULL;
+ EnumDisplayMonitors(NULL, NULL, Mon, (LPARAM)&screens);
+ return screens;
+}
+
win_t *sys_init(void)
{
HINSTANCE hInst = GetModuleHandle(NULL);
{
//printf("sys_move: %p - %d,%d %dx%d\n", win, x, y, w, h);
int b = 2*BORDER;
- win->x = MAX(x,0); win->y = MAX(y,0);
+ win->x = x; win->y = y;
win->w = MAX(w,1+b); win->h = MAX(h,1+b);
w = MAX(w-b,1); h = MAX(h-b,1);
XMoveResizeWindow(win->sys->dpy, win->sys->xid, x, y, w, h);
#define wm_tag wm->tag
#define wm_focus (wm_tag && wm_dpy && wm_col && wm_row ? wm_win : NULL)
+#define WIN(l) ((win_t*)(l)->data)
#define ROW(l) ((row_t*)(l)->data)
#define COL(l) ((col_t*)(l)->data)
#define DPY(l) ((dpy_t*)(l)->data)
if (key == key_f3) return sys_show(win, st_show), 1;
if (key == key_f4) return sys_show(win, st_hide), 1;
if (key == key_f5) return wm_update(), 1;
- if (key == key_f6) return print_txt(), 1;
+ if (key == key_f6) return print_txt(), 1;
}
if (key_mouse0 <= key && key <= key_mouse7)
sys_raise(win);
{
printf("wm_init: %p\n", root);
+ /* Hack, fix screen order */
+ list_t *screens = sys_info(root);
+ list_t *left = screens;
+ list_t *right = screens->next;
+ if (left && right && WIN(left)->x > WIN(right)->x) {
+ void *tmp = left->data;
+ left->data = right->data;
+ right->data = tmp;
+ }
+
wm = new0(wm_t);
wm->root = root;
- wm->screens = sys_info(root);
+ wm->screens = screens;
wm->tag = tag_new(wm->screens, 1);
wm->tags = list_insert(NULL, wm->tag);
'0', '1', '2', '3', '4', '5', '6', '7', '8', '9'};
Key_t keys_m[] = {'h', 'j', 'k', 'l', 'd', 's', 'm', 't',
'0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
- key_f1, key_f2, key_f3, key_f4, key_f5, key_f6,
+ /*key_f1, key_f2, key_f3, key_f4,*/ key_f5, key_f6,
key_mouse1, key_mouse3};
for (int i = 0; i < countof(keys_e); i++)
sys_watch(root, keys_e[i], MOD());