TwoByteString.st
author Claus Gittinger <cg@exept.de>
Tue, 26 Mar 2019 11:36:14 +0100
changeset 23974 2601c14688d8
parent 22375 0baa14a9b02e
child 23984 ac00c411f7f6
permissions -rw-r--r--
#TUNING by cg class: TwoByteString added: #from:to:put:
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1993 by Claus Gittinger
235
d8e62525bfdf *** empty log message ***
claus
parents: 97
diff changeset
     3
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
10223
761e2a050b69 twoByteString moved (req'd in VM)
Claus Gittinger <cg@exept.de>
parents: 8094
diff changeset
    12
"{ Package: 'stx:libbasic' }"
8094
d05f69bd0097 Use #codePoint instead of deprecated #asciiValue
Stefan Vogel <sv@exept.de>
parents: 5761
diff changeset
    13
17621
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
    14
"{ NameSpace: Smalltalk }"
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
    15
5761
9693ef8bbadd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4219
diff changeset
    16
CharacterArray variableWordSubclass:#TwoByteString
992
f456f8f7d421 JIS decode now in CharacterArray
Claus Gittinger <cg@exept.de>
parents: 631
diff changeset
    17
	instanceVariableNames:''
f456f8f7d421 JIS decode now in CharacterArray
Claus Gittinger <cg@exept.de>
parents: 631
diff changeset
    18
	classVariableNames:''
f456f8f7d421 JIS decode now in CharacterArray
Claus Gittinger <cg@exept.de>
parents: 631
diff changeset
    19
	poolDictionaries:''
f456f8f7d421 JIS decode now in CharacterArray
Claus Gittinger <cg@exept.de>
parents: 631
diff changeset
    20
	category:'Collections-Text'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    21
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    22
89
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    23
!TwoByteString class methodsFor:'documentation'!
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    24
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    25
copyright
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    26
"
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    27
 COPYRIGHT (c) 1993 by Claus Gittinger
235
d8e62525bfdf *** empty log message ***
claus
parents: 97
diff changeset
    28
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    29
89
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    30
 This software is furnished under a license and may be used
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    31
 only in accordance with the terms of that license and with the
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    32
 inclusion of the above copyright notice.   This software may not
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    33
 be provided or otherwise made available to, or used by, any
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    34
 other person.  No title to or ownership of the software is
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    35
 hereby transferred.
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    36
"
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    37
!
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    38
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    39
documentation
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    40
"
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    41
    TwoByteStrings are like strings, but storing 16bits per character.
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    42
    The integration of them into the system is not completed ....
1290
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 1253
diff changeset
    43
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 1253
diff changeset
    44
    [author:]
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 1253
diff changeset
    45
        Claus Gittinger
1309
24c98ca4a56d commentary
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
    46
24c98ca4a56d commentary
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
    47
    [see also:]
1382
93c125a594c3 xref in doku
Claus Gittinger <cg@exept.de>
parents: 1309
diff changeset
    48
        Text JISEncodedString
1309
24c98ca4a56d commentary
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
    49
        StringCollection
89
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    50
"
1214
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
    51
! !
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
    52
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
    53
!TwoByteString class methodsFor:'initialization'!
996
560a05298da9 I really store shorts ...
Claus Gittinger <cg@exept.de>
parents: 992
diff changeset
    54
560a05298da9 I really store shorts ...
Claus Gittinger <cg@exept.de>
parents: 992
diff changeset
    55
initialize
1253
7265cbaa8ec9 commentary
Claus Gittinger <cg@exept.de>
parents: 1239
diff changeset
    56
    "initialize the class - private"
7265cbaa8ec9 commentary
Claus Gittinger <cg@exept.de>
parents: 1239
diff changeset
    57
996
560a05298da9 I really store shorts ...
Claus Gittinger <cg@exept.de>
parents: 992
diff changeset
    58
    self flags:(Behavior flagWords)
560a05298da9 I really store shorts ...
Claus Gittinger <cg@exept.de>
parents: 992
diff changeset
    59
560a05298da9 I really store shorts ...
Claus Gittinger <cg@exept.de>
parents: 992
diff changeset
    60
    "
560a05298da9 I really store shorts ...
Claus Gittinger <cg@exept.de>
parents: 992
diff changeset
    61
     TwoByteString initialize
560a05298da9 I really store shorts ...
Claus Gittinger <cg@exept.de>
parents: 992
diff changeset
    62
    "
1214
Claus Gittinger <cg@exept.de>
parents: 1024
diff changeset
    63
1253
7265cbaa8ec9 commentary
Claus Gittinger <cg@exept.de>
parents: 1239
diff changeset
    64
    "Modified: 22.4.1996 / 16:14:14 / cg"
89
7be0b86ef80f *** empty log message ***
claus
parents: 73
diff changeset
    65
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    66
a27a279701f8 Initial revision
claus
parents:
diff changeset
    67
!TwoByteString class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    68
a27a279701f8 Initial revision
claus
parents:
diff changeset
    69
basicNew:anInteger
22375
0baa14a9b02e #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 22228
diff changeset
    70
    "return a new empty string with anInteger number of characters"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    71
1024
9a14acfb50ee 16bit coding
Claus Gittinger <cg@exept.de>
parents: 1017
diff changeset
    72
    ^ (super basicNew:anInteger) atAllPut:(Character space)
9a14acfb50ee 16bit coding
Claus Gittinger <cg@exept.de>
parents: 1017
diff changeset
    73
22375
0baa14a9b02e #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 22228
diff changeset
    74
    "Modified: / 26-02-1996 / 14:38:47 / cg"
0baa14a9b02e #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 22228
diff changeset
    75
    "Modified (comment): / 22-11-2017 / 21:32:49 / cg"
17621
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
    76
!
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
    77
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
    78
uninitializedNew:anInteger
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
    79
    "return a new empty string with anInteger characters"
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
    80
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
    81
    ^ super basicNew:anInteger
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
    82
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
    83
    "
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
    84
        self uninitializedNew:10
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
    85
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    86
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
    87
a27a279701f8 Initial revision
claus
parents:
diff changeset
    88
!TwoByteString methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    89
a27a279701f8 Initial revision
claus
parents:
diff changeset
    90
basicAt:index
a27a279701f8 Initial revision
claus
parents:
diff changeset
    91
    "return the character at position index, an Integer
73
a6640cc96199 *** empty log message ***
claus
parents: 63
diff changeset
    92
     - reimplemented here since we return 16-bit characters"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    93
1024
9a14acfb50ee 16bit coding
Claus Gittinger <cg@exept.de>
parents: 1017
diff changeset
    94
    |val|
63
1f0cdefb013f *** empty log message ***
claus
parents: 33
diff changeset
    95
1024
9a14acfb50ee 16bit coding
Claus Gittinger <cg@exept.de>
parents: 1017
diff changeset
    96
    val := super basicAt:index.
63
1f0cdefb013f *** empty log message ***
claus
parents: 33
diff changeset
    97
    ^ Character value:val
1024
9a14acfb50ee 16bit coding
Claus Gittinger <cg@exept.de>
parents: 1017
diff changeset
    98
9a14acfb50ee 16bit coding
Claus Gittinger <cg@exept.de>
parents: 1017
diff changeset
    99
    "Modified: 26.2.1996 / 17:02:16 / cg"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   100
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   101
a27a279701f8 Initial revision
claus
parents:
diff changeset
   102
basicAt:index put:aCharacter
1230
c349c4e9e594 commentary
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   103
    "store the argument, aCharacter at position index, an Integer.
c349c4e9e594 commentary
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   104
     Returns aCharacter (sigh).
73
a6640cc96199 *** empty log message ***
claus
parents: 63
diff changeset
   105
     - reimplemented here since we store 16-bit characters"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   106
8094
d05f69bd0097 Use #codePoint instead of deprecated #asciiValue
Stefan Vogel <sv@exept.de>
parents: 5761
diff changeset
   107
    super basicAt:index put:aCharacter codePoint.
63
1f0cdefb013f *** empty log message ***
claus
parents: 33
diff changeset
   108
    ^ aCharacter
608
cd5ac440fa95 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   109
1230
c349c4e9e594 commentary
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   110
    "Modified: 19.4.1996 / 11:16:22 / cg"
14123
a33fc6cc4332 added: #unsignedShortAt:
Stefan Vogel <sv@exept.de>
parents: 10223
diff changeset
   111
!
a33fc6cc4332 added: #unsignedShortAt:
Stefan Vogel <sv@exept.de>
parents: 10223
diff changeset
   112
a33fc6cc4332 added: #unsignedShortAt:
Stefan Vogel <sv@exept.de>
parents: 10223
diff changeset
   113
unsignedShortAt:index
a33fc6cc4332 added: #unsignedShortAt:
Stefan Vogel <sv@exept.de>
parents: 10223
diff changeset
   114
    "return the short at position index, an Integer"
a33fc6cc4332 added: #unsignedShortAt:
Stefan Vogel <sv@exept.de>
parents: 10223
diff changeset
   115
a33fc6cc4332 added: #unsignedShortAt:
Stefan Vogel <sv@exept.de>
parents: 10223
diff changeset
   116
    ^ super basicAt:index.
1014
da30760cfd3e dummy encoding support
Claus Gittinger <cg@exept.de>
parents: 996
diff changeset
   117
! !
da30760cfd3e dummy encoding support
Claus Gittinger <cg@exept.de>
parents: 996
diff changeset
   118
16750
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   119
!TwoByteString methodsFor:'filling and replacing'!
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   120
23974
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   121
from:start to:stop put:aCharacter
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   122
    "fill part of the receiver with aCharacter.
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   123
     - reimplemented here for speed"
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   124
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   125
%{  /* NOCONTEXT */
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   126
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   127
    REGISTER unsigned short *dstp;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   128
    REGISTER int count, charValue;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   129
    int len, index1, index2;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   130
    OBJ cls;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   131
    
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   132
    // fprintf(stderr, "fill16...\n");
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   133
    if (__isCharacter(aCharacter)
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   134
     && __bothSmallInteger(start, stop)) {
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   135
        len = __twoByteStringSize(self);
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   136
        index1 = __intVal(start);
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   137
        index2 = __intVal(stop);
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   138
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   139
        dstp = __twoByteStringVal(self) + index1 - 1;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   140
        if ((cls = __qClass(self)) != @global(Unicode16String)) {
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   141
            int nInst;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   142
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   143
            nInst = __OBJS2BYTES__(__intVal(__ClassInstPtr(cls)->c_ninstvars));
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   144
            dstp += nInst;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   145
            len -= nInst;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   146
        }
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   147
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   148
        charValue = __intVal(__characterVal(aCharacter));
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   149
        if (((unsigned)charValue <= 0xFFFF)
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   150
         && (index1 <= index2)
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   151
         && (index1 > 0)) {
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   152
            if (index2 <= len) {
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   153
                count = index2 - index1 + 1;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   154
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   155
#if (__POINTER_SIZE__ == 8)
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   156
                {
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   157
                    INT v4;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   158
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   159
                    v4 = (charValue << 16) | charValue;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   160
                    v4 = (v4 << 32) | v4;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   161
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   162
                    /* fill unaligned part */
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   163
                    while ((count > 0) && (((unsigned INT)dstp & 7) != 0)) {
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   164
                        *dstp++ = charValue;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   165
                        count--;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   166
                    }
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   167
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   168
                    /* fill aligned part */
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   169
                    while (count >= 4) {
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   170
                        ((unsigned INT *)dstp)[0] = v4;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   171
                        dstp += 4;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   172
                        count -= 4;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   173
                    }
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   174
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   175
                    /* fill rest */
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   176
                    while (count > 0) {
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   177
                        *dstp++ = charValue;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   178
                        count--;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   179
                    }
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   180
                    RETURN (self);
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   181
                }
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   182
#endif /* 64bit */
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   183
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   184
                while (count >= 8) {
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   185
                    dstp[0] = dstp[1] = dstp[2] = dstp[3] =
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   186
                    dstp[4] = dstp[5] = dstp[6] = dstp[7] = charValue;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   187
                    dstp += 8;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   188
                    count -= 8;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   189
                }
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   190
                while (count--) {
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   191
                    *dstp++ = charValue;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   192
                }
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   193
                RETURN (self);
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   194
            }
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   195
        }
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   196
    }
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   197
%}.
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   198
    "
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   199
     fall back in case of non-integer index or out-of-bound index/value;
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   200
     will eventually lead to an out-of-bound signal raise
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   201
    "
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   202
    ^ super from:start to:stop put:aCharacter
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   203
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   204
    "
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   205
     (Unicode16String new:10) from:1 to:10 put:$a
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   206
     (Unicode16String new:20) from:10 to:20 put:$b
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   207
     (Unicode16String new:20) from:1 to:10 put:$c
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   208
     (Unicode16String new:20) from:1 to:10 put:$c 
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   209
     (Unicode16String new:100) from:2 to:99 put:$c 
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   210
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   211
     (Unicode16String new:10) from:0 to:9 put:$a
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   212
     (Unicode16String new:10) from:1 to:11 put:$a
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   213
    "
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   214
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   215
    "Created: / 26-03-2019 / 11:20:14 / Claus Gittinger"
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   216
!
2601c14688d8 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22375
diff changeset
   217
16750
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   218
replaceFrom:start to:stop with:aString startingAt:repStart
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   219
    "replace the characters starting at index start, anInteger and ending
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   220
     at stop, anInteger with characters from aString starting at repStart.
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   221
     Return the receiver.
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   222
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   223
     - reimplemented here for speed"
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   224
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   225
%{  /* NOCONTEXT */
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   226
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   227
#ifndef NO_PRIM_STRING
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   228
    if (__bothSmallInteger(start, stop)) {
18576
724284508398 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 17621
diff changeset
   229
        int len;
724284508398 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 17621
diff changeset
   230
        int index1 = __intVal(start);
724284508398 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 17621
diff changeset
   231
        int index2 = __intVal(stop);
724284508398 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 17621
diff changeset
   232
        int count = index2 - index1 + 1;
16750
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   233
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   234
        if (count <= 0) {
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   235
             RETURN (self);
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   236
        }
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   237
        len = __twoByteStringSize(self);
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   238
        if ((index2 <= len) && (index1 > 0)) {
18576
724284508398 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 17621
diff changeset
   239
            int repIndex = __intVal(repStart);
16750
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   240
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   241
            if (__isStringLike(aString)) {
18576
724284508398 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 17621
diff changeset
   242
                int repLen = __stringSize(aString);
16750
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   243
                if ((repIndex > 0) && ((repIndex + count - 1) <= repLen)) {
18576
724284508398 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 17621
diff changeset
   244
                    REGISTER unsigned char *srcp = __stringVal(aString) + repIndex - 1;
724284508398 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 17621
diff changeset
   245
                    REGISTER unsigned short *dstp  = __twoByteStringVal(self) + index1 - 1;
16750
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   246
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   247
                    while (count-- > 0) {
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   248
                        *dstp++ = *srcp++;
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   249
                    }
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   250
                    RETURN (self);
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   251
                }
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   252
            } else  if (__isTwoByteString(aString) || __isUnicode16String(aString)) {
18576
724284508398 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 17621
diff changeset
   253
                int repLen = __twoByteStringSize(aString);
16750
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   254
                if ((repIndex > 0) && ((repIndex + count - 1) <= repLen)) {
18576
724284508398 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 17621
diff changeset
   255
                    REGISTER unsigned short *srcp  = __twoByteStringVal(aString) + repIndex - 1;
724284508398 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 17621
diff changeset
   256
                    REGISTER unsigned short *dstp = __twoByteStringVal(self) + index1 - 1;
16750
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   257
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   258
                    if (aString == self) {
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   259
                        /* take care of overlapping copy */
18576
724284508398 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 17621
diff changeset
   260
                        memmove(dstp, srcp, count*sizeof(short));
724284508398 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 17621
diff changeset
   261
                        RETURN (self);
16750
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   262
                    }
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   263
                    if (count > 5) {
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   264
                        memcpy(dstp, srcp, count*sizeof(short));
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   265
                    } else {
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   266
                        while (count-- > 0) {
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   267
                            *dstp++ = *srcp++;
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   268
                        }
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   269
                    }
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   270
                    RETURN (self);
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   271
                }
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   272
            }
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   273
        }
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   274
    }
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   275
#endif
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   276
%}.
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   277
    "/ arrive here if any index arg is out o range, or the source is neither a string,
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   278
    "/ nor a two-byte string.
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   279
    ^ super replaceFrom:start to:stop with:aString startingAt:repStart
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   280
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   281
    "
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   282
     'hello world' asUnicode16String replaceFrom:1 to:5 with:'123456' startingAt:2
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   283
     'hello world' asUnicode16String replaceFrom:1 to:5 with:'123456' asUnicode16String startingAt:2
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   284
     'hello world' asUnicode16String replaceFrom:1 to:0 with:'123456' startingAt:2
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   285
     'hello' asUnicode16String replaceFrom:1 to:6 with:'123456' startingAt:2
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   286
     'hello world' asUnicode16String replaceFrom:1 to:1 with:'123456' startingAt:2
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   287
    "
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   288
! !
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   289
608
cd5ac440fa95 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   290
!TwoByteString methodsFor:'queries'!
cd5ac440fa95 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   291
1017
2665a2628779 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1014
diff changeset
   292
bitsPerCharacter
1239
91a688ac83de commentary
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
   293
    "return the number of bits each character has.
91a688ac83de commentary
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
   294
     Here, 16 is returned (storing double byte characters)."
91a688ac83de commentary
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
   295
1017
2665a2628779 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1014
diff changeset
   296
    ^ 16
1239
91a688ac83de commentary
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
   297
91a688ac83de commentary
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
   298
    "Modified: 20.4.1996 / 23:08:38 / cg"
14557
427740fc4329 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 14123
diff changeset
   299
!
427740fc4329 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 14123
diff changeset
   300
19758
9cb10401a691 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 19581
diff changeset
   301
bytesPerCharacter
9cb10401a691 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 19581
diff changeset
   302
    "return the number of bytes each character has.
9cb10401a691 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 19581
diff changeset
   303
     Here, 2 is returned (storing double byte characters)."
9cb10401a691 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 19581
diff changeset
   304
9cb10401a691 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 19581
diff changeset
   305
    ^ 2
9cb10401a691 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 19581
diff changeset
   306
!
9cb10401a691 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 19581
diff changeset
   307
18593
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   308
characterSize
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   309
    "answer the size in bits of my largest character (actually only 7, 8 or 16)"
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   310
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   311
%{  /* NOCONTEXT */
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   312
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   313
    REGISTER unsigned short *sp = __twoByteStringVal(self);
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   314
    REGISTER unsigned short *last = sp + __twoByteStringSize(self);
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   315
    OBJ cls = __qClass(self);
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   316
    int has8BitChars = 0;
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   317
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   318
    if (cls != Unicode16String && cls != TwoByteString) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   319
        sp += __OBJS2BYTES__(__intVal(__ClassInstPtr(cls)->c_ninstvars)) / 2;
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   320
    }
18586
b8798de459f4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18576
diff changeset
   321
18593
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   322
#if __POINTER_SIZE__ == 8
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   323
    if (sizeof(unsigned INT) == 8) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   324
        if (!has8BitChars) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   325
            for ( ; (sp+4) <= last; sp += 4) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   326
                if (*(unsigned INT *)sp & 0xFF80FF80FF80FF80) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   327
                    /* there are at least 8-bit chars - check for more */
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   328
                    has8BitChars = 1;
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   329
                    break;
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   330
                }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   331
            }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   332
        }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   333
        for ( ; (sp+4) <= last; sp += 4) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   334
            if (*(unsigned INT *)sp & 0xFF00FF00FF00FF00) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   335
                RETURN(__mkSmallInteger(16));
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   336
            }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   337
        }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   338
    }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   339
