From da4986e8f871cdb3be89c277f178250f5c1f77c3 Mon Sep 17 00:00:00 2001 From: Kristaps Dz Date: Sat, 21 Dec 2024 20:16:46 -0800 Subject: [PATCH] Add -tterm ignoring of relative links. This makes sense for -tterm because, while it can display actual links, there's no concept of a current location for relative links. References #105 --- lowdown.h | 76 +++++++++++++++++++++++++++---------------------------- term.c | 26 +++++++++++++++++++ 2 files changed, 64 insertions(+), 38 deletions(-) diff --git a/lowdown.h b/lowdown.h index 61bc6c9..47f65f0 100644 --- a/lowdown.h +++ b/lowdown.h @@ -329,60 +329,60 @@ struct lowdown_opts { }; size_t maxdepth; unsigned int feat; -#define LOWDOWN_ATTRS 0x80000 -#define LOWDOWN_AUTOLINK 0x08 -#define LOWDOWN_COMMONMARK 0x8000 -#define LOWDOWN_DEFLIST 0x10000 +#define LOWDOWN_TABLES 0x01 #define LOWDOWN_FENCED 0x02 #define LOWDOWN_FOOTNOTES 0x04 +#define LOWDOWN_AUTOLINK 0x08 +#define LOWDOWN_STRIKE 0x10 +/* Omitted 0x20 */ #define LOWDOWN_HILITE 0x40 -#define LOWDOWN_IMG_EXT 0x20000 /* -> LOWDOWN_ATTRS */ -#define LOWDOWN_MANTITLE 0x100000 -#define LOWDOWN_CALLOUTS 0x200000 +/* Omitted 0x80 */ +#define LOWDOWN_SUPER 0x100 #define LOWDOWN_MATH 0x200 +#define LOWDOWN_NOINTEM 0x400 /* Disabled LOWDOWN_MATHEXP 0x1000 */ -#define LOWDOWN_METADATA 0x4000 #define LOWDOWN_NOCODEIND 0x2000 -#define LOWDOWN_NOINTEM 0x400 -#define LOWDOWN_STRIKE 0x10 -#define LOWDOWN_SUPER 0x100 -#define LOWDOWN_SUPER_SHORT 0x400000 -#define LOWDOWN_TABLES 0x01 +#define LOWDOWN_METADATA 0x4000 +#define LOWDOWN_COMMONMARK 0x8000 +#define LOWDOWN_DEFLIST 0x10000 +#define LOWDOWN_IMG_EXT 0x20000 /* -> LOWDOWN_ATTRS */ #define LOWDOWN_TASKLIST 0x40000 -/* Omitted 0x20 */ -/* Omitted 0x80 */ +#define LOWDOWN_ATTRS 0x80000 +#define LOWDOWN_MANTITLE 0x100000 +#define LOWDOWN_CALLOUTS 0x200000 +#define LOWDOWN_SUPER_SHORT 0x400000 unsigned int oflags; -#define LOWDOWN_GEMINI_LINK_END 0x8000 /* links at end */ -#define LOWDOWN_GEMINI_LINK_IN 0x10000 /* links inline */ -#define LOWDOWN_GEMINI_LINK_NOREF 0x200000 /* for !inline, no names */ -#define LOWDOWN_GEMINI_LINK_ROMAN 0x400000 /* roman link names */ -#define LOWDOWN_GEMINI_METADATA 0x100000 /* show metadata */ +#define LOWDOWN_HTML_SKIP_HTML 0x01 /* skip all HTML */ #define LOWDOWN_HTML_ESCAPE 0x02 /* escape HTML (if not skip) */ #define LOWDOWN_HTML_HARD_WRAP 0x04 /* paragraph line breaks */ +#define LOWDOWN_NROFF_SKIP_HTML 0x08 /* skip all HTML */ +#define LOWDOWN_TERM_NORELLINK 0x10 /* don't show relative links */ +#define LOWDOWN_NROFF_GROFF 0x20 /* use groff extensions */ +#define LOWDOWN_SMARTY 0x40 /* smart typography */ +#define LOWDOWN_NROFF_NUMBERED 0x80 /* numbered section headers */ #define LOWDOWN_HTML_HEAD_IDS 0x100 /* */ -#define LOWDOWN_HTML_NUM_ENT 0x1000 /* use &#nn; if possible */ +#define LOWDOWN_STANDALONE 0x200 /* emit complete document */ +#define LOWDOWN_TERM_SHORTLINK 0x400 /* shorten URLs */ #define LOWDOWN_HTML_OWASP 0x800 /* use OWASP escaping */ -#define LOWDOWN_HTML_SKIP_HTML 0x01 /* skip all HTML */ -#define LOWDOWN_HTML_TITLEBLOCK 0x4000000 /* output title block */ -#define LOWDOWN_HTML_CALLOUT_GFM 0x8000000 /* GFM callouts */ -#define LOWDOWN_HTML_CALLOUT_MDN 0x10000000 /* MDN callouts */ -#define LOWDOWN_LATEX_NUMBERED 0x4000 /* numbered sections */ +#define LOWDOWN_HTML_NUM_ENT 0x1000 /* use &#nn; if possible */ #define LOWDOWN_LATEX_SKIP_HTML 0x2000 /* skip all HTML */ -#define LOWDOWN_NROFF_GROFF 0x20 /* use groff extensions */ -/* Disable LOWDOWN_NROFF_HARD_WRAP 0x10 */ -#define LOWDOWN_NROFF_NOLINK 0x80000 /* don't show URLs */ -#define LOWDOWN_NROFF_NUMBERED 0x80 /* numbered section headers */ +#define LOWDOWN_LATEX_NUMBERED 0x4000 /* numbered sections */ +#define LOWDOWN_GEMINI_LINK_END 0x8000 /* links at end */ +#define LOWDOWN_GEMINI_LINK_IN 0x10000 /* links inline */ +#define LOWDOWN_TERM_NOLINK 0x20000 /* don't show URLs */ #define LOWDOWN_NROFF_SHORTLINK 0x40000 /* shorten URLs */ -#define LOWDOWN_NROFF_SKIP_HTML 0x08 /* skip all HTML */ -#define LOWDOWN_NROFF_ENDNOTES 0x40000000 /* endnotes for -tms */ -#define LOWDOWN_ODT_SKIP_HTML 0x2000000 /* skip all HTML */ -#define LOWDOWN_SMARTY 0x40 /* smart typography */ -#define LOWDOWN_STANDALONE 0x200 /* emit complete document */ -#define LOWDOWN_TERM_NOANSI 0x1000000 /* no ANSI escapes at all */ +#define LOWDOWN_NROFF_NOLINK 0x80000 /* don't show URLs */ +#define LOWDOWN_GEMINI_METADATA 0x100000 /* show metadata */ +#define LOWDOWN_GEMINI_LINK_NOREF 0x200000 /* for !inline, no names */ +#define LOWDOWN_GEMINI_LINK_ROMAN 0x400000 /* roman link names */ #define LOWDOWN_TERM_NOCOLOUR 0x800000 /* no ANSI colours */ -#define LOWDOWN_TERM_NOLINK 0x20000 /* don't show URLs */ -#define LOWDOWN_TERM_SHORTLINK 0x400 /* shorten URLs */ +#define LOWDOWN_TERM_NOANSI 0x1000000 /* no ANSI escapes at all */ +#define LOWDOWN_ODT_SKIP_HTML 0x2000000 /* skip all HTML */ +#define LOWDOWN_HTML_TITLEBLOCK 0x4000000 /* output title block */ +#define LOWDOWN_HTML_CALLOUT_GFM 0x8000000 /* GFM callouts */ +#define LOWDOWN_HTML_CALLOUT_MDN 0x10000000 /* MDN callouts */ #define LOWDOWN_TERM_ALL_META 0x20000000 /* show all metadata */ +#define LOWDOWN_NROFF_ENDNOTES 0x40000000 /* endnotes for -tms */ char **meta; size_t metasz; char **metaovr; diff --git a/term.c b/term.c index 1b42392..a4c1dcc 100644 --- a/term.c +++ b/term.c @@ -173,6 +173,29 @@ rndr_mbswidth(struct term *term, const char *buf, size_t sz) return csz == (size_t)-1 ? sz : csz; } +/* + * Determine whether a link URL is relative. Use a simple heuristic to + * accomplish this: a relative URL is one without a schema. Returns + * zero if not a relative link, non-zero if it is. + */ +static int +link_isrelative(const struct lowdown_buf *link) +{ + const char *colon; + size_t rem; + + /* If there's no colon, it's a relative link (no schema) */ + + if ((colon = memchr(link->data, ':', link->size)) == NULL) + return 1; + + /* If there's a slash before the colon, it's a (rel) path. */ + + assert(colon > link->data); + rem = colon - link->data; + return memchr(link->data, '/', rem) != NULL; +} + /* * Copy the buffer into "out", escaping along the width. * Returns the number of actual printed columns, which in the case of @@ -1576,6 +1599,9 @@ rndr(struct lowdown_buf *ob, struct term *st, case LOWDOWN_LINK: if (st->opts & LOWDOWN_TERM_NOLINK) break; + if ((st->opts & LOWDOWN_TERM_NORELLINK) && + link_isrelative(&n->rndr_link.link)) + break; hbuf_truncate(st->tmp); if (!HBUF_PUTSL(st->tmp, " ") || !rndr_buf(st, ob, n, st->tmp, NULL))