summaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--html.c8
-rw-r--r--mdoc_strings.c12
-rw-r--r--term.c75
3 files changed, 62 insertions, 33 deletions
diff --git a/html.c b/html.c
index 31372b99..b218ad17 100644
--- a/html.c
+++ b/html.c
@@ -1,4 +1,4 @@
-/* $Id: html.c,v 1.96 2010/02/17 19:48:33 kristaps Exp $ */
+/* $Id: html.c,v 1.97 2010/04/03 12:46:35 kristaps Exp $ */
/*
* Copyright (c) 2008, 2009 Kristaps Dzonsons <kristaps@kth.se>
*
@@ -507,8 +507,6 @@ print_text(struct html *h, const char *p)
case(')'):
/* FALLTHROUGH */
case(']'):
- /* FALLTHROUGH */
- case('}'):
if ( ! (HTML_IGNDELIM & h->flags))
h->flags |= HTML_NOSPACE;
break;
@@ -525,11 +523,11 @@ print_text(struct html *h, const char *p)
if (*p && 0 == *(p + 1))
switch (*p) {
+ case('|'):
+ /* FALLTHROUGH */
case('('):
/* FALLTHROUGH */
case('['):
- /* FALLTHROUGH */
- case('{'):
h->flags |= HTML_NOSPACE;
break;
default:
diff --git a/mdoc_strings.c b/mdoc_strings.c
index 4aa71142..9007fa32 100644
--- a/mdoc_strings.c
+++ b/mdoc_strings.c
@@ -1,4 +1,4 @@
-/* $Id: mdoc_strings.c,v 1.15 2010/03/29 19:28:04 kristaps Exp $ */
+/* $Id: mdoc_strings.c,v 1.16 2010/04/03 12:46:35 kristaps Exp $ */
/*
* Copyright (c) 2008 Kristaps Dzonsons <kristaps@kth.se>
*
@@ -61,18 +61,20 @@ static const struct mdoc_secname secnames[SECNAME_MAX] = {
};
+/*
+ * FIXME: this is repeated in print_text() (html.c) and term_word()
+ * (term.c).
+ */
int
mdoc_iscdelim(char p)
{
switch (p) {
- case('|'):
+ case('|'): /* FIXME! */
/* FALLTHROUGH */
case('('):
/* FALLTHROUGH */
case('['):
- /* FALLTHROUGH */
- case('{'):
return(1);
case('.'):
/* FALLTHROUGH */
@@ -89,8 +91,6 @@ mdoc_iscdelim(char p)
case(')'):
/* FALLTHROUGH */
case(']'):
- /* FALLTHROUGH */
- case('}'):
return(2);
default:
break;
diff --git a/term.c b/term.c
index 1421843f..f44dacc7 100644
--- a/term.c
+++ b/term.c
@@ -1,4 +1,4 @@
-/* $Id: term.c,v 1.129 2010/03/23 12:42:22 kristaps Exp $ */
+/* $Id: term.c,v 1.130 2010/04/03 12:46:35 kristaps Exp $ */
/*
* Copyright (c) 2008, 2009 Kristaps Dzonsons <kristaps@kth.se>
*
@@ -92,12 +92,10 @@ term_alloc(enum termenc enc)
* Flush a line of text. A "line" is loosely defined as being something
* that should be followed by a newline, regardless of whether it's
* broken apart by newlines getting there. A line can also be a
- * fragment of a columnar list.
+ * fragment of a columnar list (`Bl -tag' or `Bl -column'), which does
+ * not have a trailing newline.
*
- * Specifically, a line is whatever's in p->buf of length p->col, which
- * is zeroed after this function returns.
- *
- * The usage of termp:flags is as follows:
+ * The following flags may be specified:
*
* - TERMP_NOLPAD: when beginning to write the line, don't left-pad the
* offset value. This is useful when doing columnar lists where the
@@ -133,6 +131,7 @@ term_flushln(struct termp *p)
size_t vbl; /* number of blanks to prepend to output */
size_t vsz; /* visual characters to write to output */
size_t bp; /* visual right border position */
+ size_t hyph; /* visible position of hyphen */
int j; /* temporary loop index */
size_t maxvis, mmax;
@@ -178,16 +177,23 @@ term_flushln(struct termp *p)
* (starting with the CSI) aren't counted. A space
* generates a non-printing word, which is valid (the
* space is printed according to regular spacing rules).
+ * Collect the number of printable characters until the
+ * first hyphen, if found. Hyphens aren't included if
+ * they're the first character (so `Fl' doesn't break)
+ * or second consecutive character (`Fl -').
*/
/* LINTED */
- for (j = i, vsz = 0; j < (int)p->col; j++) {
+ for (j = i, vsz = 0, hyph = 0; j < (int)p->col; j++) {
if (j && ' ' == p->buf[j])
break;
- else if (8 == p->buf[j])
+ if (8 == p->buf[j])
vsz--;
else
vsz++;
+ if (j > i && '-' == p->buf[j] && 0 == hyph)
+ if ('-' != p->buf[j - 1])
+ hyph = vsz;
}
/*
@@ -195,14 +201,43 @@ term_flushln(struct termp *p)
* beginning of a line, one between words -- but do not
* actually write them yet.
*/
+
vbl = (size_t)(0 == vis ? 0 : 1);
/*
* Find out whether we would exceed the right margin.
- * If so, break to the next line. (TODO: hyphenate)
- * Otherwise, write the chosen number of blanks now.
+ * If so, break to the next line, possibly after
+ * emittign character up to a hyphen. Otherwise, write
+ * the chosen number of blanks.
*/
+
if (vis && vis + vbl + vsz > bp) {
+ /*
+ * Has a hyphen been found before the breakpoint
+ * that we can use?
+ */
+ if (hyph && vis + vbl + hyph <= bp) {
+ /* First prepend blanks. */
+ for (j = 0; j < (int)vbl; j++)
+ putchar(' ');
+
+ /* Emit up to the character. */
+ do {
+ if (31 == p->buf[i])
+ putchar(' ');
+ else
+ putchar(p->buf[i]);
+ if (8 != p->buf[i])
+ vsz--;
+ } while ('-' != p->buf[i++]);
+
+ /* Emit trailing decoration. */
+ if (8 == p->buf[i]) {
+ putchar(p->buf[i]);
+ putchar(p->buf[i + 1]);
+ }
+ }
+
putchar('\n');
if (TERMP_NOBREAK & p->flags) {
for (j = 0; j < (int)p->rmargin; j++)
@@ -213,7 +248,9 @@ term_flushln(struct termp *p)
putchar(' ');
vis = 0;
}
+
/* Remove the p->overstep width. */
+
bp += (int)/* LINTED */
p->overstep;
p->overstep = 0;
@@ -223,19 +260,15 @@ term_flushln(struct termp *p)
vis += vbl;
}
- /*
- * Finally, write out the word.
- */
- for ( ; i < (int)p->col; i++) {
+ /* Write out the [remaining] word. */
+ for ( ; i < (int)p->col; i++)
if (' ' == p->buf[i])
break;
-
- /* The unit sep. is a non-breaking space. */
- if (31 == p->buf[i])
+ else if (31 == p->buf[i])
putchar(' ');
else
putchar(p->buf[i]);
- }
+
vis += vsz;
}
@@ -440,8 +473,6 @@ term_word(struct termp *p, const char *word)
case(')'):
/* FALLTHROUGH */
case(']'):
- /* FALLTHROUGH */
- case('}'):
if ( ! (TERMP_IGNDELIM & p->flags))
p->flags |= TERMP_NOSPACE;
break;
@@ -497,11 +528,11 @@ term_word(struct termp *p, const char *word)
if (sv[0] && 0 == sv[1])
switch (sv[0]) {
+ case('|'):
+ /* FALLTHROUGH */
case('('):
/* FALLTHROUGH */
case('['):
- /* FALLTHROUGH */
- case('{'):
p->flags |= TERMP_NOSPACE;
break;
default: