summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--man.c23
-rw-r--r--man.h1
-rw-r--r--man_term.c3
3 files changed, 27 insertions, 0 deletions
diff --git a/man.c b/man.c
index a07b89b8..ce67992e 100644
--- a/man.c
+++ b/man.c
@@ -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:
diff --git a/man.h b/man.h
index ec01cae1..8744efe9 100644
--- a/man.h
+++ b/man.h
@@ -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;
diff --git a/man_term.c b/man_term.c
index 58f424ca..a070648b 100644
--- a/man_term.c
+++ b/man_term.c
@@ -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;
}