diff options
| -rw-r--r-- | dmenu.c | 35 |
1 files changed, 21 insertions, 14 deletions
| @@ -308,13 +308,21 @@ keypress(XKeyEvent *ev) | |||
| 308 | { | 308 | { |
| 309 | char buf[32]; | 309 | char buf[32]; |
| 310 | int len; | 310 | int len; |
| 311 | KeySym ksym = NoSymbol; | 311 | KeySym ksym; |
| 312 | Status status; | 312 | Status status; |
| 313 | 313 | ||
| 314 | len = XmbLookupString(xic, ev, buf, sizeof buf, &ksym, &status); | 314 | len = XmbLookupString(xic, ev, buf, sizeof buf, &ksym, &status); |
| 315 | if (status == XBufferOverflow) | 315 | switch (status) { |
| 316 | default: /* XLookupNone, XBufferOverflow */ | ||
| 316 | return; | 317 | return; |
| 317 | if (ev->state & ControlMask) | 318 | case XLookupChars: |
| 319 | goto insert; | ||
| 320 | case XLookupKeySym: | ||
| 321 | case XLookupBoth: | ||
| 322 | break; | ||
| 323 | } | ||
| 324 | |||
| 325 | if (ev->state & ControlMask) { | ||
| 318 | switch(ksym) { | 326 | switch(ksym) { |
| 319 | case XK_a: ksym = XK_Home; break; | 327 | case XK_a: ksym = XK_Home; break; |
| 320 | case XK_b: ksym = XK_Left; break; | 328 | case XK_b: ksym = XK_Left; break; |
| @@ -352,12 +360,10 @@ keypress(XKeyEvent *ev) | |||
| 352 | return; | 360 | return; |
| 353 | case XK_Left: | 361 | case XK_Left: |
| 354 | movewordedge(-1); | 362 | movewordedge(-1); |
| 355 | ksym = NoSymbol; | 363 | goto draw; |
| 356 | break; | ||
| 357 | case XK_Right: | 364 | case XK_Right: |
| 358 | movewordedge(+1); | 365 | movewordedge(+1); |
| 359 | ksym = NoSymbol; | 366 | goto draw; |
| 360 | break; | ||
| 361 | case XK_Return: | 367 | case XK_Return: |
| 362 | case XK_KP_Enter: | 368 | case XK_KP_Enter: |
| 363 | break; | 369 | break; |
| @@ -367,16 +373,14 @@ keypress(XKeyEvent *ev) | |||
| 367 | default: | 373 | default: |
| 368 | return; | 374 | return; |
| 369 | } | 375 | } |
| 370 | else if (ev->state & Mod1Mask) | 376 | } else if (ev->state & Mod1Mask) { |
| 371 | switch(ksym) { | 377 | switch(ksym) { |
| 372 | case XK_b: | 378 | case XK_b: |
| 373 | movewordedge(-1); | 379 | movewordedge(-1); |
| 374 | ksym = NoSymbol; | 380 | goto draw; |
| 375 | break; | ||
| 376 | case XK_f: | 381 | case XK_f: |
| 377 | movewordedge(+1); | 382 | movewordedge(+1); |
| 378 | ksym = NoSymbol; | 383 | goto draw; |
| 379 | break; | ||
| 380 | case XK_g: ksym = XK_Home; break; | 384 | case XK_g: ksym = XK_Home; break; |
| 381 | case XK_G: ksym = XK_End; break; | 385 | case XK_G: ksym = XK_End; break; |
| 382 | case XK_h: ksym = XK_Up; break; | 386 | case XK_h: ksym = XK_Up; break; |
| @@ -386,13 +390,14 @@ keypress(XKeyEvent *ev) | |||
| 386 | default: | 390 | default: |
| 387 | return; | 391 | return; |
| 388 | } | 392 | } |
| 393 | } | ||
| 394 | |||
| 389 | switch(ksym) { | 395 | switch(ksym) { |
| 390 | default: | 396 | default: |
| 397 | insert: | ||
| 391 | if (!iscntrl(*buf)) | 398 | if (!iscntrl(*buf)) |
| 392 | insert(buf, len); | 399 | insert(buf, len); |
| 393 | break; | 400 | break; |
| 394 | case NoSymbol: | ||
| 395 | break; | ||
| 396 | case XK_Delete: | 401 | case XK_Delete: |
| 397 | if (text[cursor] == '\0') | 402 | if (text[cursor] == '\0') |
| 398 | return; | 403 | return; |
| @@ -489,6 +494,8 @@ keypress(XKeyEvent *ev) | |||
| 489 | match(); | 494 | match(); |
| 490 | break; | 495 | break; |
| 491 | } | 496 | } |
| 497 | |||
| 498 | draw: | ||
| 492 | drawmenu(); | 499 | drawmenu(); |
| 493 | } | 500 | } |
| 494 | 501 | ||
