X-Git-Url: https://ncurses.scripts.mit.edu/?p=ncurses.git;a=blobdiff_plain;f=ncurses%2Fwidechar%2Flib_wacs.c;h=6316e1d4820d0ffeaaecde67986d77091f5e1b1a;hp=33e001fa93e700eed6b42399243fe7b8358e5880;hb=ec78532c7ae5200ec0d66281ae3d0d8b0626cb60;hpb=eee1237c858e39ddc0970dfc5a44d0ec76e2d9e4 diff --git a/ncurses/widechar/lib_wacs.c b/ncurses/widechar/lib_wacs.c index 33e001fa..6316e1d4 100644 --- a/ncurses/widechar/lib_wacs.c +++ b/ncurses/widechar/lib_wacs.c @@ -1,5 +1,5 @@ /**************************************************************************** - * Copyright (c) 2002-2012,2013 Free Software Foundation, Inc. * + * Copyright (c) 2002-2014,2015 Free Software Foundation, Inc. * * * * Permission is hereby granted, free of charge, to any person obtaining a * * copy of this software and associated documentation files (the * @@ -32,7 +32,7 @@ #include -MODULE_ID("$Id: lib_wacs.c,v 1.13 2013/02/02 17:10:48 tom Exp $") +MODULE_ID("$Id: lib_wacs.c,v 1.15 2015/12/13 00:56:03 tom Exp $") NCURSES_EXPORT_VAR(cchar_t) * _nc_wacs = 0; @@ -122,19 +122,15 @@ _nc_init_wacs(void) if ((_nc_wacs = typeCalloc(cchar_t, ACS_LEN)) != 0) { for (n = 0; n < SIZEOF(table); ++n) { - int wide = wcwidth(table[n].value[active]); + int wide = wcwidth((wchar_t) table[n].value[active]); m = table[n].map; - if (active && (wide == 1)) { - SetChar(_nc_wacs[m], table[n].value[1], A_NORMAL); - } else if (acs_map[m] & A_ALTCHARSET) { - SetChar(_nc_wacs[m], m, A_ALTCHARSET); - } else { - SetChar(_nc_wacs[m], table[n].value[0], A_NORMAL); - } + SetChar(_nc_wacs[m], + table[n].value[(active && (wide == 1)) ? 1 : 0], + A_NORMAL); - T(("#%d, SetChar(%c, %#04x) = %s", - n, m, + T(("#%d, wide:%d SetChar(%c, %#04x) = %s", + n, wide, m, table[n].value[active], _tracecchar_t(&_nc_wacs[m]))); }