diff options
| author | Jari Vetoniemi <mailroxas@gmail.com> | 2014-04-10 20:04:06 +0300 | 
|---|---|---|
| committer | Jari Vetoniemi <mailroxas@gmail.com> | 2014-04-10 20:04:06 +0300 | 
| commit | a6d0413b972580f3bbfde8750090270b0d8d463e (patch) | |
| tree | 7ed26f9c4978dfc213c89a6ec2008cccc9670dbb /lib/draw | |
| parent | 16e023aa3eb495a4b48af1784e5e78dcf4e9ba0b (diff) | |
| download | bemenu-a6d0413b972580f3bbfde8750090270b0d8d463e.tar.gz bemenu-a6d0413b972580f3bbfde8750090270b0d8d463e.tar.bz2 bemenu-a6d0413b972580f3bbfde8750090270b0d8d463e.zip  | |
Implement list structure, and feature for multiple selections.
Diffstat (limited to 'lib/draw')
| -rw-r--r-- | lib/draw/curses.c | 8 | 
1 files changed, 6 insertions, 2 deletions
diff --git a/lib/draw/curses.c b/lib/draw/curses.c index 0e19538..336b21d 100644 --- a/lib/draw/curses.c +++ b/lib/draw/curses.c @@ -120,8 +120,9 @@ static void _bmDrawCursesRender(const bmMenu *menu)      unsigned int itemsCount;      bmItem **items = bmMenuGetFilteredItems(menu, &itemsCount);      for (i = (menu->index / (lines - 1)) * (lines - 1); i < itemsCount && cl < lines; ++i) { -        int selected = (items[i] == bmMenuGetSelectedItem(menu)); -        _bmDrawCursesDrawLine((selected ? 2 : 0), cl++, "%s%s", (selected ? ">> " : "   "), items[i]->text); +        int highlighted = (items[i] == bmMenuGetHighlightedItem(menu)); +        int color = (highlighted ? 2 : (_bmMenuItemIsSelected(menu, items[i]) ? 1 : 0)); +        _bmDrawCursesDrawLine(color, cl++, "%s%s", (highlighted ? ">> " : "   "), items[i]->text);      }      curses.move(0, titleLen + menu->cursesCursor); @@ -200,6 +201,9 @@ static bmKey _bmDrawCursesGetKey(unsigned int *unicode)          case 9: /* Tab */              return BM_KEY_TAB; +        case 18: /* C-r */ +            return BM_KEY_SHIFT_RETURN; +          case 10: /* Return */              _bmDrawCursesEndWin();              return BM_KEY_RETURN;  | 
