[BACK]Return to term_ascii.c CVS log [TXT][DIR] Up to [cvsweb.bsd.lv] / mandoc

Diff for /mandoc/term_ascii.c between version 1.18 and 1.22

version 1.18, 2011/09/18 14:14:15 version 1.22, 2014/03/23 11:25:26
Line 20 
Line 20 
   
 #include <sys/types.h>  #include <sys/types.h>
   
 #include <assert.h>  
 #ifdef USE_WCHAR  #ifdef USE_WCHAR
 # include <locale.h>  # include <locale.h>
 #endif  #endif
Line 33 
Line 32 
 #endif  #endif
   
 #include "mandoc.h"  #include "mandoc.h"
   #include "mandoc_aux.h"
 #include "out.h"  #include "out.h"
 #include "term.h"  #include "term.h"
 #include "main.h"  #include "main.h"
Line 68  static size_t    locale_width(const struct termp *, in
Line 68  static size_t    locale_width(const struct termp *, in
 static struct termp *  static struct termp *
 ascii_init(enum termenc enc, char *outopts)  ascii_init(enum termenc enc, char *outopts)
 {  {
         const char      *toks[2];          const char      *toks[4];
         char            *v;          char            *v;
         struct termp    *p;          struct termp    *p;
   
         p = mandoc_calloc(1, sizeof(struct termp));          p = mandoc_calloc(1, sizeof(struct termp));
         p->enc = enc;  
   
         p->tabwidth = 5;          p->tabwidth = 5;
         p->defrmargin = 78;          p->defrmargin = 78;
Line 93  ascii_init(enum termenc enc, char *outopts)
Line 92  ascii_init(enum termenc enc, char *outopts)
         if (TERMENC_ASCII != enc) {          if (TERMENC_ASCII != enc) {
                 v = TERMENC_LOCALE == enc ?                  v = TERMENC_LOCALE == enc ?
                         setlocale(LC_ALL, "") :                          setlocale(LC_ALL, "") :
                         setlocale(LC_CTYPE, "UTF-8");                          setlocale(LC_CTYPE, "en_US.UTF-8");
                 if (NULL != v && MB_CUR_MAX > 1) {                  if (NULL != v && MB_CUR_MAX > 1) {
                         p->enc = enc;                          p->enc = enc;
                         p->advance = locale_advance;                          p->advance = locale_advance;
Line 104  ascii_init(enum termenc enc, char *outopts)
Line 103  ascii_init(enum termenc enc, char *outopts)
         }          }
 #endif  #endif
   
         toks[0] = "width";          toks[0] = "indent";
         toks[1] = NULL;          toks[1] = "width";
           toks[2] = "mdoc";
           toks[3] = NULL;
   
         while (outopts && *outopts)          while (outopts && *outopts)
                 switch (getsubopt(&outopts, UNCONST(toks), &v)) {                  switch (getsubopt(&outopts, UNCONST(toks), &v)) {
                 case (0):                  case (0):
                           p->defindent = (size_t)atoi(v);
                           break;
                   case (1):
                         p->defrmargin = (size_t)atoi(v);                          p->defrmargin = (size_t)atoi(v);
                           break;
                   case (2):
                           /*
                            * Temporary, undocumented mode
                            * to imitate mdoc(7) output style.
                            */
                           p->mdocstyle = 1;
                           p->defindent = 5;
                         break;                          break;
                 default:                  default:
                         break;                          break;

Legend:
Removed from v.1.18  
changed lines
  Added in v.1.22

CVSweb