ByteArray.st
author claus
Sat, 11 Dec 1993 01:46:55 +0100
changeset 12 8e03bd717355
parent 10 4f1f9a91e406
child 37 d9a302eaa3ef
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     3
              All Rights Reserved
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
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
10
claus
parents: 5
diff changeset
    13
ArrayedCollection variableByteSubclass:#ByteArray
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    15
       classVariableNames:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    16
       poolDictionaries:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    17
       category:'Collections-Indexed'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
ByteArray comment:'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    21
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
    22
COPYRIGHT (c) 1989 by Claus Gittinger
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    23
              All Rights Reserved
a27a279701f8 Initial revision
claus
parents:
diff changeset
    24
a27a279701f8 Initial revision
claus
parents:
diff changeset
    25
ByteArrays store integers in the range 0..255
a27a279701f8 Initial revision
claus
parents:
diff changeset
    26
unlike Smalltalk/80, my ByteArrays have fixed size - may change
a27a279701f8 Initial revision
claus
parents:
diff changeset
    27
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
    28
$Header: /cvs/stx/stx/libbasic/ByteArray.st,v 1.6 1993-12-11 00:44:06 claus Exp $
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    29
a27a279701f8 Initial revision
claus
parents:
diff changeset
    30
written spring 89 by claus
a27a279701f8 Initial revision
claus
parents:
diff changeset
    31
'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    32
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
    33
!ByteArray class methodsFor:'queries'!
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
    34
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
    35
isBuiltInClass
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
    36
    "this class is known by the run-time-system"
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
    37
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
    38
    ^ self == ByteArray
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
    39
! !
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
    40
2
claus
parents: 1
diff changeset
    41
!ByteArray class methodsFor: 'binary storage'!
claus
parents: 1
diff changeset
    42
claus
parents: 1
diff changeset
    43
binaryDefinitionFrom: stream manager: manager
claus
parents: 1
diff changeset
    44
    ^ (stream next: (stream nextNumber: 4))
claus
parents: 1
diff changeset
    45
! !
claus
parents: 1
diff changeset
    46
10
claus
parents: 5
diff changeset
    47
!ByteArray methodsFor:'resizing'!
claus
parents: 5
diff changeset
    48
claus
parents: 5
diff changeset
    49
grow:sizeIncr
claus
parents: 5
diff changeset
    50
    "report an error - ByteArrays cannot grow"
claus
parents: 5
diff changeset
    51
claus
parents: 5
diff changeset
    52
    self fixedSizeError
claus
parents: 5
diff changeset
    53
! !
claus
parents: 5
diff changeset
    54
2
claus
parents: 1
diff changeset
    55
!ByteArray methodsFor: 'binary storage'!
claus
parents: 1
diff changeset
    56
claus
parents: 1
diff changeset
    57
storeBinaryDefinitionOn: stream manager: manager
claus
parents: 1
diff changeset
    58
    manager putIdOf: self class on: stream.
claus
parents: 1
diff changeset
    59
    stream nextNumber: 4 put: self basicSize.
claus
parents: 1
diff changeset
    60
    stream nextPutAll: self
claus
parents: 1
diff changeset
    61
! !
claus
parents: 1
diff changeset
    62
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    63
!ByteArray class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    64
a27a279701f8 Initial revision
claus
parents:
diff changeset
    65
uninitializedNew:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
    66
    "return a new instance of the receiver with uninitialized
a27a279701f8 Initial revision
claus
parents:
diff changeset
    67
     (i.e. undefined) contents. The indexed elements have any random
a27a279701f8 Initial revision
claus
parents:
diff changeset
    68
     value. use, when contents will be set anyway shortly after."
a27a279701f8 Initial revision
claus
parents:
diff changeset
    69
a27a279701f8 Initial revision
claus
parents:
diff changeset
    70
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
    71
    OBJ newobj;
a27a279701f8 Initial revision
claus
parents:
diff changeset
    72
    INT instsize, nInstVars, nindexedinstvars;
a27a279701f8 Initial revision
claus
parents:
diff changeset
    73
    REGISTER OBJ *op;
a27a279701f8 Initial revision
claus
parents:
diff changeset
    74
    extern OBJ new();
a27a279701f8 Initial revision
claus
parents:
diff changeset
    75
