#include "fm.h"
#include "Symbols/alt.sym"
#include "Symbols/graph.sym"
#ifdef USE_M17N
#include "Symbols/eucjp.sym"
#include "Symbols/euckr.sym"
#include "Symbols/euccn.sym"
#include "Symbols/euctw.sym"
#include "Symbols/big5.sym"
#ifdef USE_UNICODE
#include "Symbols/utf8.sym"
#endif
#include "Symbols/cp850.sym"
typedef struct {
wc_ces ces;
char width;
char **item;
char encode;
} symbol_set;
typedef struct {
wc_ces charset;
symbol_set *symbol;
} charset_symbol_set;
/* *INDENT-OFF* */
static symbol_set alt_symbol_set = { WC_CES_US_ASCII, 1, alt_symbol, 1 };
static symbol_set alt2_symbol_set = { WC_CES_US_ASCII, 2, alt2_symbol, 1 };
static symbol_set eucjp_symbol_set = { WC_CES_EUC_JP, 2, eucjp_symbol, 0 };
static symbol_set euckr_symbol_set = { WC_CES_EUC_KR, 2, euckr_symbol, 0 };
static symbol_set euccn_symbol_set = { WC_CES_EUC_CN, 2, euccn_symbol, 0 };
static symbol_set euctw_symbol_set = { WC_CES_EUC_TW, 2, euctw_symbol, 0 };
static symbol_set big5_symbol_set = { WC_CES_BIG5, 2, big5_symbol, 0 };
#ifdef USE_UNICODE
static symbol_set utf8_symbol_set = { WC_CES_UTF_8, 1, utf8_symbol, 0 };
#endif
static symbol_set cp850_symbol_set = { WC_CES_CP850, 1, cp850_symbol, 0 };
static charset_symbol_set charset_symbol_list[] = {
{ WC_CES_EUC_JP, &eucjp_symbol_set },
{ WC_CES_SHIFT_JIS, &eucjp_symbol_set },
{ WC_CES_ISO_2022_JP, &eucjp_symbol_set },
{ WC_CES_ISO_2022_JP_2, &eucjp_symbol_set },
{ WC_CES_ISO_2022_JP_3, &eucjp_symbol_set },
{ WC_CES_EUC_KR, &euckr_symbol_set },
{ WC_CES_ISO_2022_KR, &euckr_symbol_set },
{ WC_CES_JOHAB, &euckr_symbol_set },
{ WC_CES_UHC, &euckr_symbol_set },
{ WC_CES_EUC_CN, &euccn_symbol_set },
{ WC_CES_GBK, &euccn_symbol_set },
{ WC_CES_GB18030, &euccn_symbol_set },
{ WC_CES_HZ_GB_2312, &euccn_symbol_set },
{ WC_CES_ISO_2022_CN, &euccn_symbol_set },
{ WC_CES_EUC_TW, &euctw_symbol_set },
{ WC_CES_BIG5, &big5_symbol_set },
{ WC_CES_HKSCS, &big5_symbol_set },
#ifdef USE_UNICODE
{ WC_CES_UTF_8, &utf8_symbol_set },
#endif
{ WC_CES_CP850, &cp850_symbol_set },
{ 0, NULL },
};
/* *INDENT-ON* */
static wc_ces save_charset = 0;
static symbol_set *save_symbol = NULL;
static void
encode_symbol(symbol_set * s)
{
int i;
for (i = 0; s->item[i]; i++) {
if (*(s->item[i]))
s->item[i] = wc_conv(s->item[i], s->ces, InnerCharset)->ptr;
}
s->encode = 1;
}
char **
get_symbol(wc_ces charset, int *width)
{
charset_symbol_set *p;
symbol_set *s = NULL;
if (UseGraphicChar != GRAPHIC_CHAR_ASCII) {
if (charset == save_charset && save_symbol != NULL &&
*width == save_symbol->width)
return save_symbol->item;
save_charset = charset;
for (p = charset_symbol_list; p->charset; p++) {
if (charset == p->charset &&
(*width == 0 || *width == p->symbol->width)) {
s = p->symbol;
break;
}
}
if (s == NULL)
s = (*width == 2) ? &alt2_symbol_set : &alt_symbol_set;
if (s != save_symbol) {
if (!s->encode)
encode_symbol(s);
save_symbol = s;
}
} else {
if (save_symbol != NULL && *width == save_symbol->width)
return save_symbol->item;
s = (*width == 2) ? &alt2_symbol_set : &alt_symbol_set;
save_symbol = s;
}
*width = s->width;
return s->item;
}
char **
set_symbol(int width)
{
static char **symbol_buf = NULL;
static int save_width = -1;
symbol_set *s = &alt_symbol_set;
int i;
Str tmp;
if (width == save_width)
return symbol_buf;
if (symbol_buf == NULL) {
for (i = 0; s->item[i]; i++) ;
symbol_buf = New_N(char *, i);
}
for (i = 0; s->item[i]; i++) {
tmp = Strnew_size(4);
if (width == 2)
wtf_push(tmp, WC_CCS_SPECIAL_W, (wc_uint32) (SYMBOL_BASE + i));
else
wtf_push(tmp, WC_CCS_SPECIAL, (wc_uint32) (SYMBOL_BASE + i));
symbol_buf[i] = tmp->ptr;
}
save_width = width;
return symbol_buf;
}
#else
char **
get_symbol(void)
{
return alt_symbol;
}
#endif
void
push_symbol(Str str, char symbol, int width, int n)
{
char buf[2], *p;
int i;
#ifdef USE_M17N
if (width == 2)
p = alt2_symbol[(int)symbol];
else
#endif
p = alt_symbol[(int)symbol];
for (i = 0; i < 2 && *p; i++, p++)
buf[i] = (*p == ' ') ? NBSP_CODE : *p;
Strcat(str, Sprintf("<_SYMBOL TYPE=%d>", symbol));
for (; n > 0; n--)
Strcat_charp_n(str, buf, i);
Strcat_charp(str, "</_SYMBOL>");
}