Index: Makefile =================================================================== RCS file: /home/pcvs/ports/x11/thinglaunch/Makefile,v retrieving revision 1.9 diff -u -u -r1.9 Makefile --- Makefile 27 Mar 2009 09:53:36 -0000 1.9 +++ Makefile 1 Sep 2009 20:01:10 -0000 @@ -6,15 +6,14 @@ # PORTNAME= thinglaunch -PORTVERSION= 1.03 -PORTREVISION= 3 +PORTVERSION= 1.8 CATEGORIES= x11 MASTER_SITES= CRITICAL MAINTAINER= ehaupt@FreeBSD.org COMMENT= A very fast launcher program for X -USE_XORG= x11 +USE_XORG= x11 xproto MAKE_JOBS_SAFE= yes CPPFLAGS= -I${LOCALBASE}/include -lX11 Index: files/patch-thinglaunch.c =================================================================== RCS file: /home/pcvs/ports/x11/thinglaunch/files/patch-thinglaunch.c,v retrieving revision 1.1 diff -u -u -r1.1 patch-thinglaunch.c --- files/patch-thinglaunch.c 2 Jul 2008 12:54:52 -0000 1.1 +++ files/patch-thinglaunch.c 1 Sep 2009 20:11:17 -0000 @@ -1,10 +1,111 @@ ---- ./thinglaunch.c.orig 2008-07-02 14:47:23.000000000 +0200 -+++ ./thinglaunch.c 2008-07-02 14:47:30.000000000 +0200 -@@ -23,6 +23,7 @@ +--- thinglaunch.c.orig 2004-09-20 16:27:56.000000000 +0200 ++++ thinglaunch.c 2009-09-01 22:11:10.000000000 +0200 +@@ -19,10 +19,14 @@ + */ + #include + #include ++#include + #include #include #include #include ++#ifdef __FreeBSD__ +#include ++#endif static void createWindow(); static void setupGC(); +@@ -50,10 +54,13 @@ + + /* the actual commandline */ + char command[MAXCMD+1]; ++size_t cursor_pos; + + int main(int argc, char ** argv) { + + command[0] = 0x0; ++ cursor_pos = 0; ++ + createWindow(); + + setupGC(); +@@ -209,15 +216,15 @@ + + int font_height; + int textwidth; +- ++ + font_height = font_info->ascent + font_info->descent; +- textwidth = XTextWidth(font_info, command, strlen(command)); ++ textwidth = XTextWidth(font_info, command, cursor_pos); + + XFillRectangle(display, win, rectgc, 0, 0, WINWIDTH, WINHEIGHT); + XDrawRectangle(display, win, gc, 0, 0, WINWIDTH-1, WINHEIGHT-1); + XDrawString(display, win, gc, 2, font_height+2, command, strlen(command)); +- XDrawLine(display, win, gc, 2 + textwidth, font_height + 2, +- 2 + textwidth + 10, font_height+2); ++ XDrawLine(display, win, gc, 2 + textwidth, font_height + 4, ++ 2 + textwidth + 10, font_height+4); + + XFlush(display); + +@@ -229,22 +236,36 @@ + #define KEYBUFLEN 20 + char buffer[KEYBUFLEN+1]; + KeySym key_symbol; +- int len; ++ int len, tmp_pos; + + len = XLookupString(keyevent, buffer, 1, &key_symbol, NULL); + buffer[len] = 0x0; ++ len = strlen(command); + + switch(key_symbol) { +- case 0xff1b: /* this is escape */ ++ case XK_Escape: + exit(0); + break; +- case 0xff08: /* backspace */ +- len = strlen(command); +- if (len > 0) { +- command[len-1] = 0x0; +- } ++ case XK_BackSpace: ++ if (cursor_pos) ++ for (tmp_pos = --cursor_pos; tmp_pos <= len; tmp_pos++) ++ command[tmp_pos] = command[tmp_pos+1]; ++ break; ++ case XK_Left: ++ if (cursor_pos) ++ cursor_pos--; ++ break; ++ case XK_Right: ++ if (cursor_pos < len) ++ cursor_pos++; ++ break; ++ case XK_Home: ++ cursor_pos = 0; ++ break; ++ case XK_End: ++ cursor_pos = len; + break; +- case 0xff0d: /* enter */ ++ case XK_Return: + execcmd(); + break; + default: +@@ -253,10 +274,11 @@ + + /* normal printable chars */ + if (key_symbol >= 0x20 && key_symbol <= 0x7e) { +- len = strlen(command); + if (len < MAXCMD) { +- command[len] = buffer[0]; +- command[len+1] = 0x0; ++ if (cursor_pos != len) ++ for (tmp_pos = len; tmp_pos > cursor_pos; tmp_pos--) ++ command[tmp_pos] = command[tmp_pos-1]; ++ command[cursor_pos++] = buffer[0]; + } + } + redraw();