Display text item via default PAGER - sacc - sacc(omys), simple console gopher client HTML git clone git://bitreich.org/sacc/ git://enlrupgkhuxnvlhsf6lc3fziv5h2hhfrinws65d7roiv6bfj7d652fid.onion/sacc/ DIR Log DIR Files DIR Refs DIR Tags DIR LICENSE --- DIR commit 081653074e69ae028be354aee7eca0c178a34d96 DIR parent b5c402515b3273d7889236698fea95dd57190326 HTML Author: Quentin Rameau <quinq@fifth.space> Date: Sun, 2 Jul 2017 18:55:57 +0200 Display text item via default PAGER Diffstat: M sacc.c | 42 +++++++++++++++++++++++++++---- M ui_ti.c | 46 +++++++++++++------------------ M ui_txt.c | 37 +++++++++++++------------------ 3 files changed, 71 insertions(+), 54 deletions(-) --- DIR diff --git a/sacc.c b/sacc.c @@ -9,6 +9,7 @@ #include <unistd.h> #include <sys/socket.h> #include <sys/types.h> +#include <sys/wait.h> #include "common.h" @@ -116,6 +117,28 @@ typedisplay(char t) } } +static void +displaytextitem(Item *item) +{ + FILE *pagerin; + int pid, wpid; + + uicleanup(); + switch (pid = fork()) { + case -1: + fprintf(stderr, "Couldn't fork.\n"); + return; + case 0: + pagerin = popen("$PAGER", "we"); + fputs(item->raw, pagerin); + exit(pclose(pagerin)); + default: + while ((wpid = wait(NULL)) >= 0 && wpid != pid) + ; + } + uisetup(); +} + static char * pickfield(char **raw, char sep) { @@ -303,7 +326,7 @@ dig(Item *entry, Item *item) int sock; if (item->raw) /* already in cache */ - return 1; + return item->type; if (!item->entry) item->entry = entry; @@ -331,7 +354,7 @@ dig(Item *entry, Item *item) return 0; } } - return 1; + return item->type; } static void @@ -340,12 +363,21 @@ delve(Item *hole) Item *entry = hole; while (hole) { - if (dig(entry, hole)) { - display(hole); - } else { + switch (dig(entry, hole)) { + case '0': + displaytextitem(hole); + hole = entry; + break; + case '1': + break; + default: fprintf(stderr, "Couldn't get %s:%s/%c%s\n", hole->host, hole->port, hole->type, hole->selector); + hole = entry; + break; } + + display(hole); entry = hole; hole = selectitem(hole); } DIR diff --git a/ui_ti.c b/ui_ti.c @@ -48,38 +48,31 @@ display(Item *item) Item **items; size_t i, curln, lastln, nitems, printoff; - if (item->type > '1') + if (item->type != '1') return; putp(tparm(clear_screen)); putp(tparm(save_cursor)); - switch (item->type) { - case '0': - puts(item->raw); - break; - case '1': - items = item->dir->items; - nitems = item->dir->nitems; - printoff = item->printoff; - curln = item->curline; - lastln = printoff + lines; - - for (i = printoff; i < nitems && i < lastln; ++i) { - if (item = items[i]) { - if (i != printoff) - putp(tparm(cursor_down)); - if (i == curln) { - putp(tparm(save_cursor)); - putp(tparm(enter_standout_mode)); - } - printitem(item); - putp(tparm(column_address, 0)); - if (i == curln) - putp(tparm(exit_standout_mode)); + items = item->dir->items; + nitems = item->dir->nitems; + printoff = item->printoff; + curln = item->curline; + lastln = printoff + lines; + + for (i = printoff; i < nitems && i < lastln; ++i) { + if (item = items[i]) { + if (i != printoff) + putp(tparm(cursor_down)); + if (i == curln) { + putp(tparm(save_cursor)); + putp(tparm(enter_standout_mode)); } + printitem(item); + putp(tparm(column_address, 0)); + if (i == curln) + putp(tparm(exit_standout_mode)); } - break; } putp(tparm(restore_cursor)); @@ -171,4 +164,4 @@ selectitem(Item *entry) } } -} -\ No newline at end of file +} DIR diff --git a/ui_txt.c b/ui_txt.c @@ -45,31 +45,24 @@ display(Item *item) size_t i, lines, nitems; int ndigits; - if (item->type > '1') + if (item->type != '1') return; - switch (item->type) { - case '0': - puts(item->raw); - break; - case '1': - items = item->dir->items; - nitems = item->dir->nitems; - lines = item->printoff + termlines(); - ndigits = (nitems < 10) ? 1 : (nitems < 100) ? 2 : 3; - - for (i = item->printoff; i < nitems && i < lines; ++i) { - if (item = items[i]) { - printf("%*d %-4s%c %s\n", ndigits, i+1, - item->type != 'i' ? - typedisplay(item->type) : "", - item->type > '1' ? '|' : '+', - items[i]->username); - } else { - printf("%*d !! |\n", ndigits, i+1); - } + items = item->dir->items; + nitems = item->dir->nitems; + lines = item->printoff + termlines(); + ndigits = (nitems < 10) ? 1 : (nitems < 100) ? 2 : 3; + + for (i = item->printoff; i < nitems && i < lines; ++i) { + if (item = items[i]) { + printf("%*d %-4s%c %s\n", ndigits, i+1, + item->type != 'i' ? + typedisplay(item->type) : "", + item->type > '1' ? '|' : '+', + items[i]->username); + } else { + printf("%*d !! |\n", ndigits, i+1); } - break; } }