#endif
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   340
    if (sizeof(unsigned int) == 4) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   341
        if (!has8BitChars) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   342
            for ( ; (sp+2) <= last; sp += 2) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   343
                if (*(unsigned int *)sp & 0xFF80FF80) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   344
                    /* there are at least 8-bit chars - check for more */
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   345
                    has8BitChars = 1;
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   346
                    break;
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   347
                }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   348
            }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   349
        }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   350
        for ( ; (sp+2) <= last; sp += 2) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   351
            if (*(unsigned int *)sp & 0xFF00FF00) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   352
                RETURN(__mkSmallInteger(16));
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   353
            }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   354
        }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   355
    }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   356
    if (!has8BitChars) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   357
        for ( ; sp < last; sp++) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   358
            if (*sp & 0xFF80) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   359
                /* there are at least 8-bit chars - check for more */
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   360
                has8BitChars = 1;
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   361
                break;
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   362
            }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   363
        }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   364
    }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   365
    for ( ; sp < last; sp++) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   366
        if (*sp & 0xFF00) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   367
            RETURN(__mkSmallInteger(16));
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   368
        }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   369
    }
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   370
    RETURN (__mkSmallInteger(has8BitChars ? 8 : 7));
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   371
%}.
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   372
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   373
    "
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   374
     'hello world' asUnicode16String characterSize
