CharacterEncoderImplementations__JIS0208_to_SJIS.st
author Claus Gittinger <cg@exept.de>
Thu, 18 Jan 2018 19:22:23 +0100
changeset 22448 7f0bc44b4082
parent 21623 0fd2de531f9a
child 22482 763385e4fdeb
permissions -rw-r--r--
#BUGFIX by cg class: Filename changed: #appendingFileDo: #readingFileDo: #writingFileDo: race condition
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
18243
ef19ec73cad1 class: CharacterEncoderImplementations::JIS0208_to_SJIS
Claus Gittinger <cg@exept.de>
parents: 18241
diff changeset
     1
"{ Encoding: utf8 }"
ef19ec73cad1 class: CharacterEncoderImplementations::JIS0208_to_SJIS
Claus Gittinger <cg@exept.de>
parents: 18241
diff changeset
     2
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
"
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
 COPYRIGHT (c) 2004 by eXept Software AG
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
     5
	      All Rights Reserved
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
 This software is furnished under a license and may be used
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
 only in accordance with the terms of that license and with the
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
 inclusion of the above copyright notice.   This software may not
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
 be provided or otherwise made available to, or used by, any
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
 other person.  No title to or ownership of the software is
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
 hereby transferred.
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
"
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
"{ Package: 'stx:libbasic' }"
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
"{ NameSpace: CharacterEncoderImplementations }"
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
TwoByteEncoder subclass:#JIS0208_to_SJIS
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
	instanceVariableNames:''
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
	classVariableNames:''
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
	poolDictionaries:''
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
	category:'Collections-Text-Encodings'
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
!
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
!JIS0208_to_SJIS class methodsFor:'documentation'!
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
copyright
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
"
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
 COPYRIGHT (c) 2004 by eXept Software AG
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
    30
	      All Rights Reserved
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
 This software is furnished under a license and may be used
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
 only in accordance with the terms of that license and with the
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
 inclusion of the above copyright notice.   This software may not
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
 be provided or otherwise made available to, or used by, any
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
 other person.  No title to or ownership of the software is
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
 hereby transferred.
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
"
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
! !
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
!JIS0208_to_SJIS class methodsFor:'mapping'!
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
mapFileURL1_relativePathName
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
    ^ 'OBSOLETE/EASTASIA/JIS/SHIFTJIS.TXT'
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    45
! !
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    46
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
!JIS0208_to_SJIS class methodsFor:'queries'!
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    48
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    49
nameOfDecodedCode
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    50
    "I encode sjis into jis"
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    52
    ^ #'jis0208'
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    53
! !
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    54
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    55
!JIS0208_to_SJIS methodsFor:'encoding & decoding'!
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
decodeString:aString
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
    "return a new JIS-Encoded-String containing the characters from aString,
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
     which are interpreted as Shift-JIS encoded singleByte chars.
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
     Shift-JIS is a leadyByte code, with a variable-length encoding."
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    61
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
    |newString char1 char2
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    63
     sz         "{ Class: SmallInteger }"
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    64
     dstIdx     "{ Class: SmallInteger }"
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
     srcIdx     "{ Class: SmallInteger }"
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
     b1         "{ Class: SmallInteger }"
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
     b2         "{ Class: SmallInteger }"
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
     val        "{ Class: SmallInteger }"
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
     any16bit romans|
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
    sz := aString size.
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    72
    sz == 0 ifTrue:[^ aString].
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    73
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
    newString := TwoByteString new:sz.
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
    any16bit := false.
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    76
    dstIdx := 1.
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
    srcIdx := 1.
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
    romans := CharacterEncoderImplementations::JIS0208 romanTable.
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
%{
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
    if (__isStringLike(aString)
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
     && (__Class(newString) == @global(TwoByteString))) {
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
    84
	INT _dstIdx = 0, _srcIdx = 0;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
    85
	int _sz = __intVal(sz);
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
    86
	unsigned char *_cp = __stringVal(aString);
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
    87
	unsigned char _c1, _c2;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
    88
	unsigned short *_jcp = (unsigned short *)__stringVal(newString);
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
    90
	while (_srcIdx < _sz) {
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
    91
	    int _val;
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
    93
	    _c1 = _cp[_srcIdx];
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
    94
	    _srcIdx++;
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    95
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
    96
	    if ((_srcIdx < _sz)
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
    97
	     && (((_c1 >= 129) && (_c1 <= 159))
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
    98
		 || ((_c1 >= 224) && (_c1 <= 239)))) {
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
    99
		_c2 = _cp[_srcIdx];
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   100
		_srcIdx++;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   101
		if ((_c2 >= 64) && (_c2 <= 252)) {
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   102
		    int _adjust, _rowOffs, _cellOffs;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   103
		    int _b1, _b2;
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   104
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   105
		    _adjust = (_c2 < 159) ? 1 : 0;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   106
		    _rowOffs = (_c1 < 160) ? 112 : 176;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   107
		    if (_adjust) {
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   108
			_cellOffs = 31 + ((_c2 > 127) ? 1 : 0);
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   109
		    } else {
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   110
			_cellOffs = 126;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   111
		    }
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   112
		    _b1 = ((_c1 - _rowOffs) << 1) - _adjust;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   113
		    _b2 = (_c2 - _cellOffs);
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   114
		    _val = (_b1<<8) + _b2;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   115
		    if (_val <= 0) {
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   116
			/* decoder error - let smalltalk handle that */
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   117
			_srcIdx -= 2;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   118
			goto getOutOfHere;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   119
		    }
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   120
		    if (_val > 0xFF) any16bit = true;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   121
		    _jcp[_dstIdx] = _val;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   122
		} else {
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   123
		    /* mhmh - append untranslated */
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   124
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   125
		    _jcp[_dstIdx] = _c1;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   126
		    _dstIdx++;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   127
		    _jcp[_dstIdx] = _c2;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   128
		}
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   129
	    } else {
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   130
		if ((_c1 >= 0xA1 /* 161 */) && (_c1 <= 0xDF /* 223 */)) {
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   131
		    /* HALFWIDTH KATAKANA
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   132
		     * map half-width katakana to 8E:xx
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   133
		     */
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   134
		    _val = _c1 - 128;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   135
		    _val = _val + 0x8E00;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   136
		    any16bit = true;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   137
		    _jcp[_dstIdx] = _val;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   138
		} else {
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   139
		    /* roman characters are translated as per romanTable */
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   140
		    _jcp[_dstIdx] = _c1;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   141
		    if ((romans != nil)
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   142
		     && (__isArrayLike(romans))
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   143
		     && ((_c1 - 0x20) < __arraySize(romans))) {
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   144
			any16bit = true;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   145
			_jcp[_dstIdx] = __intVal(__ArrayInstPtr(romans)->a_element[(_c1 - 0x20)]);
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   146
		    }
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   147
		}
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   148
	    }
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   149
	    _dstIdx++;
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   150
	}
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   151
    getOutOfHere: ;
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   152
	dstIdx = __mkSmallInteger(_dstIdx+1);
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   153
	srcIdx = __mkSmallInteger(_srcIdx+1);
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   154
    }
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   155
%}.
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   156
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   157
    [srcIdx <= sz] whileTrue:[
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   158
	"/
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   159
	"/ scan for next character in 129..159 or 224..239
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   160
	"/
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   161
	char1 := aString at:srcIdx.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   162
	srcIdx := srcIdx + 1.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   163
	b1 := char1 codePoint.
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   164
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   165
	((srcIdx <= sz)
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   166
	and:[(b1 >= 16r81"129" and:[b1 <= 16r9F"159"])                 "/ SJIS1 81 .. 9F
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   167
	     or:[b1 >= 16rE0"224" and:[b1 <= 16rEF"239"]]]) ifTrue:[   "/       E0 .. EF
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   168
	    char2 := aString at:srcIdx.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   169
	    srcIdx := srcIdx + 1.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   170
	    b2 := char2 codePoint.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   171
	    (b2 >= 16r40"64" and:[b2 <= 16rFC"252"]) ifTrue:[          "/ SJIS2 40 .. FC
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   172
		|adjust rowOffs cellOffs|
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   173
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   174
		adjust := (b2 < 16r9F"159") ifTrue:[1] ifFalse:[0].
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   175
		rowOffs := b1 < 16rA0"160" ifTrue:[112] ifFalse:[176].
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   176
		adjust == 1 ifTrue:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   177
		    cellOffs := 31 + (b2 > 127 ifTrue:[1] ifFalse:[0]).
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   178
		] ifFalse:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   179
		    cellOffs := 126.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   180
		].
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   181
		b1 := ((b1 - rowOffs) bitShift:1) - adjust.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   182
		b2 := (b2 - cellOffs).
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   183
		val := (b1 bitShift:8) + b2.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   184
		val <= 0 ifTrue:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   185
		    DecodingError
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   186
			    raiseWith:aString
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   187
			    errorString:'SJIS decoding failed (not SJIS encoded ?)'.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   188
		    newString at:dstIdx put:char1.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   189
		    dstIdx := dstIdx + 1.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   190
		    newString at:dstIdx put:char2.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   191
		] ifFalse:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   192
		    val > 16rFF ifTrue:[any16bit := true].
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   193
		    newString at:dstIdx put:(Character value:val).
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   194
		]
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   195
	    ] ifFalse:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   196
		"/ mhmh - append untranslated
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   197
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   198
		newString at:dstIdx put:char1.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   199
		dstIdx := dstIdx + 1.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   200
		newString at:dstIdx put:char2.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   201
	    ]
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   202
	] ifFalse:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   203
	    (b1 >= 16rA1 "161" and:[b1 <= 16rDF "223"]) ifTrue:[     "/ HALFWIDTH KATAKANA
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   204
		"/ map half-width katakan to 8E:xx
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   205
		val := b1 - 128.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   206
		val := val + (16r8E"142" bitShift:8).
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   207
		any16bit := true.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   208
		newString at:dstIdx put:(Character value:val).
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   209
	    ] ifFalse:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   210
		"/ roman characters translated as per romanTable
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   211
		newString at:dstIdx put:char1
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   212
		romans isArray ifTrue:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   213
		    char1 codePoint < romans size ifTrue:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   214
			any16bit := true.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   215
			newString at:dstIdx put:(Character value:(romans at:char1 codePoint-32+1)).
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   216
		    ]
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   217
		]
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   218
	    ]
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   219
	].
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   220
	dstIdx := dstIdx + 1.
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   221
    ].
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   222
    any16bit ifFalse:[
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   223
	newString := String fromString:newString
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   224
    ].
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   225
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   226
    (dstIdx-1) ~~ sz ifTrue:[
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   227
	newString := newString copyTo:dstIdx - 1.
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   228
    ].
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   229
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   230
    ^ newString
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   231
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   232
    "simple:
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   233
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   234
     CharacterEncoderImplementations::JIS0208_to_SJIS decodeString:'hello'
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   235
     (CharacterEncoder encoderFor:#sjis) decodeString:'hello'
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   236
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   237
     CharacterEncoderImplementations::JIS0208_to_SJIS decodeString:('../../doc/online/japanese/TOP.html' asFilename contents asString)
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   238
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   239
     '../../doc/online/japanese/TOP.html' asFilename contents asString
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   240
		decodeFrom:#sjis
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   241
    "
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   242
!
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   243
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   244
encodeString:aJISString
18243
ef19ec73cad1 class: CharacterEncoderImplementations::JIS0208_to_SJIS
Claus Gittinger <cg@exept.de>
parents: 18241
diff changeset
   245
    "return a new string with aJISString's characters as SJIS encoded 8bit string.
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   246
     The resulting string is only useful to be stored on some external file,
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   247
     not for being displayed in an ST/X view."
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   248
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   249
    |sz "{ Class: SmallInteger }"
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   250
     rval "{ Class: SmallInteger }"
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   251
     val  "{ Class: SmallInteger }"
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   252
     romans c out isSJIS|
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   253
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   254
    romans := JIS0208 romanTable.
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   255
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   256
    sz := aJISString size.
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   257
    sz == 0 ifTrue:[^ ''].
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   258
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   259
    out := WriteStream on:(String new:(sz * 2)).
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   260
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   261
    1 to:sz do:[:srcIndex |
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   262
	val := (c := aJISString at:srcIndex) codePoint.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   263
	(val <= 128) ifTrue:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   264
	    "/ a control or ascii character
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   265
	    out nextPut:c.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   266
	] ifFalse:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   267
	    (val == 16rFFFF "invalid-char") ifTrue:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   268
		out nextPut:Character space.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   269
	    ] ifFalse:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   270
		(val > 150 and:[val < 224]) ifTrue:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   271
		    "/ ascii subset
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   272
		    out nextPut:c.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   273
		] ifFalse:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   274
		    "/ should not happen ...
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   275
		    val <= 255 ifTrue:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   276
			out nextPut:c.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   277
		    ] ifFalse:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   278
			isSJIS := true.
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   279
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   280
			"/ check for HALFWIDTH KATAKANA
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   281
			"/ 8E:xx
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   282
			"/ NO: halfwidth katakana no longer generated
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   283
			"/     remains there as full-width katakana
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   284
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   285
"/                        (val bitAnd:16rFF00) == 16r8E00 ifTrue:[
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   286
"/                            |b|
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   287
"/
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   288
"/                            b := (val bitAnd:16rFF) + 128.
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   289
"/                            (b >= 16rA1 "161" and:[b <= 16rDF "223"]) ifTrue:[
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   290
"/                                out nextPut:(Character value:b).
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   291
"/                                isSJIS := false.
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   292
"/                            ].
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   293
"/                        ].
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   294
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   295
			isSJIS ifTrue:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   296
			    "/ check for a roman character
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   297
			    (val between:"romanTable min" 16r2121 and:"romanTable max" 16r2573) ifTrue:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   298
				rval := romans indexOf:val.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   299
				rval ~~ 0 ifTrue:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   300
				    rval := rval - 1 + 32.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   301
				    rval <= 16r7F ifTrue:[ "/ do not translate halfwidth katakana
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   302
					out nextPut:(Character value:rval).
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   303
					isSJIS := false.
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   304
				    ]
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   305
				].
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   306
			    ].
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   307
			].
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   308
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   309
			isSJIS ifTrue:[
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   310
			    |b1 b2 rowOffset cellOffset|
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   311
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   312
			    b1 := (val bitShift:-8).
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   313
			    b2 := (val bitAnd:16rFF).
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   314
			    rowOffset := (b1 < 95) ifTrue:[112] ifFalse:[176].
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   315
			    cellOffset := b1 odd ifTrue:[(b2 > 95) ifTrue:[32] ifFalse:[31]]
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   316
						 ifFalse:[126].
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   317
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   318
			    out nextPut:(Character value:(((b1 + 1) bitShift:-1) + rowOffset)).
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   319
			    out nextPut:(Character value:b2 + cellOffset).
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   320
			]
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   321
		    ]
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   322
		]
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   323
	    ]
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   324
	].
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   325
    ].
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   326
    ^ out contents
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   327
! !
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   328
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   329
!JIS0208_to_SJIS methodsFor:'private'!
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   330
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   331
newString:size
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   332
    ^ JISEncodedString new:size
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   333
! !
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   334
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   335
!JIS0208_to_SJIS methodsFor:'queries'!
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   336
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   337
nameOfEncoding
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   338
    ^ #'sjis'
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   339
! !
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   340
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   341
!JIS0208_to_SJIS class methodsFor:'documentation'!
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   342
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   343
version
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   344
    ^ '$Header$'
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   345
!
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   346
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   347
version_CVS
21623
0fd2de531f9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 18243
diff changeset
   348
    ^ '$Header$'
18241
c594840ddf15 renamed to make filename compliant to class name
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   349
! !