diff options
-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; } |