19581
8f0e91223fb3 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 18606
diff changeset
   375
     'hello worldüäö' asUnicode16String characterSize
18593
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   376
     'a' asUnicode16String characterSize
19581
8f0e91223fb3 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 18606
diff changeset
   377
     'ü' asUnicode16String characterSize
18593
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   378
     'aa' asUnicode16String characterSize
19581
8f0e91223fb3 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 18606
diff changeset
   379
     'aü' asUnicode16String characterSize
18593
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   380
     'aaa' asUnicode16String characterSize
19581
8f0e91223fb3 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 18606
diff changeset
   381
     'aaü' asUnicode16String characterSize
8f0e91223fb3 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 18606
diff changeset
   382
     'aaaü' asUnicode16String characterSize
18593
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   383
     'aaaa' asUnicode16String characterSize
19581
8f0e91223fb3 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 18606
diff changeset
   384
     'aaaaü' asUnicode16String characterSize
18593
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   385
    "
18586
b8798de459f4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18576
diff changeset
   386
!
b8798de459f4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18576
diff changeset
   387
18593
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   388
containsNon7BitAscii
17621
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   389
    "return true, if the underlying string contains 8BitCharacters (or widers)
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   390
     (i.e. if it is non-ascii)"
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   391
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   392
%{  /* NOCONTEXT */
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   393
18593
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   394
    REGISTER unsigned short *sp = __twoByteStringVal(self);
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   395
    REGISTER unsigned short *last = sp + __twoByteStringSize(self);
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   396
    OBJ cls = __qClass(self);
17621
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   397
18593
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   398
    if ( cls != Unicode16String && cls != TwoByteString) {
17621
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   399
        sp += __OBJS2BYTES__(__intVal(__ClassInstPtr(cls)->c_ninstvars)) / 2;
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   400
    }
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   401
#if __POINTER_SIZE__ == 8
18593
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   402
    if (sizeof(unsigned INT) == 8) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   403
        for ( ; (sp+4) <= last; sp += 4) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   404
            if (*(unsigned INT *)sp & 0xFF80FF80FF80FF80) {
17621
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   405
                RETURN ( true );
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   406
            }
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   407
        }
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   408
    }
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   409
#endif
18593
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   410
    if (sizeof(unsigned int) == 4) {
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   411
        for ( ; (sp+2) <= last; sp += 2) {
17621
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   412
            if (*(unsigned int *)sp & 0xFF80FF80) {
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   413
                RETURN ( true );
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   414
            }
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   415
        }
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   416
    }
