little else. Also remove the check for __STDC_ISO_10646__. It turns
out that very few systems---even those that support it---actually
declare this and it's just causing problems instead of being useful.
-/* $Id: main.h,v 1.11 2011/05/17 14:38:34 kristaps Exp $ */
+/* $Id: main.h,v 1.12 2011/05/20 15:48:22 kristaps Exp $ */
/*
* Copyright (c) 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv>
*
/*
* Copyright (c) 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv>
*
void tree_man(void *, const struct man *);
void *locale_alloc(char *);
void tree_man(void *, const struct man *);
void *locale_alloc(char *);
+void *utf8_alloc(char *);
void *ascii_alloc(char *);
void ascii_free(void *);
void *ascii_alloc(char *);
void ascii_free(void *);
-/* $Id: term.h,v 1.84 2011/05/17 14:38:34 kristaps Exp $ */
+/* $Id: term.h,v 1.85 2011/05/20 15:48:22 kristaps Exp $ */
/*
* Copyright (c) 2008, 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv>
*
/*
* Copyright (c) 2008, 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv>
*
enum termenc {
TERMENC_ASCII,
enum termenc {
TERMENC_ASCII,
+ TERMENC_LOCALE,
+ TERMENC_UTF8
-/* $Id: term_ascii.c,v 1.16 2011/05/19 15:48:58 kristaps Exp $ */
+/* $Id: term_ascii.c,v 1.17 2011/05/20 15:48:22 kristaps Exp $ */
/*
* Copyright (c) 2010 Kristaps Dzonsons <kristaps@bsd.lv>
*
/*
* Copyright (c) 2010 Kristaps Dzonsons <kristaps@bsd.lv>
*
p->letter = ascii_letter;
p->width = ascii_width;
p->letter = ascii_letter;
p->width = ascii_width;
-#if defined (USE_WCHAR)
- if (TERMENC_LOCALE == enc)
- if (setlocale(LC_ALL, "") && MB_CUR_MAX > 1) {
+#ifdef USE_WCHAR
+ if (TERMENC_ASCII != enc) {
+ v = TERMENC_LOCALE == enc ?
+ setlocale(LC_ALL, "") :
+ setlocale(LC_CTYPE, "UTF-8");
+ if (NULL != v && MB_CUR_MAX > 1) {
p->enc = enc;
p->advance = locale_advance;
p->endline = locale_endline;
p->letter = locale_letter;
p->width = locale_width;
}
p->enc = enc;
p->advance = locale_advance;
p->endline = locale_endline;
p->letter = locale_letter;
p->width = locale_width;
}
#endif
toks[0] = "width";
#endif
toks[0] = "width";
return(ascii_init(TERMENC_ASCII, outopts));
}
return(ascii_init(TERMENC_ASCII, outopts));
}
+void *
+utf8_alloc(char *outopts)
+{
+
+ return(ascii_init(TERMENC_UTF8, outopts));
+}
+
+
void *
locale_alloc(char *outopts)
{
void *
locale_alloc(char *outopts)
{