summaryrefslogtreecommitdiff
path: root/cmdtree.c
diff options
context:
space:
mode:
authorWilliam Casarin <jb55@jb55.com>2018-07-09 10:19:59 -0700
committerWilliam Casarin <jb55@jb55.com>2018-07-09 10:19:59 -0700
commit55ae285ef587942dc34c5f95b7f97037deb791a2 (patch)
treeb9d1ce96f5ca0b43c207e88360cd6dff20b836d6 /cmdtree.c
parentd1dea11d1091b4eacefb8be73a0740f87444fe29 (diff)
getting there
Diffstat (limited to 'cmdtree.c')
-rw-r--r--cmdtree.c154
1 files changed, 121 insertions, 33 deletions
diff --git a/cmdtree.c b/cmdtree.c
index 142bbb8..408e8c8 100644
--- a/cmdtree.c
+++ b/cmdtree.c
@@ -1,36 +1,70 @@
-#include <X11/Xlib.h>
-#include <X11/Xutil.h>
-#include <X11/Xresource.h>
-
#include <stdarg.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
+#include <time.h>
+#include <X11/Xlib.h>
+#include <X11/Xutil.h>
+#include <X11/Xresource.h>
+#include <X11/Xft/Xft.h>
#include <unistd.h>
+#include <assert.h>
+#include "drw.h"
#include "util.h"
+enum {
+ SchemeNorm,
+ SchemeSel,
+ SchemeOut,
+ SchemeLast,
+}; /* color schemes */
+
static Window root, parentwin, win;
static int screen;
static Display *display;
static int mw, mh;
-static unsigned int lines = 0;
static XIC xic;
+static Clr *scheme[SchemeLast];
+
+#include "config.h"
-// config
-static int topbar = 1;
static void
-setup()
+grabkeyboard(void)
{
- int x, y;
+ struct timespec ts = { .tv_sec = 0, .tv_nsec = 1000000 };
+ int i;
+
+ // XXXembed
+ /* if (embed) */
+ /* return; */
+ /* try to grab keyboard, we may have to wait for another process to ungrab */
+ for (i = 0; i < 1000; i++) {
+ if (XGrabKeyboard(display, DefaultRootWindow(display), True,
+ GrabModeAsync, GrabModeAsync, CurrentTime)
+ == GrabSuccess)
+ return;
+ nanosleep(&ts, NULL);
+ }
+ die("cannot grab keyboard");
+}
+
+static void
+setup(Drw *drw)
+{
+ int x, y, j;
XSetWindowAttributes swa;
XWindowAttributes wa;
XIM xim;
XClassHint ch = {"cmdtree", "cmdtree"};
+ /* init appearance */
+ for (j = 0; j < SchemeLast; j++)
+ scheme[j] = drw_scm_create(drw, colors[j], 2);
+
if (!XGetWindowAttributes(display, parentwin, &wa))
die("could not get embedding window attributes: 0x%lx",
parentwin);
@@ -42,7 +76,7 @@ setup()
mh = 100;
swa.override_redirect = True;
- /* swa.background_pixel = scheme[SchemeNorm][ColBg].pixel; */
+ swa.background_pixel = scheme[SchemeNorm][ColBg].pixel;
swa.event_mask = ExposureMask | KeyPressMask | VisibilityChangeMask;
win = XCreateWindow(display, parentwin, x, y, mw, mh, 0,
@@ -52,8 +86,8 @@ setup()
XSetClassHint(display, win, &ch);
// what do?
- /* XMapRaised(display, win); */
-
+ XMapRaised(display, win);
+ XSetInputFocus(display, win, RevertToParent, CurrentTime);
xim = XOpenIM(display, NULL, NULL, NULL);
xic = XCreateIC(xim, XNInputStyle, XIMPreeditNothing | XIMStatusNothing,
@@ -64,7 +98,7 @@ setup()
XSetInputFocus(display, win, RevertToParent, CurrentTime);
- // XXX embed
+ // XXXembed
/* if (embed) { */
/* XSelectInput(dpy, parentwin, FocusChangeMask); */
/* if (XQueryTree(dpy, parentwin, &dw, &w, &dws, &du) && dws) { */
@@ -80,44 +114,88 @@ setup()
}
static void
-draw_tree() {
- static const char *msg = "cmdtree is a tree of commands";
+draw_command(Drw *drw, const char *name, const char *binding) {
+
+ int x = 50;
+ int y = 10;
+ int lpad = 0;
+ unsigned int w = 100;
+ unsigned int h = 100;
+ int invert = 0;
+ int res = 1;
+
+ /* XFillRectangle(display, win, DefaultGC(display, screen), x, y, 10, 10); */
+
+ drw_setscheme(drw, scheme[SchemeNorm]);
+ drw_rect(drw, 0, 0, mw, mh, 1, 1);
+ drw_setscheme(drw, scheme[SchemeSel]);
+ res = drw_text(drw, x, y, w, h, lpad, name, invert);
+ (void)res;
+ assert(res != 0);
+
+ /* XDrawString(drw->dpy, win, DefaultGC(display, screen), 10, 50, name, */
+ /* strlen(name)); */
+
+ /* XDrawString(drw->dpy, win, DefaultGC(display, screen), 10, 50, name, */
+ /* strlen(name)); */
+}
- XFillRectangle(display, win, DefaultGC(display, screen),
- 20, 20, 10, 10);
+static void
+draw_tree(Drw *drw, int x, int y, int w, int h) {
+ draw_command(drw, "apps", "a");
+
+ if (!drw)
+ return;
- XDrawString(display, win, DefaultGC(display, screen), 10,
- 50, msg, strlen(msg));
+ XCopyArea(drw->dpy, drw->drawable, win, drw->gc, x, y, w, h, x, y);
+ XSync(drw->dpy, False);
}
static void
-run() {
+cleanup(Drw *drw, int code) {
+ int i;
+
+ for (i = 0; i < SchemeLast; i++)
+ free(scheme[i]);
+
+ drw_free(drw);
+ exit(0);
+}
+
+static void
+run(Drw *drw) {
XEvent e;
int done = 0;
char buf[32];
KeySym ksym = NoSymbol;
Status status;
+ int code = 0;
while (!done) {
XNextEvent(display, &e);
- if (e.type == Expose) {
- draw_tree();
- }
-
- if (e.type == KeyPress) {
- XmbLookupString(xic, (XKeyEvent*)&e, buf,
- sizeof buf, &ksym, &status);
- if (ksym == XK_q) done = 1;
- if (ksym == XK_Escape) done = 1;
+ switch (e.type) {
+ case Expose:
+ draw_tree(drw, 0, 0, mw, mh);
+ break;
+ case KeyPress:
+ XmbLookupString(xic, (XKeyEvent*)&e, buf, sizeof buf,
+ &ksym, &status);
+ if (ksym == XK_q || ksym == XK_Escape) {
+ code = 1;
+ done = 1;
+ }
+ break;
}
-
}
+ cleanup(drw, code);
}
int main(void) {
+ XWindowAttributes wa;
+ Drw *drw;
display = XOpenDisplay(NULL);
if (display == NULL) {
@@ -128,14 +206,24 @@ int main(void) {
screen = DefaultScreen(display);
root = RootWindow(display, screen);
- // XXX embed
+ // XXXembed
/* if (!embed || !(parentwin = strtol(embed, NULL, 0))) */
/* parentwin = root; */
parentwin = root;
- setup();
- run();
+ if (!XGetWindowAttributes(display, parentwin, &wa))
+ die("could not get embedding window attributes: 0x%lx",
+ parentwin);
+
+ drw = drw_create(display, screen, root, wa.width, wa.height);
+
+ if (!drw_fontset_create(drw, fonts, LENGTH(fonts)))
+ die("no fonts could be loaded.");
+
+ grabkeyboard();
+ setup(drw);
+ run(drw);
XCloseDisplay(display);
return 0;