18593
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   417
    for ( ; sp < last; sp++) {
17621
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   418
        if (*sp & 0xFF80) {
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   419
            RETURN ( true );
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   420
        }
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   421
    }
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   422
    RETURN (false);
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   423
%}.
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   424
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   425
    "
18593
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   426
     'hello world' asUnicode16String containsNon7BitAscii
19581
8f0e91223fb3 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 18606
diff changeset
   427
     'hello worldüäö' asUnicode16String containsNon7BitAscii
8f0e91223fb3 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 18606
diff changeset
   428
     'ü' asUnicode16String containsNon7BitAscii
8f0e91223fb3 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 18606
diff changeset
   429
     'aü' asUnicode16String containsNon7BitAscii
8f0e91223fb3 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 18606
diff changeset
   430
     'aaü' asUnicode16String containsNon7BitAscii
8f0e91223fb3 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 18606
diff changeset
   431
     'aaaü' asUnicode16String containsNon7BitAscii
8f0e91223fb3 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 18606
diff changeset
   432
     'aaaaü' asUnicode16String containsNon7BitAscii
18593
e69a425e3823 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 18586
diff changeset
   433
     'aaaaa' asUnicode16String containsNon7BitAscii
17621
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   434
    "
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   435
!
098adea6b2d4 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 16750
diff changeset
   436
