diff options
author | Moritz Luedecke <ritze@skweez.net> | 2018-01-25 10:10:08 +0100 |
---|---|---|
committer | Moritz Luedecke <ritze@skweez.net> | 2018-01-25 10:14:21 +0100 |
commit | 631b801c00fae61f28989c3a829562b149dc9165 (patch) | |
tree | ed0ec70bb3ad8e276f3095d522b43fdedb93a3b2 /pinentry-dmenu.c | |
parent | 3efd900cd26505bdaf64d411195a4be556cee011 (diff) |
Change the approach of prompt setup
Diffstat (limited to 'pinentry-dmenu.c')
-rw-r--r-- | pinentry-dmenu.c | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/pinentry-dmenu.c b/pinentry-dmenu.c index ba1faae..98544cf 100644 --- a/pinentry-dmenu.c +++ b/pinentry-dmenu.c @@ -41,7 +41,7 @@ enum { Nothing, Yes, No }; static int bh, mw, mh; static int sel; -static int promptw, ppromptw, pdescw; +static int promptw, pdescw; /* Sum of left and right padding */ static int lrpad; static size_t cursor; @@ -154,6 +154,9 @@ drawwin(void) { size_t pdesclen; int leftinput; char* censort; + + char* pprompt = (repeat) ? pinentry->repeat_passphrase : pinentry->prompt; + int ppromptw = (pprompt) ? TEXTW(pprompt) : 0; unsigned int censortl = minpwlen * TEXTW(asterisk) / strlen(asterisk); unsigned int confirml = TEXTW(" YesNo ") + 3 * lrpad; @@ -166,9 +169,9 @@ drawwin(void) { x = drw_text(drw, x, 0, promptw, bh, lrpad / 2, prompt, 0); } - if (pinentry->prompt) { + if (pprompt) { drw_setscheme(drw, scheme[SchemePrompt]); - drw_text(drw, x, 0, ppromptw, bh, lrpad / 2, pinentry->prompt, 0); + drw_text(drw, x, 0, ppromptw, bh, lrpad / 2, pprompt, 0); x += ppromptw; } @@ -236,6 +239,7 @@ setup_pin(char* pin_ptr, int len) { pin = pin_ptr; pin_len = len; cursor = 0; + promptw = (prompt) ? TEXTW(prompt) - lrpad / 4 : 0; if (pin) { pin[0] = '\0'; } @@ -317,8 +321,6 @@ setup(void) { mw = wa.width; } - promptw = (prompt) ? TEXTW(prompt) - lrpad / 4 : 0; - ppromptw = (pinentry->prompt) ? TEXTW(pinentry->prompt) : 0; pdescw = (pinentry->description) ? TEXTW(pinentry->description) : 0; /* Create menu window */ |