summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKristaps Dzonsons <kristaps@bsd.lv>2010-05-12 16:46:28 +0000
committerKristaps Dzonsons <kristaps@bsd.lv>2010-05-12 16:46:28 +0000
commit4daffc849bbddd623b910e2b63a734fb4d03d633 (patch)
tree7e77fd405e874037bb8a3074b6da9ef84de5d02d
parent2c120582ef488979d4fe93a2b6a88f498dac4a3b (diff)
downloadmandoc-4daffc849bbddd623b910e2b63a734fb4d03d633.tar.gz
End-of-sentence spacing for -man -Tascii.
-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;
}