14557
427740fc4329 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 14123
diff changeset
   437
isWideString
19581
8f0e91223fb3 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 18606
diff changeset
   438
    "true if I require more than one byte per character"
8f0e91223fb3 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 18606
diff changeset
   439
14557
427740fc4329 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 14123
diff changeset
   440
    ^ true
608
cd5ac440fa95 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   441
! !
cd5ac440fa95 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   442
22226
0604a0bec563 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 19840
diff changeset
   443
!TwoByteString methodsFor:'testing'!
0604a0bec563 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 19840
diff changeset
   444
22228
f9b1fd876cbb #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 22226
diff changeset
   445
isSingleByteCollection
f9b1fd876cbb #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 22226
diff changeset
   446
    "return true, if the receiver has access methods for bytes;
f9b1fd876cbb #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 22226
diff changeset
   447
     i.e. #at: and #at:put: accesses a byte and are equivalent to #byteAt: and byteAt:put:
f9b1fd876cbb #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 22226
diff changeset
   448
     and #replaceFrom:to: is equivalent to #replaceBytesFrom:to:. 
f9b1fd876cbb #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 22226
diff changeset
   449
     false is returned here since at: returns 2-byte characters and not bytes 
f9b1fd876cbb #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 22226
diff changeset
   450
      - the method is redefined from UninterpretedBytes."
