aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/man_term.c
diff options
context:
space:
mode:
authorIngo Schwarze <schwarze@openbsd.org>2014-02-16 12:33:39 +0000
committerIngo Schwarze <schwarze@openbsd.org>2014-02-16 12:33:39 +0000
commit8a0b324b8b94885e022c49afb19b7d3a8bcc6f37 (patch)
treef37d9f3b8dec4e1167a600035dc8bbc4386154fb /man_term.c
parent252902fd24cc5fe83e72673afcc66c140a42de42 (diff)
downloadmandoc-8a0b324b8b94885e022c49afb19b7d3a8bcc6f37.tar.gz
mandoc-8a0b324b8b94885e022c49afb19b7d3a8bcc6f37.tar.zst
mandoc-8a0b324b8b94885e022c49afb19b7d3a8bcc6f37.zip
when indenting, extend the right margin accordingly, when needed;
fixes a crash reported by blambert@ and a few other, similar ones
Diffstat (limited to 'man_term.c')
-rw-r--r--man_term.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/man_term.c b/man_term.c
index 4bd62443..10378d3a 100644
--- a/man_term.c
+++ b/man_term.c
@@ -1,7 +1,7 @@
-/* $Id: man_term.c,v 1.139 2013/12/22 23:34:13 schwarze Exp $ */
+/* $Id: man_term.c,v 1.140 2014/02/16 12:33:39 schwarze Exp $ */
/*
* Copyright (c) 2008-2012 Kristaps Dzonsons <kristaps@bsd.lv>
- * Copyright (c) 2010, 2011, 2012, 2013 Ingo Schwarze <schwarze@openbsd.org>
+ * Copyright (c) 2010-2014 Ingo Schwarze <schwarze@openbsd.org>
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
@@ -658,7 +658,8 @@ pre_IP(DECL_ARGS)
return(0);
case (MAN_BODY):
p->offset = mt->offset + len;
- p->rmargin = p->maxrmargin;
+ p->rmargin = p->maxrmargin > p->offset ?
+ p->maxrmargin : p->offset;
break;
default:
break;
@@ -748,7 +749,8 @@ pre_TP(DECL_ARGS)
return(0);
case (MAN_BODY):
p->offset = mt->offset + len;
- p->rmargin = p->maxrmargin;
+ p->rmargin = p->maxrmargin > p->offset ?
+ p->maxrmargin : p->offset;
p->trailspace = 0;
p->flags &= ~TERMP_NOBREAK;
break;
@@ -909,8 +911,9 @@ pre_RS(DECL_ARGS)
sz = (size_t)ival;
mt->offset += sz;
- p->rmargin = p->maxrmargin;
- p->offset = mt->offset < p->rmargin ? mt->offset : p->rmargin;
+ p->offset = mt->offset;
+ p->rmargin = p->maxrmargin > p->offset ?
+ p->maxrmargin : p->offset;
if (++mt->lmarginsz < MAXMARGINS)
mt->lmargincur = mt->lmarginsz;