gmni

a gemini line mode client
git clone https://git.clttr.info/gmni.git
Log (Feed) | Files | Refs (Tags) | README | LICENSE

commit e448e3ea7dba4870a6b2c6d844db9958ec291a9b
parent 2f976c52dcfaaaa5b83a9208f07b04343d38f594
Author: Ondřej Fiala <fiala.ondrej@volny.cz>
Date:   Sun,  5 Nov 2023 03:07:56 +0100

gmnlm: calculate number of rows available for text correctly

Diffstat:
Msrc/gmnlm.c | 49++++++++++++++++++++++++++++++++-----------------
1 file changed, 32 insertions(+), 17 deletions(-)

diff --git a/src/gmnlm.c b/src/gmnlm.c @@ -951,12 +951,40 @@ display_gemini(struct browser *browser, struct gemini_response *resp) int row = 0, col = 0; struct gemini_token tok; struct link **next = &browser->links; - // When your screen is too narrow, more lines will be used for helptext and URL. - // 87 is the maximum width of the prompt. - int info_rows = (ws.ws_col >= 87) ? 4 : 6; + char prompt[4096]; + char *end = NULL; + int info_rows = 0; + bool first_screen = 1; while (text != NULL || gemini_parser_next(&p, &tok) == 0) { repeat: + if (!row) { + if (browser->meta && (end = strchr(resp->meta, ';')) != NULL) { + *end = 0; + } + snprintf(prompt, sizeof(prompt), "\n%s at %s\n" + "[Enter]: read more; %s[N]: =follow Nth link; %s%s[q]uit; [?]; or type a URL\n" + "(more) => ", resp->meta, browser->plain_url, + browser->searching ? "[n]ext result; " : "", + browser->history->prev ? "[b]ack; " : "", + browser->history->next ? "[f]orward; " : ""); + if (end != NULL) { + *end = ';'; + } + + info_rows = 0; + for (char *ln = prompt; (end = strchr(ln, '\n')); ln = end + 1) { + *end = '\0'; + int len = strlen(ln); + info_rows += len / ws.ws_col + (len % ws.ws_col != 0); + if (!*ln) info_rows++; // empty line + *end = '\n'; + } + // if not first screen, text is preceded by an empty line, + // and help text is followed by a prompt line + info_rows += !first_screen + 1; + } + switch (tok.token) { case GEMINI_TEXT: col += fprintf(out, " "); @@ -1062,20 +1090,7 @@ repeat: ++row; col = 0; if (browser->pagination && row >= ws.ws_row - info_rows) { - char prompt[4096]; - char *end = NULL; - if (browser->meta && (end = strchr(resp->meta, ';')) != NULL) { - *end = 0; - } - snprintf(prompt, sizeof(prompt), "\n%s at %s\n" - "[Enter]: read more; %s[N]: follow Nth link; %s%s[q]uit; [?]; or type a URL\n" - "(more) => ", resp->meta, browser->plain_url, - browser->searching ? "[n]ext result; " : "", - browser->history->prev ? "[b]ack; " : "", - browser->history->next ? "[f]orward; " : ""); - if (end != NULL) { - *end = ';'; - } + first_screen = 0; enum prompt_result result = PROMPT_AGAIN; while (result == PROMPT_AGAIN) { result = do_prompts(prompt, browser);