merged with grid (and gridnav) patch
This commit is contained in:
commit
03b6df0414
@ -13,8 +13,10 @@ static const char *colors[SchemeLast][2] = {
|
|||||||
[SchemeSel] = { "#eeeeee", "#005577" },
|
[SchemeSel] = { "#eeeeee", "#005577" },
|
||||||
[SchemeOut] = { "#000000", "#00ffff" },
|
[SchemeOut] = { "#000000", "#00ffff" },
|
||||||
};
|
};
|
||||||
/* -l option; if nonzero, dmenu uses vertical list with given number of lines */
|
|
||||||
|
/* -l and -g options; controls number of lines and columns in grid if > 0 */
|
||||||
static unsigned int lines = 9;
|
static unsigned int lines = 9;
|
||||||
|
static unsigned int columns = 4;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Characters not considered part of a word while deleting words
|
* Characters not considered part of a word while deleting words
|
||||||
|
7
dmenu.1
7
dmenu.1
@ -4,6 +4,8 @@ dmenu \- dynamic menu
|
|||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B dmenu
|
.B dmenu
|
||||||
.RB [ \-bfiv ]
|
.RB [ \-bfiv ]
|
||||||
|
.RB [ \-g
|
||||||
|
.IR columns ]
|
||||||
.RB [ \-l
|
.RB [ \-l
|
||||||
.IR lines ]
|
.IR lines ]
|
||||||
.RB [ \-m
|
.RB [ \-m
|
||||||
@ -47,8 +49,11 @@ is faster, but will lock up X until stdin reaches end\-of\-file.
|
|||||||
.B \-i
|
.B \-i
|
||||||
dmenu matches menu items case insensitively.
|
dmenu matches menu items case insensitively.
|
||||||
.TP
|
.TP
|
||||||
|
.BI \-g " columns"
|
||||||
|
dmenu lists items in a grid with the given number of columns.
|
||||||
|
.TP
|
||||||
.BI \-l " lines"
|
.BI \-l " lines"
|
||||||
dmenu lists items vertically, with the given number of lines.
|
dmenu lists items in a grid with the given number of lines.
|
||||||
.TP
|
.TP
|
||||||
.BI \-m " monitor"
|
.BI \-m " monitor"
|
||||||
dmenu is displayed on the monitor number supplied. Monitor numbers are starting
|
dmenu is displayed on the monitor number supplied. Monitor numbers are starting
|
||||||
|
66
dmenu.c
66
dmenu.c
@ -84,7 +84,7 @@ calcoffsets(void)
|
|||||||
int i, n;
|
int i, n;
|
||||||
|
|
||||||
if (lines > 0)
|
if (lines > 0)
|
||||||
n = lines * bh;
|
n = lines * columns * bh;
|
||||||
else
|
else
|
||||||
n = mw - (promptw + inputw + TEXTW("<") + TEXTW(">"));
|
n = mw - (promptw + inputw + TEXTW("<") + TEXTW(">"));
|
||||||
/* calculate which items will begin the next page and previous page */
|
/* calculate which items will begin the next page and previous page */
|
||||||
@ -169,9 +169,15 @@ drawmenu(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (lines > 0) {
|
if (lines > 0) {
|
||||||
/* draw vertical list */
|
/* draw grid */
|
||||||
for (item = curr; item != next; item = item->right)
|
int i = 0;
|
||||||
drawitem(item, x, y += bh, mw - x);
|
for (item = curr; item != next; item = item->right, i++)
|
||||||
|
drawitem(
|
||||||
|
item,
|
||||||
|
x + ((i / lines) * ((mw - x) / columns)),
|
||||||
|
y + (((i % lines) + 1) * bh),
|
||||||
|
(mw - x) / columns
|
||||||
|
);
|
||||||
} else if (matches) {
|
} else if (matches) {
|
||||||
/* draw horizontal list */
|
/* draw horizontal list */
|
||||||
x += inputw;
|
x += inputw;
|
||||||
@ -328,6 +334,8 @@ keypress(XKeyEvent *ev)
|
|||||||
int len;
|
int len;
|
||||||
KeySym ksym = NoSymbol;
|
KeySym ksym = NoSymbol;
|
||||||
Status status;
|
Status status;
|
||||||
|
int i, offscreen = 0;
|
||||||
|
struct item *tmpsel;
|
||||||
|
|
||||||
len = XmbLookupString(xic, ev, buf, sizeof buf, &ksym, &status);
|
len = XmbLookupString(xic, ev, buf, sizeof buf, &ksym, &status);
|
||||||
switch (status) {
|
switch (status) {
|
||||||
@ -460,6 +468,27 @@ insert:
|
|||||||
break;
|
break;
|
||||||
case XK_Left:
|
case XK_Left:
|
||||||
case XK_KP_Left:
|
case XK_KP_Left:
|
||||||
|
if (columns > 1) {
|
||||||
|
if (!sel)
|
||||||
|
return;
|
||||||
|
tmpsel = sel;
|
||||||
|
for (i = 0; i < lines; i++) {
|
||||||
|
if (!tmpsel->left || tmpsel->left->right != tmpsel) {
|
||||||
|
if (offscreen)
|
||||||
|
break;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (tmpsel == curr)
|
||||||
|
offscreen = 1;
|
||||||
|
tmpsel = tmpsel->left;
|
||||||
|
}
|
||||||
|
sel = tmpsel;
|
||||||
|
if (offscreen) {
|
||||||
|
curr = prev;
|
||||||
|
calcoffsets();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
if (cursor > 0 && (!sel || !sel->left || lines > 0)) {
|
if (cursor > 0 && (!sel || !sel->left || lines > 0)) {
|
||||||
cursor = nextrune(-1);
|
cursor = nextrune(-1);
|
||||||
break;
|
break;
|
||||||
@ -500,6 +529,27 @@ insert:
|
|||||||
break;
|
break;
|
||||||
case XK_Right:
|
case XK_Right:
|
||||||
case XK_KP_Right:
|
case XK_KP_Right:
|
||||||
|
if (columns > 1) {
|
||||||
|
if (!sel)
|
||||||
|
return;
|
||||||
|
tmpsel = sel;
|
||||||
|
for (i = 0; i < lines; i++) {
|
||||||
|
if (!tmpsel->right || tmpsel->right->left != tmpsel) {
|
||||||
|
if (offscreen)
|
||||||
|
break;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
tmpsel = tmpsel->right;
|
||||||
|
if (tmpsel == next)
|
||||||
|
offscreen = 1;
|
||||||
|
}
|
||||||
|
sel = tmpsel;
|
||||||
|
if (offscreen) {
|
||||||
|
curr = next;
|
||||||
|
calcoffsets();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
if (text[cursor] != '\0') {
|
if (text[cursor] != '\0') {
|
||||||
cursor = nextrune(+1);
|
cursor = nextrune(+1);
|
||||||
break;
|
break;
|
||||||
@ -743,9 +793,13 @@ main(int argc, char *argv[])
|
|||||||
} else if (i + 1 == argc)
|
} else if (i + 1 == argc)
|
||||||
usage();
|
usage();
|
||||||
/* these options take one argument */
|
/* these options take one argument */
|
||||||
else if (!strcmp(argv[i], "-l")) /* number of lines in vertical list */
|
else if (!strcmp(argv[i], "-g")) { /* number of columns in grid */
|
||||||
|
columns = atoi(argv[++i]);
|
||||||
|
if (lines == 0) lines = 1;
|
||||||
|
} else if (!strcmp(argv[i], "-l")) { /* number of lines in grid */
|
||||||
lines = atoi(argv[++i]);
|
lines = atoi(argv[++i]);
|
||||||
else if (!strcmp(argv[i], "-m"))
|
if (columns == 0) columns = 1;
|
||||||
|
} else if (!strcmp(argv[i], "-m"))
|
||||||
mon = atoi(argv[++i]);
|
mon = atoi(argv[++i]);
|
||||||
else if (!strcmp(argv[i], "-p")) /* adds prompt to left of input field */
|
else if (!strcmp(argv[i], "-p")) /* adds prompt to left of input field */
|
||||||
prompt = argv[++i];
|
prompt = argv[++i];
|
||||||
|
Loading…
Reference in New Issue
Block a user