=================================================================== RCS file: /cvsrepo/anoncvs/cvs/src/usr.bin/mandoc/term_ascii.c,v retrieving revision 1.11 retrieving revision 1.12 diff -u -r1.11 -r1.12 --- src/usr.bin/mandoc/term_ascii.c 2014/03/21 22:17:01 1.11 +++ src/usr.bin/mandoc/term_ascii.c 2014/03/30 19:47:32 1.12 @@ -1,6 +1,7 @@ -/* $Id: term_ascii.c,v 1.11 2014/03/21 22:17:01 schwarze Exp $ */ +/* $Id: term_ascii.c,v 1.12 2014/03/30 19:47:32 schwarze Exp $ */ /* * Copyright (c) 2010, 2011 Kristaps Dzonsons + * Copyright (c) 2014 Ingo Schwarze * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above @@ -38,6 +39,7 @@ static void ascii_end(struct termp *); static void ascii_endline(struct termp *); static void ascii_letter(struct termp *, int); +static void ascii_setwidth(struct termp *, size_t); static void locale_advance(struct termp *, size_t); static void locale_endline(struct termp *); @@ -54,7 +56,7 @@ p = mandoc_calloc(1, sizeof(struct termp)); p->tabwidth = 5; - p->defrmargin = 78; + p->defrmargin = p->lastrmargin = 78; p->begin = ascii_begin; p->end = ascii_end; @@ -65,6 +67,7 @@ p->advance = ascii_advance; p->endline = ascii_endline; p->letter = ascii_letter; + p->setwidth = ascii_setwidth; p->width = ascii_width; if (TERMENC_ASCII != enc) { @@ -132,6 +135,17 @@ { return(ascii_init(TERMENC_LOCALE, outopts)); +} + +static void +ascii_setwidth(struct termp *p, size_t width) +{ + size_t lastwidth; + + lastwidth = p->defrmargin; + p->rmargin = p->maxrmargin = p->defrmargin = + width ? width : p->lastrmargin; + p->lastrmargin = lastwidth; } /* ARGSUSED */