diff options
author | nyan <nyan@FreeBSD.org> | 2002-02-10 10:15:41 +0000 |
---|---|---|
committer | nyan <nyan@FreeBSD.org> | 2002-02-10 10:15:41 +0000 |
commit | 41d18bbb0a9b27601845cd2413bc7a2682828e40 (patch) | |
tree | 21d03267b2bf4166aaaf85b31020d35df6c01fe3 /sys/pc98 | |
parent | bf52fb4e7a75e1730a5ba056af240fd1d59e1ad9 (diff) | |
download | FreeBSD-src-41d18bbb0a9b27601845cd2413bc7a2682828e40.zip FreeBSD-src-41d18bbb0a9b27601845cd2413bc7a2682828e40.tar.gz |
- Refine the iskanji1 function.
- Print continuous ascii characters at a time.
Submitted by: chi@bd.mbn.or.jp (Chiharu Shibata)
Diffstat (limited to 'sys/pc98')
-rw-r--r-- | sys/pc98/cbus/scterm-sck.c | 113 | ||||
-rw-r--r-- | sys/pc98/pc98/scterm-sck.c | 113 |
2 files changed, 122 insertions, 104 deletions
diff --git a/sys/pc98/cbus/scterm-sck.c b/sys/pc98/cbus/scterm-sck.c index e49a4a6..7905f42 100644 --- a/sys/pc98/cbus/scterm-sck.c +++ b/sys/pc98/cbus/scterm-sck.c @@ -135,60 +135,54 @@ static int mask2attr(term_stat *tcp); __inline static u_char iskanji1(u_char mode, u_char c) { - if ((mode == KTYPE_7JIS) && (c >= 0x21) && (c <= 0x7e)) { - /* JIS */ - default_kanji = UJIS; - return KTYPE_7JIS; - } - - if ((mode == KTYPE_JKANA) && (c >= 0x21) && (c <= 0x5f)) { - /* JIS HANKAKU */ - default_kanji = UJIS; - return KTYPE_JKANA; - } - -#if 1 - if ((c >= 0xa1) && (c <= 0xdf) && (default_kanji == UJIS)) { - /* UJIS */ - return KTYPE_UJIS; - } -#endif - - if ((c >= 0x81) && (c <= 0x9f) && (c != 0x8e)) { - /* SJIS */ - default_kanji = SJIS; - return KTYPE_SJIS; - } + if (c > 0x80) { + if ((c >= 0xa1) && (c <= 0xdf)) { + if (default_kanji == UJIS) { + /* UJIS */ + return KTYPE_UJIS; + } + if (default_kanji == SJIS) { + /* SJIS HANKAKU */ + return KTYPE_KANA; + } + } - if ((c >= 0xa1) && (c <= 0xdf) && (default_kanji == SJIS)) { - /* SJIS HANKAKU */ - return KTYPE_KANA; - } + if (c <= 0x9f) { + if (c == 0x8e) { + /* SJIS or UJIS HANKAKU */ + return KTYPE_SUKANA; + } -#if 0 - if ((c >= 0xa1) && (c <= 0xdf) && (default_kanji == UJIS)) { - /* UJIS */ - return KTYPE_UJIS; - } -#endif + /* SJIS */ + default_kanji = SJIS; + return KTYPE_SJIS; + } - if ((c >= 0xf0) && (c <= 0xfe)) { - /* UJIS */ - default_kanji = UJIS; - return KTYPE_UJIS; - } + if ((c >= 0xe0) && (c <= 0xef)) { + /* SJIS or UJIS */ + return KTYPE_SUJIS; + } - if ((c >= 0xe0) && (c <= 0xef)) { - /* SJIS or UJIS */ - return KTYPE_SUJIS; - } + if ((c >= 0xf0) && (c <= 0xfe)) { + /* UJIS */ + default_kanji = UJIS; + return KTYPE_UJIS; + } + } else { + if ((mode == KTYPE_7JIS) && (c >= 0x21) && (c <= 0x7e)) { + /* JIS */ + default_kanji = UJIS; + return KTYPE_7JIS; + } - if (c == 0x8e) { - /* SJIS or UJIS HANKAKU */ - return KTYPE_SUKANA; - } + if ((mode == KTYPE_JKANA) && (c >= 0x21) && (c <= 0x5f)) { + /* JIS HANKAKU */ + default_kanji = UJIS; + return KTYPE_JKANA; + } + } - return KTYPE_ASCII; + return KTYPE_ASCII; } __inline static u_char @@ -933,10 +927,9 @@ outloop: u_char *map; int attr; int i; + int cnt; #ifdef KANJI u_char c; -#else - int cnt; #endif p = sc_vtb_pointer(&scp->vtb, scp->cursor_pos); @@ -951,8 +944,23 @@ outloop: /* not Ascii & not HANKAKU */ tcp->kanji_1st_char = c; goto kanji_end; - } else { - tcp->kanji_1st_char = 0; + } else if (tcp->kanji_type == KTYPE_ASCII) { + cnt = imin(len, scp->xsize - scp->xpos); + i = cnt; + do { + p = sc_vtb_putchar(&scp->vtb, p, map[c], attr); + c = *++ptr; + --i; + } while (i > 0 && PRINTABLE(c) && + iskanji1(tcp->kanji_type, c) == KTYPE_ASCII); + + len -= cnt - i; + mark_for_update(scp, scp->cursor_pos); + scp->cursor_pos += cnt - i; + mark_for_update(scp, scp->cursor_pos - 1); + scp->xpos += cnt - i; + KTYPE_MASK_CTRL(tcp->kanji_type); + goto ascii_end; } } else { if ((tcp->kanji_type = @@ -990,6 +998,7 @@ outloop: kanji_end: ++ptr; --len; +ascii_end: #else /* !KANJI */ cnt = imin(len, scp->xsize - scp->xpos); i = cnt; diff --git a/sys/pc98/pc98/scterm-sck.c b/sys/pc98/pc98/scterm-sck.c index e49a4a6..7905f42 100644 --- a/sys/pc98/pc98/scterm-sck.c +++ b/sys/pc98/pc98/scterm-sck.c @@ -135,60 +135,54 @@ static int mask2attr(term_stat *tcp); __inline static u_char iskanji1(u_char mode, u_char c) { - if ((mode == KTYPE_7JIS) && (c >= 0x21) && (c <= 0x7e)) { - /* JIS */ - default_kanji = UJIS; - return KTYPE_7JIS; - } - - if ((mode == KTYPE_JKANA) && (c >= 0x21) && (c <= 0x5f)) { - /* JIS HANKAKU */ - default_kanji = UJIS; - return KTYPE_JKANA; - } - -#if 1 - if ((c >= 0xa1) && (c <= 0xdf) && (default_kanji == UJIS)) { - /* UJIS */ - return KTYPE_UJIS; - } -#endif - - if ((c >= 0x81) && (c <= 0x9f) && (c != 0x8e)) { - /* SJIS */ - default_kanji = SJIS; - return KTYPE_SJIS; - } + if (c > 0x80) { + if ((c >= 0xa1) && (c <= 0xdf)) { + if (default_kanji == UJIS) { + /* UJIS */ + return KTYPE_UJIS; + } + if (default_kanji == SJIS) { + /* SJIS HANKAKU */ + return KTYPE_KANA; + } + } - if ((c >= 0xa1) && (c <= 0xdf) && (default_kanji == SJIS)) { - /* SJIS HANKAKU */ - return KTYPE_KANA; - } + if (c <= 0x9f) { + if (c == 0x8e) { + /* SJIS or UJIS HANKAKU */ + return KTYPE_SUKANA; + } -#if 0 - if ((c >= 0xa1) && (c <= 0xdf) && (default_kanji == UJIS)) { - /* UJIS */ - return KTYPE_UJIS; - } -#endif + /* SJIS */ + default_kanji = SJIS; + return KTYPE_SJIS; + } - if ((c >= 0xf0) && (c <= 0xfe)) { - /* UJIS */ - default_kanji = UJIS; - return KTYPE_UJIS; - } + if ((c >= 0xe0) && (c <= 0xef)) { + /* SJIS or UJIS */ + return KTYPE_SUJIS; + } - if ((c >= 0xe0) && (c <= 0xef)) { - /* SJIS or UJIS */ - return KTYPE_SUJIS; - } + if ((c >= 0xf0) && (c <= 0xfe)) { + /* UJIS */ + default_kanji = UJIS; + return KTYPE_UJIS; + } + } else { + if ((mode == KTYPE_7JIS) && (c >= 0x21) && (c <= 0x7e)) { + /* JIS */ + default_kanji = UJIS; + return KTYPE_7JIS; + } - if (c == 0x8e) { - /* SJIS or UJIS HANKAKU */ - return KTYPE_SUKANA; - } + if ((mode == KTYPE_JKANA) && (c >= 0x21) && (c <= 0x5f)) { + /* JIS HANKAKU */ + default_kanji = UJIS; + return KTYPE_JKANA; + } + } - return KTYPE_ASCII; + return KTYPE_ASCII; } __inline static u_char @@ -933,10 +927,9 @@ outloop: u_char *map; int attr; int i; + int cnt; #ifdef KANJI u_char c; -#else - int cnt; #endif p = sc_vtb_pointer(&scp->vtb, scp->cursor_pos); @@ -951,8 +944,23 @@ outloop: /* not Ascii & not HANKAKU */ tcp->kanji_1st_char = c; goto kanji_end; - } else { - tcp->kanji_1st_char = 0; + } else if (tcp->kanji_type == KTYPE_ASCII) { + cnt = imin(len, scp->xsize - scp->xpos); + i = cnt; + do { + p = sc_vtb_putchar(&scp->vtb, p, map[c], attr); + c = *++ptr; + --i; + } while (i > 0 && PRINTABLE(c) && + iskanji1(tcp->kanji_type, c) == KTYPE_ASCII); + + len -= cnt - i; + mark_for_update(scp, scp->cursor_pos); + scp->cursor_pos += cnt - i; + mark_for_update(scp, scp->cursor_pos - 1); + scp->xpos += cnt - i; + KTYPE_MASK_CTRL(tcp->kanji_type); + goto ascii_end; } } else { if ((tcp->kanji_type = @@ -990,6 +998,7 @@ outloop: kanji_end: ++ptr; --len; +ascii_end: #else /* !KANJI */ cnt = imin(len, scp->xsize - scp->xpos); i = cnt; |