summaryrefslogtreecommitdiffstats
path: root/roff.c
diff options
context:
space:
mode:
authorIngo Schwarze <schwarze@openbsd.org>2014-10-20 15:04:56 +0000
committerIngo Schwarze <schwarze@openbsd.org>2014-10-20 15:04:56 +0000
commit0284beff01aa6cf1819c49e16dde13c3eb602990 (patch)
tree6152ef5d6181b530dd8adfb73999ffd7cf9d5cf8 /roff.c
parentf1689f618aeb4d82318224898f0df3ba12ebe25c (diff)
downloadmandoc-0284beff01aa6cf1819c49e16dde13c3eb602990.tar.gz
correctly parse spacing around in-line equations
at the beginning and at the end of input lines; issue reported by kristaps@
Diffstat (limited to 'roff.c')
-rw-r--r--roff.c41
1 files changed, 36 insertions, 5 deletions
diff --git a/roff.c b/roff.c
index d5bc54e2..cd310b4f 100644
--- a/roff.c
+++ b/roff.c
@@ -1857,7 +1857,8 @@ roff_T_(ROFF_ARGS)
static enum rofferr
roff_eqndelim(struct roff *r, char **bufp, size_t *szp, int pos)
{
- char *cp1, *cp2;
+ char *cp1, *cp2;
+ const char *bef_pr, *bef_nl, *mac, *aft_nl, *aft_pr;
/*
* Outside equations, look for an opening delimiter.
@@ -1872,11 +1873,41 @@ roff_eqndelim(struct roff *r, char **bufp, size_t *szp, int pos)
if (cp2 == NULL)
return(ROFF_CONT);
- /* Replace the delimiter with an equation macro. */
-
*cp2++ = '\0';
- *szp = mandoc_asprintf(&cp1, "%s%s%s", *bufp,
- r->eqn == NULL ? "\\&\n.EQ\n" : "\n.EN\n\\&", cp2) + 1;
+ bef_pr = bef_nl = aft_nl = aft_pr = "";
+
+ /* Handle preceding text, protecting whitespace. */
+
+ if (**bufp != '\0') {
+ if (r->eqn == NULL)
+ bef_pr = "\\&";
+ bef_nl = "\n";
+ }
+
+ /*
+ * Prepare replacing the delimiter with an equation macro
+ * and drop leading white space from the equation.
+ */
+
+ if (r->eqn == NULL) {
+ while (*cp2 == ' ')
+ cp2++;
+ mac = ".EQ";
+ } else
+ mac = ".EN";
+
+ /* Handle following text, protecting whitespace. */
+
+ if (*cp2 != '\0') {
+ aft_nl = "\n";
+ if (r->eqn != NULL)
+ aft_pr = "\\&";
+ }
+
+ /* Do the actual replacement. */
+
+ *szp = mandoc_asprintf(&cp1, "%s%s%s%s%s%s%s", *bufp,
+ bef_pr, bef_nl, mac, aft_nl, aft_pr, cp2) + 1;
free(*bufp);
*bufp = cp1;