summaryrefslogtreecommitdiff
path: root/format.c
diff options
context:
space:
mode:
authordefault <nobody@localhost>2022-11-06 06:55:06 +0100
committerdefault <nobody@localhost>2022-11-06 06:55:06 +0100
commit01743cee551f84c81db00714a59d6897418ba06a (patch)
tree580613c23da88dbdec713e53a7572197689e67a4 /format.c
parent7992563532584382b8f10b0324bb02e092c57858 (diff)
More tweaks to not_really_markdown() to avoid ambiguities.
Diffstat (limited to 'format.c')
-rw-r--r--format.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/format.c b/format.c
index ae2b731..93080fe 100644
--- a/format.c
+++ b/format.c
@@ -44,9 +44,12 @@ d_char *not_really_markdown(char *content, d_char **f_content)
char *p, *v;
xs *wrk = xs_str_new(NULL);
+ /* some preparation to avoid writing very kludgy code */
+ xs *p_content = xs_replace(content, "```", "@pre@");
+
{
/* split by special markup */
- xs *sm = xs_regex_split(content,
+ xs *sm = xs_regex_split(p_content,
"(`[^`]+`|\\*\\*?[^\\*]+\\*?\\*|https?:/" "/[^[:space:]]+)");
int n = 0;
@@ -54,7 +57,7 @@ d_char *not_really_markdown(char *content, d_char **f_content)
while (xs_list_iter(&p, &v)) {
if ((n & 0x1)) {
/* markup */
- if (xs_startswith(v, "`") && v[1] != '\n') {
+ if (xs_startswith(v, "`")) {
xs *s1 = xs_crop(xs_dup(v), 1, -1);
xs *s2 = xs_fmt("<code>%s</code>", s1);
wrk = xs_str_cat(wrk, s2);
@@ -95,7 +98,7 @@ d_char *not_really_markdown(char *content, d_char **f_content)
while (xs_list_iter(&p, &v)) {
xs *ss = xs_strip(xs_dup(v));
- if (xs_startswith(ss, "```")) {
+ if (xs_startswith(ss, "@pre@")) {
if (!in_pre)
s = xs_str_cat(s, "<pre>");
else