a27a279701f8 Initial revision
claus
parents:
diff changeset
    76
    if (_isSmallInteger(anInteger)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
    77
        nindexedinstvars = _intVal(anInteger);
a27a279701f8 Initial revision
claus
parents:
diff changeset
    78
        if (nindexedinstvars >= 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
    79
            nInstVars = _intVal(_ClassInstPtr(self)->c_ninstvars);
a27a279701f8 Initial revision
claus
parents:
diff changeset
    80
            if ((_intVal(_ClassInstPtr(self)->c_flags) & ARRAYMASK) == BYTEARRAY) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
    81
                instsize = OHDR_SIZE + nInstVars * sizeof(OBJ) + nindexedinstvars * sizeof(char);
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
    82
                PROTECT_CONTEXT
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    83
                _qNew(newobj, instsize, SENDER);
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
    84
                UNPROTECT_CONTEXT
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
    85
                if (newobj) {
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
    86
                    _InstPtr(newobj)->o_class = self;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    87
#if defined(FAST_MEMSET) && ! defined(NEGATIVE_ADDRESSES)
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
    88
                    /*
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
    89
                     * knowing that nil is 0
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
    90
                     */
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
    91
                    memset(_InstPtr(newobj)->i_instvars, 0, instsize - OHDR_SIZE);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    92
#else
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
    93
                    op = _InstPtr(newobj)->i_instvars;
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
    94
                    while (nInstVars--)
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
    95
                        *op++ = nil;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    96
#endif
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
    97
                    RETURN ( newobj );
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
    98
                }
10
claus
parents: 5
diff changeset
    99
            }
claus
parents: 5
diff changeset
   100
        }
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   101
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   102
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   103
.
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   104
    (anInteger isMemberOf:SmallInteger) ifTrue:[
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   105
        (anInteger < 0) ifTrue:[
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   106
            self error:'bad (negative) argument to new'
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   107
        ] ifFalse:[
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   108
            ObjectMemory allocationFailureSignal raise.
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   109
        ].
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   110
        ^ nil
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   111
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   112
    ^ self basicNew:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   113
a27a279701f8 Initial revision
claus
parents:
diff changeset
   114
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   115
a27a279701f8 Initial revision
claus
parents:
diff changeset
   116
!ByteArray methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   117
a27a279701f8 Initial revision
claus
parents:
diff changeset
   118
basicAt:index
a27a279701f8 Initial revision
claus
parents:
diff changeset
   119
    "return the indexed instance variable with index, anInteger
2
claus
parents: 1
diff changeset
   120
     - redefined here to be slighly faster than the default in Object"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   121
a27a279701f8 Initial revision
claus
parents:
diff changeset
   122
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   123
a27a279701f8 Initial revision
claus
parents:
diff changeset
   124
    REGISTER int indx;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   125
    int nIndex;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   126
2
claus
parents: 1
diff changeset
   127
    if (_isSmallInteger(index)) {
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   128
        indx = _intVal(index);
2
claus
parents: 1
diff changeset
   129
claus
parents: 1
diff changeset
   130
        if (_qClass(self) != ByteArray)
claus
parents: 1
diff changeset
   131
            indx += _intVal(_ClassInstPtr(_qClass(self))->c_ninstvars) * sizeof(OBJ);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   132
        nIndex = _qSize(self) - OHDR_SIZE;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   133
        if ((indx > 0) && (indx <= nIndex)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   134
            RETURN ( _MKSMALLINT(_ByteArrayInstPtr(self)->ba_element[indx - 1]) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   135
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   136
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   137
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   138
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   139
    ^ super basicAt:index
a27a279701f8 Initial revision
claus
parents:
diff changeset
   140
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   141
a27a279701f8 Initial revision
claus
parents:
diff changeset
   142
basicAt:index put:value
a27a279701f8 Initial revision
claus
parents:
diff changeset
   143
    "set the indexed instance variable with index, anInteger to value
2
claus
parents: 1
diff changeset
   144
     - redefined here to be slighly faster than the default in Object"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   145
a27a279701f8 Initial revision
claus
parents:
diff changeset
   146
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   147
a27a279701f8 Initial revision
claus
parents:
diff changeset
   148
    REGISTER int indx;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   149
    int nIndex;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   150
    int val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   151
2
claus
parents: 1
diff changeset
   152
    if (_isSmallInteger(index) && _isSmallInteger(value)) {
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   153
        val = _intVal(value);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   154
        if ((val >= 0) && (val <= 255)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   155
            indx = _intVal(index);
2
claus
parents: 1
diff changeset
   156
            if (_qClass(self) != ByteArray)
claus
parents: 1
diff changeset
   157
                indx += _intVal(_ClassInstPtr(_qClass(self))->c_ninstvars) * sizeof(OBJ);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   158
            nIndex = _qSize(self) - OHDR_SIZE;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   159
            if ((indx > 0) && (indx <= nIndex)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   160
                _ByteArrayInstPtr(self)->ba_element[indx - 1] = val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   161
                RETURN ( value );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   162
            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   163
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   164
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   165
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   166
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   167
    ^ super basicAt:index put:value
2
claus
parents: 1
diff changeset
   168
!
claus
parents: 1
diff changeset
   169
claus
parents: 1
diff changeset
   170
wordAt:index
claus
parents: 1
diff changeset
   171
    "return the 2-bytes starting at index as an (unsigned) Integer.
claus
parents: 1
diff changeset
   172
     question: should it be signed ?"
claus
parents: 1
diff changeset
   173
claus
parents: 1
diff changeset
   174
%{  /* NOCONTEXT */
claus
parents: 1
diff changeset
   175
claus
parents: 1
diff changeset
   176
    REGISTER int indx;
claus
parents: 1
diff changeset
   177
    int nIndex;
claus
parents: 1
diff changeset
   178
    int val;
claus
parents: 1
diff changeset
   179
    extern OBJ _makeLarge();
claus
parents: 1
diff changeset
   180
claus
parents: 1
diff changeset
   181
    if (_isSmallInteger(index)) {
claus
parents: 1
diff changeset
   182
        indx = _intVal(index);
claus
parents: 1
diff changeset
   183
        if (_qClass(self) != ByteArray)
claus
parents: 1
diff changeset
   184
            indx += _intVal(_ClassInstPtr(_qClass(self))->c_ninstvars) * sizeof(OBJ);
claus
parents: 1
diff changeset
   185
        nIndex = _qSize(self) - OHDR_SIZE;
claus
parents: 1
diff changeset
   186
        if ((indx > 0) && ((indx+1) <= nIndex)) {
10
claus
parents: 5
diff changeset
   187
            val = _ByteArrayInstPtr(self)->ba_element[indx+1-1];
claus
parents: 5
diff changeset
   188
            val = (val << 8) + _ByteArrayInstPtr(self)->ba_element[indx-1];
2
claus
parents: 1
diff changeset
   189
            RETURN ( _MKSMALLINT(val) );
claus
parents: 1
diff changeset
   190
        }
claus
parents: 1
diff changeset
   191
    }
claus
parents: 1
diff changeset
   192
%}
claus
parents: 1
diff changeset
   193
.
claus
parents: 1
diff changeset
   194
    ^ ((self at:index+1) * 256) + (self at:index)
claus
parents: 1
diff changeset
   195
!
claus
parents: 1
diff changeset
   196
claus
parents: 1
diff changeset
   197
wordAt:index put:value
claus
parents: 1
diff changeset
   198
    "set the 2-bytes starting at index from the (unsigned) Integer value.
claus
parents: 1
diff changeset
   199
     question: should it be signed ?"
claus
parents: 1
diff changeset
   200
claus
parents: 1
diff changeset
   201
%{  /* NOCONTEXT */
claus
parents: 1
diff changeset
   202
claus
parents: 1
diff changeset
   203
    REGISTER int indx;
claus
parents: 1
diff changeset
   204
    int nIndex;
claus
parents: 1
diff changeset
   205
    int val;
claus
parents: 1
diff changeset
   206
    extern OBJ _makeLarge();
claus
parents: 1
diff changeset
   207
claus
parents: 1
diff changeset
   208
    if (_isSmallInteger(index) && _isSmallInteger(value)) {
claus
parents: 1
diff changeset
   209
        indx = _intVal(index);
claus
parents: 1
diff changeset
   210
        if (_qClass(self) != ByteArray)
claus
parents: 1
diff changeset
   211
            indx += _intVal(_ClassInstPtr(_qClass(self))->c_ninstvars) * sizeof(OBJ);
claus
parents: 1
diff changeset
   212
        nIndex = _qSize(self) - OHDR_SIZE;
claus
parents: 1
diff changeset
   213
        if ((indx > 0) && ((indx+1) <= nIndex)) {
10
claus
parents: 5
diff changeset
   214
            val = _intVal(value);
claus
parents: 5
diff changeset
   215
            if ((val >= 0) && (val <= 0xFFFF)) {
claus
parents: 5
diff changeset
   216
                _ByteArrayInstPtr(self)->ba_element[indx-1] = val & 0xFF;
claus
parents: 5
diff changeset
   217
                val >>= 8;
claus
parents: 5
diff changeset
   218
                _ByteArrayInstPtr(self)->ba_element[indx+1-1] = val & 0xFF;
2
claus
parents: 1
diff changeset
   219
                RETURN ( value );
claus
parents: 1
diff changeset
   220
            }
claus
parents: 1
diff changeset
   221
        }
claus
parents: 1
diff changeset
   222
    }
claus
parents: 1
diff changeset
   223
%}
claus
parents: 1
diff changeset
   224
.
claus
parents: 1
diff changeset
   225
    (value < 0) ifTrue:[
10
claus
parents: 5
diff changeset
   226
        ^ self elementBoundsError
2
claus
parents: 1
diff changeset
   227
    ].
claus
parents: 1
diff changeset
   228
    self at:index put:(value \\ 256).
claus
parents: 1
diff changeset
   229
    self at:index + 1 put:(value // 256).
claus
parents: 1
diff changeset
   230
    ^ value
claus
parents: 1
diff changeset
   231
!
claus
parents: 1
diff changeset
   232
claus
parents: 1
diff changeset
   233
doubleWordAt:index
claus
parents: 1
diff changeset
   234
    "return the 4-bytes starting at index as an (unsigned) Integer.
claus
parents: 1
diff changeset
   235
     question: should it be signed ?"
claus
parents: 1
diff changeset
   236
claus
parents: 1
diff changeset
   237
%{  /* NOCONTEXT */
claus
parents: 1
diff changeset
   238
claus
parents: 1
diff changeset
   239
    REGISTER int indx;
claus
parents: 1
diff changeset
   240
    int nIndex;
claus
parents: 1
diff changeset
   241
    int val;
claus
parents: 1
diff changeset
   242
    extern OBJ _makeLarge();
claus
parents: 1
diff changeset
   243
claus
parents: 1
diff changeset
   244
    if (_isSmallInteger(index)) {
claus
parents: 1
diff changeset
   245
        indx = _intVal(index);
claus
parents: 1
diff changeset
   246
        if (_qClass(self) != ByteArray)
claus
parents: 1
diff changeset
   247
            indx += _intVal(_ClassInstPtr(_qClass(self))->c_ninstvars) * sizeof(OBJ);
claus
parents: 1
diff changeset
   248
        nIndex = _qSize(self) - OHDR_SIZE;
claus
parents: 1
diff changeset
   249
        if ((indx > 0) && ((indx+3) <= nIndex)) {
10
claus
parents: 5
diff changeset
   250
            val = _ByteArrayInstPtr(self)->ba_element[indx+3-1];
claus
parents: 5
diff changeset
   251
            val = (val << 8) + _ByteArrayInstPtr(self)->ba_element[indx+2-1];
claus
parents: 5
diff changeset
   252
            val = (val << 8) + _ByteArrayInstPtr(self)->ba_element[indx+1-1];
claus
parents: 5
diff changeset
   253
            val = (val << 8) + _ByteArrayInstPtr(self)->ba_element[indx-1];
claus
parents: 5
diff changeset
   254
            if ((val >= 0) && (val <= _MAX_INT)) {
2
claus
parents: 1
diff changeset
   255
                RETURN ( _MKSMALLINT(val) );
claus
parents: 1
diff changeset
   256
            }
claus
parents: 1
diff changeset
   257
        }
claus
parents: 1
diff changeset
   258
    }
claus
parents: 1
diff changeset
   259
%}
claus
parents: 1
diff changeset
   260
.
claus
parents: 1
diff changeset
   261
    ^ ((self wordAt:index+2) * (256 *256)) + (self wordAt:index)
claus
parents: 1
diff changeset
   262
!
claus
parents: 1
diff changeset
   263
claus
parents: 1
diff changeset
   264
doubleWordAt:index put:value
claus
parents: 1
diff changeset
   265
    "set the 4-bytes starting at index from the (unsigned) Integer value.
claus
parents: 1
diff changeset
   266
     question: should it be signed ?"
claus
parents: 1
diff changeset
   267
claus
parents: 1
diff changeset
   268
    |t|
claus
parents: 1
diff changeset
   269
claus
parents: 1
diff changeset
   270
%{  /* NOCONTEXT */
claus
parents: 1
diff changeset
   271
claus
parents: 1
diff changeset
   272
    REGISTER int indx;
claus
parents: 1
diff changeset
   273
    int nIndex;
claus
parents: 1
diff changeset
   274
    int val;
claus
parents: 1
diff changeset
   275
    extern OBJ _makeLarge();
claus
parents: 1
diff changeset
   276
claus
parents: 1
diff changeset
   277
    if (_isSmallInteger(index) && _isSmallInteger(value)) {
10
claus
parents: 5
diff changeset
   278
        val = _intVal(value);
claus
parents: 5
diff changeset
   279
        if (val >= 0) {
2
claus
parents: 1
diff changeset
   280
            indx = _intVal(index);
claus
parents: 1
diff changeset
   281
            if (_qClass(self) != ByteArray)
claus
parents: 1
diff changeset
   282
                indx += _intVal(_ClassInstPtr(_qClass(self))->c_ninstvars) * sizeof(OBJ);
claus
parents: 1
diff changeset
   283
            nIndex = _qSize(self) - OHDR_SIZE;
claus
parents: 1
diff changeset
   284
            if ((indx > 0) && ((indx+3) <= nIndex)) {
10
claus
parents: 5
diff changeset
   285
                _ByteArrayInstPtr(self)->ba_element[indx-1] = val & 0xFF;
claus
parents: 5
diff changeset
   286
                val >>= 8;
claus
parents: 5
diff changeset
   287
                _ByteArrayInstPtr(self)->ba_element[indx+1-1] = val & 0xFF;
claus
parents: 5
diff changeset
   288
                val >>= 8;
claus
parents: 5
diff changeset
   289
                _ByteArrayInstPtr(self)->ba_element[indx+2-1] = val & 0xFF;
claus
parents: 5
diff changeset
   290
                val >>= 8;
claus
parents: 5
diff changeset
   291
                _ByteArrayInstPtr(self)->ba_element[indx+3-1] = val & 0xFF;
2
claus
parents: 1
diff changeset
   292
                RETURN ( value );
claus
parents: 1
diff changeset
   293
            }
claus
parents: 1
diff changeset
   294
        }
claus
parents: 1
diff changeset
   295
    }
claus
parents: 1
diff changeset
   296
%}
claus
parents: 1
diff changeset
   297
.
claus
parents: 1
diff changeset
   298
    (value < 0) ifTrue:[
10
claus
parents: 5
diff changeset
   299
        ^ self elementBoundsError
2
claus
parents: 1
diff changeset
   300
    ].
claus
parents: 1
diff changeset
   301
    t := value // (256 * 256).
claus
parents: 1
diff changeset
   302
    self wordAt:(index+2) put:t.
claus
parents: 1
diff changeset
   303
    self wordAt:(index) put:(value - (t * 256 * 256)).
claus
parents: 1
diff changeset
   304
    ^ value
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   305
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   306
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   307
!ByteArray methodsFor:'converting'!
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   308
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   309
asByteArray
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   310
    "return the receiver as a byteArray"
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   311
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   312
    "could be an instance of a subclass..."
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   313
    self class == ByteArray ifTrue:[
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   314
        ^ self
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   315
    ].
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   316
    ^ super asByteArray
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   317
! !
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   318
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   319
!ByteArray methodsFor:'printing & storing'!
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   320
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   321
isLiteral
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   322
    "return true, if the receiver can be used as a literal"
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   323
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   324
    ^ true
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   325
!
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   326
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   327
storeOn:aStream
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   328
    aStream nextPutAll:'#['.
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   329
    self do:[:byte | byte storeOn:aStream. aStream space. ].
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   330
    aStream nextPutAll:']'
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   331
! !
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   332
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   333
!ByteArray methodsFor:'queries'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   334
a27a279701f8 Initial revision
claus
parents:
diff changeset
   335
indexOf:aByte startingAt:start
a27a279701f8 Initial revision
claus
parents:
diff changeset
   336
    "return the index of the first occurrence of the argument, aByte
a27a279701f8 Initial revision
claus
parents:
diff changeset
   337
     in the receiver starting at start, anInteger; return 0 if not found.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   338
     - reimplemented here for speed"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   339
a27a279701f8 Initial revision
claus
parents:
diff changeset
   340
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   341
a27a279701f8 Initial revision
claus
parents:
diff changeset
   342
    REGISTER unsigned char *cp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   343
    REGISTER int index, byteValue;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   344
    REGISTER int len;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   345
a27a279701f8 Initial revision
claus
parents:
diff changeset
   346
    if (! _isSmallInteger(aByte)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   347
        RETURN ( _MKSMALLINT(0) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   348
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   349
a27a279701f8 Initial revision
claus
parents:
diff changeset
   350
    byteValue = _intVal(aByte);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   351
a27a279701f8 Initial revision
claus
parents:
diff changeset
   352
    if ((byteValue < 0) || (byteValue > 255)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   353
        RETURN ( _MKSMALLINT(0) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   354
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   355
2
claus
parents: 1
diff changeset
   356
    if (_isSmallInteger(start)) {
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   357
        index = _intVal(start);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   358
        len = _qSize(self) - OHDR_SIZE;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   359
        cp = &(_ByteArrayInstPtr(self)->ba_element[0]);
2
claus
parents: 1
diff changeset
   360
        if (_qClass(self) != ByteArray) {
10
claus
parents: 5
diff changeset
   361
            int nInst;
2
claus
parents: 1
diff changeset
   362
claus
parents: 1
diff changeset
   363
            nInst = _intVal(_ClassInstPtr(_qClass(self))->c_ninstvars) * sizeof(OBJ);
claus
parents: 1
diff changeset
   364
            cp += nInst;
10
claus
parents: 5
diff changeset
   365
            len -= nInst;
claus
parents: 5
diff changeset
   366
        }
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   367
        cp += index - 1;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   368
        while (index <= len) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   369
            if (*cp == byteValue) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   370
                RETURN ( _MKSMALLINT(index) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   371
            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   372
            index++;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   373
            cp++;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   374
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   375
        RETURN ( _MKSMALLINT(0) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   376
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   377
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   378
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   379
    ^ super indexOf:aByte startingAt:start
a27a279701f8 Initial revision
claus
parents:
diff changeset
   380
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   381
a27a279701f8 Initial revision
claus
parents:
diff changeset
   382
usedValues
a27a279701f8 Initial revision
claus
parents:
diff changeset
   383
    "return a new ByteArray with all used values (actually a kind of Set);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   384
     needed specially for Image class."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   385
a27a279701f8 Initial revision
claus
parents:
diff changeset
   386
    |result l|
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   387
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   388
%{  /* STACK: 400 */
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   389
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   390
    REGISTER unsigned char *cp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   391
    REGISTER int len;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   392
    unsigned char flags[256];
a27a279701f8 Initial revision
claus
parents:
diff changeset
   393
    static struct inlineCache nw = _ILC1;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   394
    extern OBJ ByteArray, _new_;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   395
a27a279701f8 Initial revision
claus
parents:
diff changeset
   396
    if (_qClass(self) == ByteArray) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   397
        memset(flags, 0, sizeof(flags));
a27a279701f8 Initial revision
claus
parents:
diff changeset
   398
        len = _qSize(self) - OHDR_SIZE;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   399
        cp = &(_ByteArrayInstPtr(self)->ba_element[0]);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   400
a27a279701f8 Initial revision
claus
parents:
diff changeset
   401
        /* for each used byte, set flag */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   402
        while (len > 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   403
            flags[*cp] = 1;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   404
            cp++;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   405
            len--;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   406
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   407
        /* count 1's */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   408
        len = 0;
2
claus
parents: 1
diff changeset
   409
        for (cp=flags+255; cp >= flags; cp--)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   410
            if (*cp) len++;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   411
a27a279701f8 Initial revision
claus
parents:
diff changeset
   412
        /* create ByteArray of used values */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   413
        result = (*nw.ilc_func)(ByteArray, _new_, CON_COMMA nil, &nw, _MKSMALLINT(len));
a27a279701f8 Initial revision
claus
parents:
diff changeset
   414
        if (_Class(result) == ByteArray) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   415
            cp = &(_ByteArrayInstPtr(result)->ba_element[0]);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   416
            for (len=0; len < 256; len++) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   417
                if (flags[len]) 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   418
                    *cp++ = len;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   419
            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   420
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   421
        RETURN ( result );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   422
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   423
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   424
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   425
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   426
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   427
a27a279701f8 Initial revision
claus
parents:
diff changeset
   428
usageCounts
a27a279701f8 Initial revision
claus
parents:
diff changeset
   429
    "return an array filled with value-counts -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   430
     added for Image handling"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   431
a27a279701f8 Initial revision
claus
parents:
diff changeset
   432
    |counts|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   433
a27a279701f8 Initial revision
claus
parents:
diff changeset
   434
    counts := Array new:256.
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   435
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   436
%{  /* STACK: 2000 */
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   437
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   438
    REGISTER unsigned char *cp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   439
    REGISTER int nByte;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   440
    REGISTER int index;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   441
    int icounts[256];
a27a279701f8 Initial revision
claus
parents:
diff changeset
   442
a27a279701f8 Initial revision
claus
parents:
diff changeset
   443
    if ((_qClass(self) == ByteArray) && _isArray(counts)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   444
        /*
a27a279701f8 Initial revision
claus
parents:
diff changeset
   445
         * zero counts
a27a279701f8 Initial revision
claus
parents:
diff changeset
   446
         */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   447
        for (index=0; index<256; index++) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   448
            icounts[index] = 0;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   449
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   450
a27a279701f8 Initial revision
claus
parents:
diff changeset
   451
        /*
a27a279701f8 Initial revision
claus
parents:
diff changeset
   452
         * count
a27a279701f8 Initial revision
claus
parents:
diff changeset
   453
         */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   454
        nByte = _qSize(self) - OHDR_SIZE;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   455
        cp = &(_ByteArrayInstPtr(self)->ba_element[0]);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   456
        while (nByte--) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   457
            icounts[*cp++]++;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   458
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   459
a27a279701f8 Initial revision
claus
parents:
diff changeset
   460
        /*
a27a279701f8 Initial revision
claus
parents:
diff changeset
   461
         * make it real counts
a27a279701f8 Initial revision
claus
parents:
diff changeset
   462
         */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   463
        for (index=0; index<256; index++) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   464
            _ArrayInstPtr(counts)->a_element[index] = _MKSMALLINT(icounts[index]);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   465
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   466
        RETURN ( counts );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   467
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   468
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   469
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   470
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   471
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   472
a27a279701f8 Initial revision
claus
parents:
diff changeset
   473
maximumValue
a27a279701f8 Initial revision
claus
parents:
diff changeset
   474
    "return the maximum value in the receiver -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   475
     added for sound-player (which needs a fast method for this)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   476
a27a279701f8 Initial revision
claus
parents:
diff changeset
   477
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   478
a27a279701f8 Initial revision
claus
parents:
diff changeset
   479
    REGISTER unsigned char *cp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   480
    REGISTER int index, max;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   481
    int len;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   482
a27a279701f8 Initial revision
claus
parents:
diff changeset
   483
    if (_qClass(self) == ByteArray) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   484
        max = 0;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   485
        index = 0;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   486
        len = _qSize(self) - OHDR_SIZE;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   487
        cp = &(_ByteArrayInstPtr(self)->ba_element[0]);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   488
        while (++index <= len) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   489
            if (*cp > max) max = *cp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   490
            cp++;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   491
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   492
        RETURN ( _MKSMALLINT(max) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   493
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   494
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   495
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   496
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   497
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   498
a27a279701f8 Initial revision
claus
parents:
diff changeset
   499
!ByteArray methodsFor:'filling and replacing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   500
a27a279701f8 Initial revision
claus
parents:
diff changeset
   501
replaceFrom:start to:stop with:aCollection startingAt:repStart
a27a279701f8 Initial revision
claus
parents:
diff changeset
   502
    "reimplemented for speed"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   503
a27a279701f8 Initial revision
claus
parents:
diff changeset
   504
%{      /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   505
a27a279701f8 Initial revision
claus
parents:
diff changeset
   506
        int nIndex, repNIndex;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   507
        int startIndex, stopIndex;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   508
        REGISTER unsigned char *src;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   509
        REGISTER int repStartIndex;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   510
        int repStopIndex, count;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   511
        REGISTER unsigned char *dst;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   512
a27a279701f8 Initial revision
claus
parents:
diff changeset
   513
        if ((_qClass(self) == ByteArray)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   514
         && (_Class(aCollection) == ByteArray)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   515
         && _isSmallInteger(start)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   516
         && _isSmallInteger(stop)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   517
         && _isSmallInteger(repStart)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   518
            startIndex = _intVal(start) - 1;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   519
            if (startIndex >= 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   520
              nIndex = _qSize(self) - OHDR_SIZE;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   521
              stopIndex = _intVal(stop) - 1;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   522
              count = stopIndex - startIndex + 1;
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   523
              if (count == 0) {
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   524
                  RETURN ( self );
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   525
              }
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   526
              if ((count > 0) && (stopIndex < nIndex)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   527
                repStartIndex = _intVal(repStart) - 1;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   528
                if (repStartIndex >= 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   529
                  repNIndex = _qSize(aCollection) - OHDR_SIZE;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   530
                  repStopIndex = repStartIndex + (stopIndex - startIndex);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   531
                  if (repStopIndex < repNIndex) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   532
                    src = &(_ByteArrayInstPtr(aCollection)->ba_element[repStartIndex]);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   533
                    dst = &(_ByteArrayInstPtr(self)->ba_element[startIndex]);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   534
a27a279701f8 Initial revision
claus
parents:
diff changeset
   535
                    if (aCollection == self) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   536
                        /* take care of overlapping copy */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   537
                        if (src < dst) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   538
                            /* must do a reverse copy */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   539
                            src += count;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   540
                            dst += count;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   541
                            while (count-- > 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   542
                                *--dst = *--src;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   543
                            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   544
                            RETURN ( self );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   545
                        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   546
                    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   547
#ifdef FAST_MEMCPY
a27a279701f8 Initial revision
claus
parents:
diff changeset
   548
                    bcopy(src, dst, count);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   549
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   550
                    while (count-- > 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   551
                        *dst++ = *src++;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   552
                    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   553
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   554
                    RETURN ( self );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   555
                  }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   556
                }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   557
              }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   558
            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   559
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   560
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   561
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   562
    ^ super replaceFrom:start to:stop with:aCollection startingAt:repStart
a27a279701f8 Initial revision
claus
parents:
diff changeset
   563
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   564
a27a279701f8 Initial revision
claus
parents:
diff changeset
   565
!ByteArray methodsFor:'image manipulation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   566
a27a279701f8 Initial revision
claus
parents:
diff changeset
   567
invert
a27a279701f8 Initial revision
claus
parents:
diff changeset
   568
    "invert all bytes - used with image manipulations
a27a279701f8 Initial revision
claus
parents:
diff changeset
   569
     written as a primitive for speed"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   570
a27a279701f8 Initial revision
claus
parents:
diff changeset
   571
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   572
a27a279701f8 Initial revision
claus
parents:
diff changeset
   573
    REGISTER unsigned char *dst;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   574
    REGISTER unsigned long *ldst;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   575
    REGISTER int cnt;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   576
a27a279701f8 Initial revision
claus
parents:
diff changeset
   577
    if (_qClass(self) == ByteArray) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   578
        cnt = _qSize(self) - OHDR_SIZE;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   579
        dst = _ByteArrayInstPtr(self)->ba_element;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   580
        if (! ((int)dst & (sizeof(long)-1))) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   581
            ldst = (unsigned long *)dst;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   582
            while (cnt >= sizeof(long)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   583
                *ldst = ~(*ldst);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   584
                ldst++;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   585
                cnt -= sizeof(long);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   586
            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   587
            dst = (unsigned char *)ldst;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   588
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   589
        while (cnt--) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   590
            *dst = ~(*dst);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   591
            dst++;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   592
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   593
        RETURN ( self );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   594
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   595
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   596
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   597
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   598
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   599
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   600
reverse
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   601
    "reverse order of elements inplace - 
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   602
     written as a primitive for speed on image manipulations"
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   603
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   604
%{  /* NOCONTEXT */
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   605
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   606
    REGISTER unsigned char *p1, *p2;
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   607
    REGISTER int cnt;
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   608
    REGISTER unsigned t;
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   609
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   610
    if (_qClass(self) == ByteArray) {
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   611
        cnt = _qSize(self) - OHDR_SIZE;
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   612
        p1 = _ByteArrayInstPtr(self)->ba_element;
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   613
        p2 = _ByteArrayInstPtr(self)->ba_element + cnt - 1;
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   614
        while (cnt > 0) {
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   615
            t = *p1;
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   616
            *p1++ = *p2;
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   617
            *p2-- = t;
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   618
            cnt-=2;
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   619
        }
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   620
        RETURN ( self );
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   621
    }
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   622
%}
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   623
.
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   624
    ^ super reverse
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   625
!
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   626
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   627
expandPixels:nBitsPerPixel width:width height:height into:aByteArray
a27a279701f8 Initial revision
claus
parents:
diff changeset
   628
                         mapping:aMapByteArray
a27a279701f8 Initial revision
claus
parents:
diff changeset
   629
    "given the receiver with nBitsPerPixel-depth pixels, expand them into
a27a279701f8 Initial revision
claus
parents:
diff changeset
   630
     aByteArray with 8-bit pixels. The width/height-arguments are needed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   631
     to skip any padded src-bits. On the fly, the destination pixels
a27a279701f8 Initial revision
claus
parents:
diff changeset
   632
     are translated using aMapByteArray if nonnil.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   633
     - used to display mono, 2-bit and 4-bit bitmaps on grey-scale/color
a27a279701f8 Initial revision
claus
parents:
diff changeset
   634
       machines"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   635
a27a279701f8 Initial revision
claus
parents:
diff changeset
   636
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   637
a27a279701f8 Initial revision
claus
parents:
diff changeset
   638
    {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   639
        REGISTER unsigned char *src, *dst;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   640
        REGISTER int wrun;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   641
        unsigned char *srcNext;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   642
        int bytesPerRow, mask, shift0, shift;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   643
        int w, h, hrun;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   644
        int srcBytes, dstBytes;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   645
        int bitsPerPixel;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   646
        int bits;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   647
        int ncells;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   648
        unsigned char *map;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   649
a27a279701f8 Initial revision
claus
parents:
diff changeset
   650
        if ((_qClass(self) == ByteArray) 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   651
         && (_qClass(aByteArray) == ByteArray)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   652
         && _isSmallInteger(nBitsPerPixel)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   653
         && _isSmallInteger(height)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   654
         && _isSmallInteger(width)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   655
            if ((aMapByteArray != nil)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   656
             && (_Class(aMapByteArray) == ByteArray)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   657
                map = _ByteArrayInstPtr(aMapByteArray)->ba_element;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   658
            } else {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   659
                map = (unsigned char *)0;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   660
            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   661
a27a279701f8 Initial revision
claus
parents:
diff changeset
   662
            bitsPerPixel = _intVal(nBitsPerPixel);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   663
            w = _intVal(width);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   664
            h = _intVal(height);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   665
            src = _ByteArrayInstPtr(self)->ba_element;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   666
            dst = _ByteArrayInstPtr(aByteArray)->ba_element;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   667
            switch (bitsPerPixel) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   668
                case 1:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   669
                    mask = 0x01;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   670
                    break;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   671
                case 2:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   672
                    mask = 0x03;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   673
                    break;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   674
                case 4:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   675
                    mask = 0x0F;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   676
                    break;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   677
                case 8:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   678
                    mask = 0xFF;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   679
                    break;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   680
                default:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   681
                    goto fail;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   682
            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   683
            ncells = mask + 1;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   684
            if (map) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   685
                if ((_qSize(aMapByteArray) - OHDR_SIZE) < ncells)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   686
                    goto fail;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   687
            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   688
a27a279701f8 Initial revision
claus
parents:
diff changeset
   689
            bytesPerRow = (w * bitsPerPixel + 7) / 8;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   690
            shift0 = 8 - bitsPerPixel;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   691
            srcBytes = bytesPerRow * h;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   692
            dstBytes = w * h;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   693
a27a279701f8 Initial revision
claus
parents:
diff changeset
   694
            if (((_qSize(self) - OHDR_SIZE) >= srcBytes)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   695
             && ((_qSize(aByteArray) - OHDR_SIZE) >= dstBytes)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   696
                for (hrun=h; hrun; hrun--) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   697
                    srcNext = src + bytesPerRow;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   698
                    shift = shift0;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   699
                    if (map) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   700
                        for (wrun=w; wrun; wrun--) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   701
                            if (shift == shift0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   702
                                bits = *src++;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   703
                            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   704
                            *dst++ = map[(bits >> shift) & mask];
a27a279701f8 Initial revision
claus
parents:
diff changeset
   705
                            shift -= bitsPerPixel;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   706
                            if (shift < 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   707
                                shift = shift0;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   708
                            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   709
                        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   710
                    } else {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   711
                        for (wrun=w; wrun; wrun--) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   712
                            if (shift == shift0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   713
                                bits = *src++;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   714
                            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   715
                            *dst++ = (bits >> shift) & mask;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   716
                            shift -= bitsPerPixel;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   717
                            if (shift < 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   718
                                shift = shift0;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   719
                            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   720
                        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   721
                    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   722
                    src = srcNext;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   723
                }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   724
                RETURN ( self );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   725
            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   726
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   727
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   728
fail: ;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   729
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   730
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   731
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   732
! !