version 1.24, 2014/03/30 21:28:01 |
version 1.25, 2014/04/20 16:46:05 |
Line 67 static void locale_letter(struct termp *, int); |
|
Line 67 static void locale_letter(struct termp *, int); |
|
static size_t locale_width(const struct termp *, int); |
static size_t locale_width(const struct termp *, int); |
#endif |
#endif |
|
|
|
|
static struct termp * |
static struct termp * |
ascii_init(enum termenc enc, char *outopts) |
ascii_init(enum termenc enc, char *outopts) |
{ |
{ |
Line 94 ascii_init(enum termenc enc, char *outopts) |
|
Line 95 ascii_init(enum termenc enc, char *outopts) |
|
#ifdef USE_WCHAR |
#ifdef USE_WCHAR |
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, "en_US.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 113 ascii_init(enum termenc enc, char *outopts) |
|
Line 114 ascii_init(enum termenc enc, char *outopts) |
|
|
|
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); |
p->defindent = (size_t)atoi(v); |
break; |
break; |
case (1): |
case 1: |
p->defrmargin = (size_t)atoi(v); |
p->defrmargin = (size_t)atoi(v); |
break; |
break; |
case (2): |
case 2: |
/* |
/* |
* Temporary, undocumented mode |
* Temporary, undocumented mode |
* to imitate mdoc(7) output style. |
* to imitate mdoc(7) output style. |
Line 152 utf8_alloc(char *outopts) |
|
Line 153 utf8_alloc(char *outopts) |
|
return(ascii_init(TERMENC_UTF8, outopts)); |
return(ascii_init(TERMENC_UTF8, outopts)); |
} |
} |
|
|
|
|
void * |
void * |
locale_alloc(char *outopts) |
locale_alloc(char *outopts) |
{ |
{ |
Line 175 ascii_setwidth(struct termp *p, int iop, size_t width) |
|
Line 175 ascii_setwidth(struct termp *p, int iop, size_t width) |
|
p->rmargin = p->maxrmargin = p->defrmargin; |
p->rmargin = p->maxrmargin = p->defrmargin; |
} |
} |
|
|
/* ARGSUSED */ |
|
static size_t |
static size_t |
ascii_width(const struct termp *p, int c) |
ascii_width(const struct termp *p, int c) |
{ |
{ |
Line 190 ascii_free(void *arg) |
|
Line 189 ascii_free(void *arg) |
|
term_free((struct termp *)arg); |
term_free((struct termp *)arg); |
} |
} |
|
|
/* ARGSUSED */ |
|
static void |
static void |
ascii_letter(struct termp *p, int c) |
ascii_letter(struct termp *p, int c) |
{ |
{ |
|
|
putchar(c); |
putchar(c); |
} |
} |
|
|
Line 212 ascii_end(struct termp *p) |
|
Line 210 ascii_end(struct termp *p) |
|
(*p->footf)(p, p->argf); |
(*p->footf)(p, p->argf); |
} |
} |
|
|
/* ARGSUSED */ |
|
static void |
static void |
ascii_endline(struct termp *p) |
ascii_endline(struct termp *p) |
{ |
{ |
Line 220 ascii_endline(struct termp *p) |
|
Line 217 ascii_endline(struct termp *p) |
|
putchar('\n'); |
putchar('\n'); |
} |
} |
|
|
/* ARGSUSED */ |
|
static void |
static void |
ascii_advance(struct termp *p, size_t len) |
ascii_advance(struct termp *p, size_t len) |
{ |
{ |
size_t i; |
size_t i; |
|
|
for (i = 0; i < len; i++) |
for (i = 0; i < len; i++) |
putchar(' '); |
putchar(' '); |
} |
} |
|
|
/* ARGSUSED */ |
|
static double |
static double |
ascii_hspan(const struct termp *p, const struct roffsu *su) |
ascii_hspan(const struct termp *p, const struct roffsu *su) |
{ |
{ |
Line 242 ascii_hspan(const struct termp *p, const struct roffsu |
|
Line 237 ascii_hspan(const struct termp *p, const struct roffsu |
|
*/ |
*/ |
|
|
switch (su->unit) { |
switch (su->unit) { |
case (SCALE_CM): |
case SCALE_CM: |
r = 4 * su->scale; |
r = 4 * su->scale; |
break; |
break; |
case (SCALE_IN): |
case SCALE_IN: |
r = 10 * su->scale; |
r = 10 * su->scale; |
break; |
break; |
case (SCALE_PC): |
case SCALE_PC: |
r = (10 * su->scale) / 6; |
r = (10 * su->scale) / 6; |
break; |
break; |
case (SCALE_PT): |
case SCALE_PT: |
r = (10 * su->scale) / 72; |
r = (10 * su->scale) / 72; |
break; |
break; |
case (SCALE_MM): |
case SCALE_MM: |
r = su->scale / 1000; |
r = su->scale / 1000; |
break; |
break; |
case (SCALE_VS): |
case SCALE_VS: |
r = su->scale * 2 - 1; |
r = su->scale * 2 - 1; |
break; |
break; |
default: |
default: |
Line 269 ascii_hspan(const struct termp *p, const struct roffsu |
|
Line 264 ascii_hspan(const struct termp *p, const struct roffsu |
|
} |
} |
|
|
#ifdef USE_WCHAR |
#ifdef USE_WCHAR |
/* ARGSUSED */ |
|
static size_t |
static size_t |
locale_width(const struct termp *p, int c) |
locale_width(const struct termp *p, int c) |
{ |
{ |
Line 278 locale_width(const struct termp *p, int c) |
|
Line 272 locale_width(const struct termp *p, int c) |
|
return((rc = wcwidth(c)) < 0 ? 0 : rc); |
return((rc = wcwidth(c)) < 0 ? 0 : rc); |
} |
} |
|
|
/* ARGSUSED */ |
|
static void |
static void |
locale_advance(struct termp *p, size_t len) |
locale_advance(struct termp *p, size_t len) |
{ |
{ |
size_t i; |
size_t i; |
|
|
for (i = 0; i < len; i++) |
for (i = 0; i < len; i++) |
putwchar(L' '); |
putwchar(L' '); |
} |
} |
|
|
/* ARGSUSED */ |
|
static void |
static void |
locale_endline(struct termp *p) |
locale_endline(struct termp *p) |
{ |
{ |
Line 296 locale_endline(struct termp *p) |
|
Line 288 locale_endline(struct termp *p) |
|
putwchar(L'\n'); |
putwchar(L'\n'); |
} |
} |
|
|
/* ARGSUSED */ |
|
static void |
static void |
locale_letter(struct termp *p, int c) |
locale_letter(struct termp *p, int c) |
{ |
{ |
|
|
putwchar(c); |
putwchar(c); |
} |
} |
#endif |
#endif |