Esempio n. 1
0
static size_t mac_japanese_char_pull(ucs2_t* out, const uint8_t* in, size_t* size)
{
  uint16_t c = in[0];

  if (c <= 0x7f) {
    *size = 1;
    *out = (c == 0x5c ? 0xa5 : c);
    return 1;
  } else if ((c >= 0x81 && c <= 0x9f) || (c >= 0xe0 && c <= 0xfc)) {
    if (*size >= 2) {
      uint8_t c2 = in[1];

      if ((c2 >= 0x40 && c2 <= 0x7e) || (c2 >= 0x80 && c2 <= 0xfc)) {
	*size = 2;
	if (c >= 0xf0) { /* user defined */
	  *out = 0xe000 + (c - 0xf0) * 188 + c2 - (c2 < 0x80 ? 0x40 : 0x41);
	  return 1;
	}
	c = (c << 8) + c2;
      } else {
	errno = EILSEQ;
	return (size_t)-1;
      }
    } else {
      errno = EINVAL;
      return (size_t)-1;
    }
  } else {
    *size = 1;
  }
  return cjk_char_pull(cjk_lookup(c, mac_japanese_2uni_index,
				  mac_japanese_2uni_charset),
		       out, mac_japanese_compose);
}
static size_t mac_chinese_simp_char_pull(ucs2_t* out, const u_int8_t* in, size_t* size)
{
  u_int16_t c = in[0];

  if (c <= 0x7f) {
    *size = 1;
    *out = c;
    return 1;
  } else if (c >= 0xa1 && c <= 0xfc) {
    if (*size >= 2) {
      u_int8_t c2 = in[1];

      if (c2 >= 0xa1 && c2 <= 0xfe) {
	*size = 2;
	c = (c << 8) + c2;
      } else {
	errno = EILSEQ;
	return (size_t)-1;
      }
    } else {
      errno = EINVAL;
      return (size_t)-1;
    }
  } else {
    *size = 1;
  }
  return cjk_char_pull(cjk_lookup(c, mac_chinese_simp_2uni_index,
				  mac_chinese_simp_2uni_charset),
		       out, mac_chinese_simp_compose);
}
Esempio n. 3
0
static size_t mac_japanese_char_push(uint8_t* out, const ucs2_t* in, size_t* size)
{
  ucs2_t wc = in[0];

  if (wc <= 0x7f) {
    *size = 1;
    out[0] = (uint8_t)(wc == 0x5c ? 0x80 : wc);
    return 1;
  } else if ((wc & 0xf000) == 0xe000) { /* user defined */
    *size = 1;
    if (wc > 0xe98b) return 0;
    wc -= 0xe000;
    out[0] = (uint8_t)(wc / 188 + 0xf0);
    out[1] = (uint8_t)(wc % 188 + 0x40);
    if (out[1] >= 0x7f) ++out[1];
    return 2;
  } else if ((wc & ~7) == 0xf860) {
    wc = cjk_compose_seq(in, size, mac_japanese_compose,
			 sizeof(mac_japanese_compose) / sizeof(uint32_t));
    if (!wc) return (size_t)-1;
  } else if (*size >= 2 && ((in[1] & ~15) == 0xf870 || in[1] == 0x20dd)) {
    ucs2_t comp = cjk_compose(wc, in[1], mac_japanese_compose,
			      sizeof(mac_japanese_compose) / sizeof(uint32_t));
    if (comp) {
      wc = comp;
      *size = 2;
    } else {
      *size = 1;
    }
  } else {
    *size = 1;
  }
  return cjk_char_push(cjk_lookup(wc, mac_japanese_uni2_index,
				  mac_japanese_uni2_charset), out);
}
static size_t mac_chinese_simp_char_push(u_int8_t* out, const ucs2_t* in, size_t* size)
{
  ucs2_t wc = in[0];

  if (wc <= 0x7f) {
    *size = 1;
    out[0] = (u_int8_t)wc;
    return 1;
  } else if ((wc & 0xf000) == 0xe000) {
    *size = 1;
    return 0;
  } else if (*size >= 2 && (in[1] & ~15) == 0xf870) {
    ucs2_t comp = cjk_compose(wc, in[1], mac_chinese_simp_compose,
			      sizeof(mac_chinese_simp_compose) / sizeof(u_int32_t));
    if (comp) {
      wc = comp;
      *size = 2;
    } else {
      *size = 1;
    }
  } else {
    *size = 1;
  }
  return cjk_char_push(cjk_lookup(wc, mac_chinese_simp_uni2_index,
				  mac_chinese_simp_uni2_charset), out);
}