diff options
author | Kristaps Dzonsons <kristaps@bsd.lv> | 2010-05-12 16:46:28 +0000 |
---|---|---|
committer | Kristaps Dzonsons <kristaps@bsd.lv> | 2010-05-12 16:46:28 +0000 |
commit | 4daffc849bbddd623b910e2b63a734fb4d03d633 (patch) | |
tree | 7e77fd405e874037bb8a3074b6da9ef84de5d02d | |
parent | 2c120582ef488979d4fe93a2b6a88f498dac4a3b (diff) | |
download | mandoc-4daffc849bbddd623b910e2b63a734fb4d03d633.tar.gz |
End-of-sentence spacing for -man -Tascii.
-rw-r--r-- | man.c | 23 | ||||
-rw-r--r-- | man.h | 1 | ||||
-rw-r--r-- | man_term.c | 3 |
3 files changed, 27 insertions, 0 deletions
@@ -420,6 +420,29 @@ man_ptext(struct man *m, int line, char *buf) if ( ! man_word_alloc(m, line, 0, buf)) return(0); + /* + * End-of-sentence check. If the last character is an unescaped + * EOS character, then flag the node as being the end of a + * sentence. The front-end will know how to interpret this. + */ + + assert(i); + + switch (buf[i - 1]) { + case ('.'): + if (i > 1 && '\\' == buf[i - 2]) + break; + /* FALLTHROUGH */ + case ('!'): + /* FALLTHROUGH */ + case ('?'): + m->last->flags |= MAN_EOS; + break; + default: + break; + + } + descope: /* * Co-ordinate what happens with having a next-line scope open: @@ -93,6 +93,7 @@ struct man_node { int flags; #define MAN_VALID (1 << 0) #define MAN_ACTED (1 << 1) +#define MAN_EOS (1 << 2) enum man_type type; char *string; struct man_node *head; @@ -842,6 +842,9 @@ print_man_node(DECL_ARGS) if ( ! (MAN_NOTEXT & termacts[n->tok].flags)) term_fontrepl(p, TERMFONT_NONE); } + + if (MAN_EOS & n->flags) + p->flags |= TERMP_SENTENCE; } |