gmni

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

commit 46b5d74576ffce397c83ac53ebfacb25e1cdc851
parent fed9c0561947126442fbb32e3437922dcc467ef1
Author: Drew DeVault <sir@cmpwn.com>
Date:   Sun, 20 Sep 2020 21:22:40 -0400

Expand wrapping to all token types

Diffstat:
Msrc/gmnlm.c | 92++++++++++++++++++++++++++++++++++++++++++++++---------------------------------
1 file changed, 54 insertions(+), 38 deletions(-)

diff --git a/src/gmnlm.c b/src/gmnlm.c @@ -139,10 +139,7 @@ do_prompts(const char *prompt, struct browser *browser) static char * trim_ws(char *in) { - for (int i = strlen(in) - 1; in[i] && isspace(in[i]); --i) { - in[i] = 0; - } - for (; *in && isspace(*in); ++in); + while (*in && isspace(*in)) ++in; return in; } @@ -203,61 +200,80 @@ display_gemini(struct browser *browser, struct gemini_response *resp) while (text != NULL || gemini_parser_next(&p, &tok) == 0) { switch (tok.token) { case GEMINI_TEXT: - // TODO: Run other stuff through wrap() + col += fprintf(browser->tty, " "); if (text == NULL) { text = tok.text; } - - do { - col += fprintf(browser->tty, " "); - int w = wrap(browser->tty, text, &ws, &row, &col); - text += w; - if (row >= ws.ws_row - 4) { - break; - } - } while (text[0]); - - if (!text[0]) { - text = NULL; - } break; case GEMINI_LINK: - col += fprintf(browser->tty, "%d) %s\n", nlinks++, - trim_ws(tok.link.text ? tok.link.text : tok.link.url)); - *next = calloc(1, sizeof(struct link)); - (*next)->url = strdup(trim_ws(tok.link.url)); - next = &(*next)->next; + if (text == NULL) { + col += fprintf(browser->tty, "%d) ", nlinks++); + text = trim_ws(tok.link.text ? tok.link.text : tok.link.url); + *next = calloc(1, sizeof(struct link)); + (*next)->url = strdup(trim_ws(tok.link.url)); + next = &(*next)->next; + } else { + col += fprintf(browser->tty, " "); + } break; case GEMINI_PREFORMATTED: continue; // TODO case GEMINI_HEADING: - for (int n = tok.heading.level; n; --n) { - col += fprintf(browser->tty, "#"); - } - for (int n = 3 - tok.heading.level; n > 1; --n) { - col += fprintf(browser->tty, " "); + if (text == NULL) { + for (int n = tok.heading.level; n; --n) { + col += fprintf(browser->tty, "#"); + } + switch (tok.heading.level) { + case 1: + col += fprintf(browser->tty, " "); + break; + case 2: + case 3: + col += fprintf(browser->tty, " "); + break; + } + text = trim_ws(tok.heading.title); + } else { + col += fprintf(browser->tty, " "); } - col += fprintf(browser->tty, " %s\n", - trim_ws(tok.heading.title)); break; case GEMINI_LIST_ITEM: - col += fprintf(browser->tty, " %s %s\n", - browser->unicode ? "•" : "*", - trim_ws(tok.list_item)); + if (text == NULL) { + col += fprintf(browser->tty, " %s ", + browser->unicode ? "•" : "*"); + text = trim_ws(tok.list_item); + } else { + col += fprintf(browser->tty, " "); + } break; case GEMINI_QUOTE: - col += fprintf(browser->tty, " %s %s\n", - browser->unicode ? "|" : "|", - trim_ws(tok.quote_text)); + if (text == NULL) { + col += fprintf(browser->tty, " %s ", + browser->unicode ? "|" : "|"); + text = trim_ws(tok.quote_text); + } else { + col += fprintf(browser->tty, " "); + } break; } + if (text) { + int w = wrap(browser->tty, text, &ws, &row, &col); + text += w; + if (text[0] && row < ws.ws_row - 4) { + continue; + } + + if (!text[0]) { + text = NULL; + } + } + while (col >= ws.ws_col) { col -= ws.ws_col; ++row; } - ++row; - col = 0; + ++row; col = 0; if (browser->pagination && row >= ws.ws_row - 4) { char prompt[4096];