f9b1fd876cbb #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 22226
diff changeset
   451
22226
0604a0bec563 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 19840
diff changeset
   452
    ^ false
0604a0bec563 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 19840
diff changeset
   453
0604a0bec563 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 19840
diff changeset
   454
    "Created: / 30-08-2017 / 23:30:36 / cg"
0604a0bec563 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 19840
diff changeset
   455
! !
0604a0bec563 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 19840
diff changeset
   456
631
d43deb0ec558 version at the end
Claus Gittinger <cg@exept.de>
parents: 608
diff changeset
   457
!TwoByteString class methodsFor:'documentation'!
d43deb0ec558 version at the end
Claus Gittinger <cg@exept.de>
parents: 608
diff changeset
   458
d43deb0ec558 version at the end
Claus Gittinger <cg@exept.de>
parents: 608
diff changeset
   459
version
18576
724284508398 class: TwoByteString
Stefan Vogel <sv@exept.de>
parents: 17621
diff changeset
   460
    ^ '$Header$'
631
d43deb0ec558 version at the end
Claus Gittinger <cg@exept.de>
parents: 608
diff changeset
   461
! !
8094
d05f69bd0097 Use #codePoint instead of deprecated #asciiValue
Stefan Vogel <sv@exept.de>
parents: 5761
diff changeset
   462
16750
394404a33691 class: TwoByteString
Claus Gittinger <cg@exept.de>
parents: 14557
diff changeset
   463
996
560a05298da9 I really store shorts ...
Claus Gittinger <cg@exept.de>
parents: 992
diff changeset
   464
TwoByteString initialize!