SmallInteger.st
author claus
Sun, 16 Jan 1994 04:47:41 +0100
changeset 44 b262907c93ea
parent 41 a14247b04d03
child 50 71f3b9444905
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) 1988 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
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
Integer subclass:#SmallInteger
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:'Magnitude-Numbers'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
SmallInteger comment:'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    21
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
    22
COPYRIGHT (c) 1988 by Claus Gittinger
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    23
              All Rights Reserved
a27a279701f8 Initial revision
claus
parents:
diff changeset
    24
44
b262907c93ea *** empty log message ***
claus
parents: 41
diff changeset
    25
$Header: /cvs/stx/stx/libbasic/SmallInteger.st,v 1.8 1994-01-16 03:46:48 claus Exp $
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    26
a27a279701f8 Initial revision
claus
parents:
diff changeset
    27
SmallIntegers are Integers in the range of +/- 2^30 (i.e. 31 bits).
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
    28
These are no real objects - they have no instances (not even storage !!)
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
    29
and cannot be subclassed.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    30
The reason is to save both storage and runtime by not collecting
a27a279701f8 Initial revision
claus
parents:
diff changeset
    31
SmallIntegers in the system. SmallInts are marked by having the TAG_INT 
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
    32
bit set in contrast to Objects which do not. Since this knowledge is 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    33
hardwired into the system (an there is no class-field stored with
a27a279701f8 Initial revision
claus
parents:
diff changeset
    34
SmallIntegers) there can be no subclass of SmallInteger (sorry).
a27a279701f8 Initial revision
claus
parents:
diff changeset
    35
'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    36
a27a279701f8 Initial revision
claus
parents:
diff changeset
    37
!SmallInteger class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    38
a27a279701f8 Initial revision
claus
parents:
diff changeset
    39
basicNew
a27a279701f8 Initial revision
claus
parents:
diff changeset
    40
    "catch instance creation
a27a279701f8 Initial revision
claus
parents:
diff changeset
    41
     - SmallIntegers cannot be created with new"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    42
a27a279701f8 Initial revision
claus
parents:
diff changeset
    43
    self error:'instances of SmallInteger cannot be created with new'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    44
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    45
a27a279701f8 Initial revision
claus
parents:
diff changeset
    46
basicNew:size
a27a279701f8 Initial revision
claus
parents:
diff changeset
    47
    "catch instance creation
a27a279701f8 Initial revision
claus
parents:
diff changeset
    48
     - SmallIntegers cannot be created with new"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    49
a27a279701f8 Initial revision
claus
parents:
diff changeset
    50
    self error:'instances of SmallInteger cannot be created with new'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    51
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
    52
a27a279701f8 Initial revision
claus
parents:
diff changeset
    53
!SmallInteger class methodsFor:'constants'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    54
a27a279701f8 Initial revision
claus
parents:
diff changeset
    55
maxBits
a27a279701f8 Initial revision
claus
parents:
diff changeset
    56
    "return the number of bits in instances of me"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    57
a27a279701f8 Initial revision
claus
parents:
diff changeset
    58
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
    59
    RETURN ( _MKSMALLINT(N_INT_BITS) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
    60
%}
2
claus
parents: 1
diff changeset
    61
claus
parents: 1
diff changeset
    62
    "SmallInteger maxBits"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    63
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    64
a27a279701f8 Initial revision
claus
parents:
diff changeset
    65
maxBytes
a27a279701f8 Initial revision
claus
parents:
diff changeset
    66
    "return the number of bytes in instances of me"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    67
a27a279701f8 Initial revision
claus
parents:
diff changeset
    68
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
    69
    RETURN ( _MKSMALLINT(N_INT_BITS / 8 + 1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
    70
%}
2
claus
parents: 1
diff changeset
    71
claus
parents: 1
diff changeset
    72
    "SmallInteger maxBytes"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    73
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    74
a27a279701f8 Initial revision
claus
parents:
diff changeset
    75
minVal
a27a279701f8 Initial revision
claus
parents:
diff changeset
    76
    "return the smallest Integer representable as SmallInteger"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    77
a27a279701f8 Initial revision
claus
parents:
diff changeset
    78
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
    79
    RETURN ( _MKSMALLINT(_MIN_INT) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
    80
%}
2
claus
parents: 1
diff changeset
    81
claus
parents: 1
diff changeset
    82
    "SmallInteger minVal"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    83
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    84
a27a279701f8 Initial revision
claus
parents:
diff changeset
    85
maxVal
a27a279701f8 Initial revision
claus
parents:
diff changeset
    86
    "return the largest Integer representable as SmallInteger"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    87
a27a279701f8 Initial revision
claus
parents:
diff changeset
    88
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
    89
    RETURN ( _MKSMALLINT(_MAX_INT) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
    90
%}
2
claus
parents: 1
diff changeset
    91
claus
parents: 1
diff changeset
    92
    "SmallInteger maxVal"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    93
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
    94
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
    95
!SmallInteger class methodsFor:'queries'!
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
    96
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
    97
isBuiltInClass
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
    98
    "this class is known by the run-time-system"
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
    99
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   100
    ^ true
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   101
! !
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   102
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   103
!SmallInteger methodsFor:'error catching'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   104
a27a279701f8 Initial revision
claus
parents:
diff changeset
   105
at:index
a27a279701f8 Initial revision
claus
parents:
diff changeset
   106
    "catch indexed access - report an error
a27a279701f8 Initial revision
claus
parents:
diff changeset
   107
     defined here since at: in Object ommits the SmallInteger check"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   108
a27a279701f8 Initial revision
claus
parents:
diff changeset
   109
    self notIndexed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   110
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   111
a27a279701f8 Initial revision
claus
parents:
diff changeset
   112
basicAt:index
a27a279701f8 Initial revision
claus
parents:
diff changeset
   113
    "catch indexed access - report an error
a27a279701f8 Initial revision
claus
parents:
diff changeset
   114
     defined here since basicAt: in Object ommits the SmallInteger check"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   115
a27a279701f8 Initial revision
claus
parents:
diff changeset
   116
    self notIndexed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   117
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   118
a27a279701f8 Initial revision
claus
parents:
diff changeset
   119
at:index put:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
   120
    "catch indexed access - report an error
a27a279701f8 Initial revision
claus
parents:
diff changeset
   121
     defined here since at:put: in Object ommits the SmallInteger check"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   122
a27a279701f8 Initial revision
claus
parents:
diff changeset
   123
    self notIndexed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   124
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   125
a27a279701f8 Initial revision
claus
parents:
diff changeset
   126
basicAt:index put:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
   127
    "catch indexed access - report an error
a27a279701f8 Initial revision
claus
parents:
diff changeset
   128
     defined here since basicAt:put: in Object ommits the SmallInteger check"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   129
a27a279701f8 Initial revision
claus
parents:
diff changeset
   130
    self notIndexed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   131
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   132
a27a279701f8 Initial revision
claus
parents:
diff changeset
   133
size
a27a279701f8 Initial revision
claus
parents:
diff changeset
   134
    "return the number of indexed instvars - SmallIntegers have none
a27a279701f8 Initial revision
claus
parents:
diff changeset
   135
     defined here since size in Object ommits the SmallInteger check"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   136
a27a279701f8 Initial revision
claus
parents:
diff changeset
   137
    ^ 0
a27a279701f8 Initial revision
claus
parents:
diff changeset
   138
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   139
a27a279701f8 Initial revision
claus
parents:
diff changeset
   140
basicSize
a27a279701f8 Initial revision
claus
parents:
diff changeset
   141
    "return the number of indexed instvars - SmallIntegers have none
a27a279701f8 Initial revision
claus
parents:
diff changeset
   142
     defined here since basicSize in Object ommits the SmallInteger check"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   143
a27a279701f8 Initial revision
claus
parents:
diff changeset
   144
    ^ 0
a27a279701f8 Initial revision
claus
parents:
diff changeset
   145
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   146
a27a279701f8 Initial revision
claus
parents:
diff changeset
   147
!SmallInteger methodsFor:'copying'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   148
a27a279701f8 Initial revision
claus
parents:
diff changeset
   149
shallowCopy
a27a279701f8 Initial revision
claus
parents:
diff changeset
   150
    "return a shallow copy of myself
2
claus
parents: 1
diff changeset
   151
     - reimplemented here since smallintegers are unique"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   152
a27a279701f8 Initial revision
claus
parents:
diff changeset
   153
    ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   154
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   155
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   156
simpleDeepCopy
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   157
    "return a deep copy of myself
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   158
     - reimplemented here since smallintegers are unique"
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   159
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   160
    ^ self
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   161
!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   162
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   163
deepCopyUsing:aDictionary
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   164
    "return a deep copy of myself
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   165
     - reimplemented here since smallintegers are unique"
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   166
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   167
    ^ self
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   168
!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   169
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   170
deepCopy
a27a279701f8 Initial revision
claus
parents:
diff changeset
   171
    "return a deep copy of myself
2
claus
parents: 1
diff changeset
   172
     - reimplemented here since smallintegers are unique"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   173
a27a279701f8 Initial revision
claus
parents:
diff changeset
   174
    ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   175
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   176
a27a279701f8 Initial revision
claus
parents:
diff changeset
   177
!SmallInteger methodsFor:'comparing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   178
a27a279701f8 Initial revision
claus
parents:
diff changeset
   179
= aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   180
    "return true, if the arguments value is equal to mine"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   181
a27a279701f8 Initial revision
claus
parents:
diff changeset
   182
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   183
a27a279701f8 Initial revision
claus
parents:
diff changeset
   184
    if (aNumber == self) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   185
        RETURN ( true );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   186
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   187
    if (! _isNonNilObject(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   188
        RETURN ( false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   189
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   190
a27a279701f8 Initial revision
claus
parents:
diff changeset
   191
    if (_qClass(aNumber) == Float) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   192
        RETURN ( ((double)_intVal(self) == _floatVal(aNumber)) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   193
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   194
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   195
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   196
    aNumber respondsToArithmetic ifFalse:[^ false].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   197
    ^ self retry:#= coercing:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   198
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   199
a27a279701f8 Initial revision
claus
parents:
diff changeset
   200
~= aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   201
    "return true, if the arguments value is not equal to mine"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   202
a27a279701f8 Initial revision
claus
parents:
diff changeset
   203
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   204
a27a279701f8 Initial revision
claus
parents:
diff changeset
   205
    if (aNumber == self) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   206
        RETURN ( false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   207
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   208
    if (! _isNonNilObject(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   209
        RETURN ( true );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   210
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   211
a27a279701f8 Initial revision
claus
parents:
diff changeset
   212
    if (_qClass(aNumber) == Float) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   213
        RETURN ( ((double)_intVal(self) == _floatVal(aNumber)) ? false : true );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   214
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   215
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   216
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   217
    aNumber respondsToArithmetic ifFalse:[^ true].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   218
    ^ self retry:#~= coercing:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   219
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   220
a27a279701f8 Initial revision
claus
parents:
diff changeset
   221
< aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   222
    "return true, if the argument is greater than the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   223
a27a279701f8 Initial revision
claus
parents:
diff changeset
   224
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   225
a27a279701f8 Initial revision
claus
parents:
diff changeset
   226
    if (_isSmallInteger(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   227
#ifdef POSITIVE_ADDRESSES
a27a279701f8 Initial revision
claus
parents:
diff changeset
   228
        RETURN ( (_intVal(self) < _intVal(aNumber)) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   229
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   230
        /* tag bit does not change ordering */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   231
        RETURN ( ((INT)self < (INT)aNumber) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   232
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   233
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   234
    if (_isFloat(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   235
        RETURN ( ((double)_intVal(self) < _floatVal(aNumber)) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   236
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   237
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   238
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   239
    ^ aNumber lessFromInteger:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   240
    "^ self retry:#< coercing:aNumber"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   241
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   242
a27a279701f8 Initial revision
claus
parents:
diff changeset
   243
> aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   244
    "return true, if the argument is less than the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   245
a27a279701f8 Initial revision
claus
parents:
diff changeset
   246
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   247
a27a279701f8 Initial revision
claus
parents:
diff changeset
   248
    if (_isSmallInteger(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   249
#ifdef POSITIVE_ADDRESSES
a27a279701f8 Initial revision
claus
parents:
diff changeset
   250
        RETURN ( (_intVal(self) > _intVal(aNumber)) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   251
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   252
        /* tag bit does not change ordering */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   253
        RETURN ( ((INT)self > (INT)aNumber) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   254
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   255
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   256
    if (_isFloat(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   257
        RETURN ( ((double)_intVal(self) > _floatVal(aNumber)) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   258
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   259
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   260
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   261
    ^ self retry:#> coercing:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   262
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   263
a27a279701f8 Initial revision
claus
parents:
diff changeset
   264
>= aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   265
    "return true, if the argument is less or equal"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   266
a27a279701f8 Initial revision
claus
parents:
diff changeset
   267
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   268
a27a279701f8 Initial revision
claus
parents:
diff changeset
   269
    if (_isSmallInteger(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   270
#ifdef POSITIVE_ADDRESSES
a27a279701f8 Initial revision
claus
parents:
diff changeset
   271
        RETURN ( (_intVal(self) >= _intVal(aNumber)) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   272
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   273
        /* tag bit does not change ordering */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   274
        RETURN ( ((INT)self >= (INT)aNumber) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   275
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   276
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   277
    if (_isFloat(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   278
        RETURN ( ((double)_intVal(self) >= _floatVal(aNumber)) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   279
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   280
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   281
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   282
    ^ self retry:#>= coercing:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   283
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   284
a27a279701f8 Initial revision
claus
parents:
diff changeset
   285
<= aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   286
    "return true, if the argument is greater or equal"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   287
a27a279701f8 Initial revision
claus
parents:
diff changeset
   288
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   289
a27a279701f8 Initial revision
claus
parents:
diff changeset
   290
    if (_isSmallInteger(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   291
#ifdef POSITIVE_ADDRESSES
a27a279701f8 Initial revision
claus
parents:
diff changeset
   292
        RETURN ( (_intVal(self) <= _intVal(aNumber)) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   293
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   294
        /* tag bit does not change ordering */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   295
        RETURN ( ((INT)self <= (INT)aNumber) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   296
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   297
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   298
    if (_isFloat(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   299
        RETURN ( ((double)_intVal(self) <= _floatVal(aNumber)) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   300
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   301
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   302
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   303
    ^ self retry:#<= coercing:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   304
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   305
a27a279701f8 Initial revision
claus
parents:
diff changeset
   306
identityHash
a27a279701f8 Initial revision
claus
parents:
diff changeset
   307
    "return an integer useful for hashing on identity"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   308
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   309
    self >= 0 ifTrue:[
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   310
        ^ self + 8192
a27a279701f8 Initial revision
claus
parents:
diff changeset
   311
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   312
    ^ self negated + 8192
a27a279701f8 Initial revision
claus
parents:
diff changeset
   313
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   314
a27a279701f8 Initial revision
claus
parents:
diff changeset
   315
min:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   316
    "return the receiver or the argument, whichever is smaller"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   317
a27a279701f8 Initial revision
claus
parents:
diff changeset
   318
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   319
a27a279701f8 Initial revision
claus
parents:
diff changeset
   320
    if (_isSmallInteger(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   321
#ifdef POSITIVE_ADDRESSES
a27a279701f8 Initial revision
claus
parents:
diff changeset
   322
        if (_intVal(self) < _intVal(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   323
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   324
        /* tag bit does not change ordering */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   325
        if ((INT)(self) < (INT)(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   326
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   327
            RETURN ( self );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   328
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   329
        RETURN ( aNumber );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   330
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   331
    if (_isFloat(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   332
        if ( (double)_intVal(self) < _floatVal(aNumber) ) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   333
            RETURN ( self );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   334
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   335
        RETURN ( aNumber );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   336
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   337
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   338
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   339
    (self < aNumber) ifTrue:[^ self].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   340
    ^ aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   341
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   342
a27a279701f8 Initial revision
claus
parents:
diff changeset
   343
max:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   344
    "return the receiver or the argument, whichever is greater"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   345
a27a279701f8 Initial revision
claus
parents:
diff changeset
   346
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   347
a27a279701f8 Initial revision
claus
parents:
diff changeset
   348
    if (_isSmallInteger(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   349
#ifdef POSITIVE_ADDRESSES
a27a279701f8 Initial revision
claus
parents:
diff changeset
   350
        if (_intVal(self) > _intVal(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   351
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   352
        /* tag bit does not change ordering */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   353
        if ((INT)(self) > (INT)(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   354
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   355
            RETURN ( self );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   356
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   357
        RETURN ( aNumber );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   358
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   359
    if (_isFloat(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   360
        if ( (double)_intVal(self) > _floatVal(aNumber) ) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   361
            RETURN ( self );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   362
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   363
        RETURN ( aNumber );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   364
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   365
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   366
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   367
    (self > aNumber) ifTrue:[^ self].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   368
    ^ aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   369
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   370
a27a279701f8 Initial revision
claus
parents:
diff changeset
   371
!SmallInteger methodsFor:'testing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   372
a27a279701f8 Initial revision
claus
parents:
diff changeset
   373
negative
a27a279701f8 Initial revision
claus
parents:
diff changeset
   374
    "return true, if the receiver is less than zero
a27a279701f8 Initial revision
claus
parents:
diff changeset
   375
     reimplemented here for speed"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   376
a27a279701f8 Initial revision
claus
parents:
diff changeset
   377
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   378
a27a279701f8 Initial revision
claus
parents:
diff changeset
   379
#ifdef POSITIVE_ADDRESSES
a27a279701f8 Initial revision
claus
parents:
diff changeset
   380
    RETURN ( (_intVal(self) < 0) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   381
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   382
    /* tag bit does not change sign */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   383
    RETURN ( ((INT)(self) < 0) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   384
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   385
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   386
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   387
a27a279701f8 Initial revision
claus
parents:
diff changeset
   388
positive
a27a279701f8 Initial revision
claus
parents:
diff changeset
   389
    "return true, if the receiver is not negative
a27a279701f8 Initial revision
claus
parents:
diff changeset
   390
     reimplemented here for speed"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   391
a27a279701f8 Initial revision
claus
parents:
diff changeset
   392
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   393
a27a279701f8 Initial revision
claus
parents:
diff changeset
   394
#ifdef POSITIVE_ADDRESSES
a27a279701f8 Initial revision
claus
parents:
diff changeset
   395
    RETURN ( (_intVal(self) >= 0) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   396
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   397
    /* tag bit does not change sign */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   398
    RETURN ( ((INT)(self) >= 0) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   399
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   400
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   401
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   402
a27a279701f8 Initial revision
claus
parents:
diff changeset
   403
strictlyPositive
a27a279701f8 Initial revision
claus
parents:
diff changeset
   404
    "return true, if the receiver is greater than zero
a27a279701f8 Initial revision
claus
parents:
diff changeset
   405
     reimplemented here for speed"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   406
a27a279701f8 Initial revision
claus
parents:
diff changeset
   407
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   408
a27a279701f8 Initial revision
claus
parents:
diff changeset
   409
#ifdef POSITIVE_ADDRESSES
a27a279701f8 Initial revision
claus
parents:
diff changeset
   410
    RETURN ( (_intVal(self) > 0) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   411
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   412
    /* tag bit does not change sign */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   413
    RETURN ( ((INT)(self) > 0) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   414
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   415
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   416
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   417
a27a279701f8 Initial revision
claus
parents:
diff changeset
   418
sign
a27a279701f8 Initial revision
claus
parents:
diff changeset
   419
    "return the sign of the receiver
a27a279701f8 Initial revision
claus
parents:
diff changeset
   420
     reimplemented here for speed"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   421
a27a279701f8 Initial revision
claus
parents:
diff changeset
   422
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   423
a27a279701f8 Initial revision
claus
parents:
diff changeset
   424
    INT val = _intVal(self);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   425
a27a279701f8 Initial revision
claus
parents:
diff changeset
   426
    if (val < 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   427
        RETURN ( _MKSMALLINT(-1) ); 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   428
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   429
    if (val > 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   430
        RETURN ( _MKSMALLINT(1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   431
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   432
    RETURN ( _MKSMALLINT(0) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   433
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   434
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   435
a27a279701f8 Initial revision
claus
parents:
diff changeset
   436
between:min and:max
a27a279701f8 Initial revision
claus
parents:
diff changeset
   437
    "return true if the receiver is less than or equal to the argument max
a27a279701f8 Initial revision
claus
parents:
diff changeset
   438
     and greater than or equal to the argument min.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   439
     - reimplemented here for speed"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   440
a27a279701f8 Initial revision
claus
parents:
diff changeset
   441
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   442
a27a279701f8 Initial revision
claus
parents:
diff changeset
   443
    if (_isSmallInteger(min) && _isSmallInteger(max)) {
2
claus
parents: 1
diff changeset
   444
        REGISTER INT selfVal;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   445
2
claus
parents: 1
diff changeset
   446
        selfVal = _intVal(self);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   447
        if (selfVal < _intVal(min)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   448
             RETURN ( false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   449
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   450
        if (selfVal > _intVal(max)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   451
             RETURN ( false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   452
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   453
        RETURN ( true );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   454
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   455
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   456
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   457
    (self < min) ifTrue:[^ false].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   458
    (self > max) ifTrue:[^ false].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   459
    ^ true
a27a279701f8 Initial revision
claus
parents:
diff changeset
   460
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   461
a27a279701f8 Initial revision
claus
parents:
diff changeset
   462
even
a27a279701f8 Initial revision
claus
parents:
diff changeset
   463
    "return true, if the receiver is even"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   464
a27a279701f8 Initial revision
claus
parents:
diff changeset
   465
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   466
a27a279701f8 Initial revision
claus
parents:
diff changeset
   467
#ifdef POSITIVE_ADDRESSES
a27a279701f8 Initial revision
claus
parents:
diff changeset
   468
    RETURN ( ((INT)self & 1) ? false : true );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   469
#else    
a27a279701f8 Initial revision
claus
parents:
diff changeset
   470
    RETURN ( ((INT)self & ((INT)_MKSMALLINT(1) & ~TAG_INT)) ? false : true );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   471
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   472
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   473
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   474
a27a279701f8 Initial revision
claus
parents:
diff changeset
   475
odd
a27a279701f8 Initial revision
claus
parents:
diff changeset
   476
    "return true, if the receiver is odd"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   477
a27a279701f8 Initial revision
claus
parents:
diff changeset
   478
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   479
a27a279701f8 Initial revision
claus
parents:
diff changeset
   480
#ifdef POSITIVE_ADDRESSES
a27a279701f8 Initial revision
claus
parents:
diff changeset
   481
    RETURN ( ((INT)self & 1) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   482
#else    
a27a279701f8 Initial revision
claus
parents:
diff changeset
   483
    RETURN ( ((INT)self & ((INT)_MKSMALLINT(1) & ~TAG_INT)) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   484
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   485
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   486
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   487
a27a279701f8 Initial revision
claus
parents:
diff changeset
   488
!SmallInteger methodsFor:'arithmetic'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   489
a27a279701f8 Initial revision
claus
parents:
diff changeset
   490
+ aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   491
    "return the sum of the receivers value and the arguments value"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   492
a27a279701f8 Initial revision
claus
parents:
diff changeset
   493
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   494
a27a279701f8 Initial revision
claus
parents:
diff changeset
   495
    if (_isSmallInteger(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   496
#ifdef _ADD_IO_IO
2
claus
parents: 1
diff changeset
   497
        RETURN ( _ADD_IO_IO(self, aNumber) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   498
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   499
        REGISTER INT sum;
2
claus
parents: 1
diff changeset
   500
        extern OBJ _makeLarge();
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   501
a27a279701f8 Initial revision
claus
parents:
diff changeset
   502
        sum =  _intVal(self) + _intVal(aNumber);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   503
        if ((sum >= _MIN_INT) && (sum <= _MAX_INT)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   504
            RETURN ( _MKSMALLINT(sum) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   505
        }
2
claus
parents: 1
diff changeset
   506
        RETURN ( _makeLarge(sum) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   507
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   508
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   509
    if ((aNumber != nil) && (_qClass(aNumber) == Float)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   510
        extern char *newNextPtr, *newEndPtr;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   511
        OBJ newFloat;
2
claus
parents: 1
diff changeset
   512
        double val;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   513
2
claus
parents: 1
diff changeset
   514
        val = _floatVal(aNumber);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   515
        _qAlignedNew(newFloat, sizeof(struct floatstruct), SENDER);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   516
        _InstPtr(newFloat)->o_class = Float;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   517
        _FloatInstPtr(newFloat)->f_floatvalue = (double)(_intVal(self)) + val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   518
        RETURN ( newFloat );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   519
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   520
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   521
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   522
    ^ aNumber sumFromInteger:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   523
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   524
a27a279701f8 Initial revision
claus
parents:
diff changeset
   525
- aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   526
    "return the difference of the receivers value and the arguments value"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   527
a27a279701f8 Initial revision
claus
parents:
diff changeset
   528
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   529
a27a279701f8 Initial revision
claus
parents:
diff changeset
   530
    if (_isSmallInteger(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   531
#ifdef _SUB_IO_IO
2
claus
parents: 1
diff changeset
   532
        RETURN ( _SUB_IO_IO(self, aNumber) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   533
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   534
        REGISTER INT diff;
2
claus
parents: 1
diff changeset
   535
        extern OBJ _makeLarge();
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   536
a27a279701f8 Initial revision
claus
parents:
diff changeset
   537
        diff =  _intVal(self) - _intVal(aNumber);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   538
        if ((diff >= _MIN_INT) && (diff <= _MAX_INT)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   539
            RETURN ( _MKSMALLINT(diff) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   540
        }
2
claus
parents: 1
diff changeset
   541
        RETURN ( _makeLarge(diff) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   542
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   543
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   544
    if ((aNumber != nil) && (_qClass(aNumber) == Float)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   545
        extern char *newNextPtr, *newEndPtr;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   546
        OBJ newFloat;
2
claus
parents: 1
diff changeset
   547
        double val;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   548
2
claus
parents: 1
diff changeset
   549
        val = _floatVal(aNumber);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   550
        _qAlignedNew(newFloat, sizeof(struct floatstruct), SENDER);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   551
        _InstPtr(newFloat)->o_class = Float;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   552
        _FloatInstPtr(newFloat)->f_floatvalue = (double)(_intVal(self)) - val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   553
        RETURN ( newFloat );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   554
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   555
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   556
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   557
    ^ aNumber differenceFromInteger:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   558
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   559
a27a279701f8 Initial revision
claus
parents:
diff changeset
   560
* aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   561
    "return the product of the receivers value and the arguments value"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   562
a27a279701f8 Initial revision
claus
parents:
diff changeset
   563
    |aLarge|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   564
a27a279701f8 Initial revision
claus
parents:
diff changeset
   565
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   566
a27a279701f8 Initial revision
claus
parents:
diff changeset
   567
    REGISTER INT myValue, otherValue;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   568
    unsigned INT pHH, pHL, pLH, pLL;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   569
a27a279701f8 Initial revision
claus
parents:
diff changeset
   570
    if (_isSmallInteger(aNumber)) {
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   571
        myValue = _intVal(self);
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   572
        otherValue = _intVal(aNumber);
44
b262907c93ea *** empty log message ***
claus
parents: 41
diff changeset
   573
#if defined(NOTDEF) && defined(__GNUC__) && (__GNUC__ >= 2)
41
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
   574
        {
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
   575
            long long product;
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   576
41
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
   577
            product = myValue * otherValue;
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
   578
            if ((product >= (long long)_MIN_INT) 
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
   579
             && (product <= (long long)_MAX_INT)) {
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
   580
                RETURN ( _MKSMALLINT((int)product) );
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
   581
            }
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
   582
        }
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   583
#else
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   584
        /* this is too slow:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   585
         * since most machines can do 32*32 to 64 bit multiply,
a27a279701f8 Initial revision
claus
parents:
diff changeset
   586
         * (or at least 32*32 with Overflow check)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   587
         * its better to do it this way .. - need an assembler (inline) function here 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   588
         */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   589
        if (myValue < 0) myValue = -myValue;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   590
        if (otherValue < 0) otherValue = -otherValue;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   591
        pHH = ((myValue >> 16) & 0xFFFF) * ((otherValue >> 16) & 0xFFFF);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   592
        pHL = ((myValue >> 16) & 0xFFFF) * (otherValue & 0xFFFF);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   593
        pLH = (myValue & 0xFFFF) * ((otherValue >> 16) & 0xFFFF);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   594
        pLL = (myValue & 0xFFFF) * (otherValue & 0xFFFF);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   595
        if (! (pHH || (pHL & 0xFFFFc000) || (pLH & 0xFFFFc000) || (pLL & 0xc0000000))) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   596
            RETURN ( _MKSMALLINT(_intVal(self) * _intVal(aNumber)) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   597
        }
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   598
#endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   599
    } else if ((aNumber != nil) && (_qClass(aNumber) == Float)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   600
        extern char *newNextPtr, *newEndPtr;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   601
        OBJ newFloat;
2
claus
parents: 1
diff changeset
   602
        double val;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   603
2
claus
parents: 1
diff changeset
   604
        val = _floatVal(aNumber);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   605
        _qAlignedNew(newFloat, sizeof(struct floatstruct), SENDER);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   606
        _InstPtr(newFloat)->o_class = Float;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   607
        _FloatInstPtr(newFloat)->f_floatvalue = (double)(_intVal(self)) * val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   608
        RETURN ( newFloat );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   609
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   610
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   611
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   612
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
   613
    extern OBJ LargeInteger, __mu, _value_;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   614
    static struct inlineCache val = _ILC1;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   615
    static struct inlineCache mu = _ILC1;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   616
a27a279701f8 Initial revision
claus
parents:
diff changeset
   617
    if (_isSmallInteger(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   618
        /*
a27a279701f8 Initial revision
claus
parents:
diff changeset
   619
         * non overflow case has already been checked
a27a279701f8 Initial revision
claus
parents:
diff changeset
   620
         */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   621
        aLarge = (*val.ilc_func)(LargeInteger, _value_, CON_COMMA nil, &val, self);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   622
        RETURN ( (*mu.ilc_func)(aLarge, __mu, CON_COMMA nil, &mu, aNumber) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   623
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   624
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   625
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   626
    ^ aNumber productFromInteger:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   627
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   628
a27a279701f8 Initial revision
claus
parents:
diff changeset
   629
/ aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   630
    "return the quotient of the receivers value and the arguments value"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   631
a27a279701f8 Initial revision
claus
parents:
diff changeset
   632
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   633
a27a279701f8 Initial revision
claus
parents:
diff changeset
   634
    INT me, t, val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   635
    double dval;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   636
a27a279701f8 Initial revision
claus
parents:
diff changeset
   637
    if (_isSmallInteger(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   638
        val = _intVal(aNumber);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   639
        if (val != 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   640
            me = _intVal(self);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   641
            t = me / val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   642
#ifdef GOOD_OPTIMIZER
a27a279701f8 Initial revision
claus
parents:
diff changeset
   643
            if (me % val) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   644
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   645
            /* this is stupid - all I want is to look for a remainder ... 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   646
               but most compilers are too stupid and generate an extra mod instr.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   647
               for "if (me % val)" even if most div instructions also compute
a27a279701f8 Initial revision
claus
parents:
diff changeset
   648
               the remainder.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   649
               therefore I use a multiplication which is faster than a modulu
a27a279701f8 Initial revision
claus
parents:
diff changeset
   650
               on most machines
a27a279701f8 Initial revision
claus
parents:
diff changeset
   651
            */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   652
            if ((t * val) == me) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   653
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   654
                RETURN ( _MKSMALLINT(t) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   655
            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   656
/*
a27a279701f8 Initial revision
claus
parents:
diff changeset
   657
 * now disabled - Fractions work
a27a279701f8 Initial revision
claus
parents:
diff changeset
   658
 *
a27a279701f8 Initial revision
claus
parents:
diff changeset
   659
            RETURN ( _MKFLOAT((double)_intVal(self) / (double)val, __context) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   660
*/
a27a279701f8 Initial revision
claus
parents:
diff changeset
   661
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   662
    } else {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   663
        if (_isFloat(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   664
            dval = _floatVal(aNumber);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   665
            if (dval != 0.0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   666
                me = _intVal(self);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   667
                RETURN ( _MKFLOAT((double)me / dval COMMA_CON) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   668
            }
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   669
        }
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   670
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   671
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   672
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   673
    aNumber isInteger ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   674
        aNumber = 0 ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   675
            DivisionByZeroSignal raise.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   676
            ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   677
        ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   678
        ^ Fraction numerator:self denominator:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   679
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   680
    ^ aNumber quotientFromInteger:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   681
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   682
2
claus
parents: 1
diff changeset
   683
// aNumber
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   684
    "return the integer part of the quotient of the receivers value
a27a279701f8 Initial revision
claus
parents:
diff changeset
   685
     and the arguments value"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   686
a27a279701f8 Initial revision
claus
parents:
diff changeset
   687
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   688
    INT val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   689
2
claus
parents: 1
diff changeset
   690
    if (_isSmallInteger(aNumber)) {
claus
parents: 1
diff changeset
   691
        val = _intVal(aNumber);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   692
        if (val != 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   693
            RETURN ( _MKSMALLINT(_intVal(self) / val) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   694
        }
2
claus
parents: 1
diff changeset
   695
    } else {
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   696
        if (_isFraction(aNumber)) {
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   697
            OBJ t;
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   698
            INT num, den;
2
claus
parents: 1
diff changeset
   699
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   700
            t = _FractionInstPtr(aNumber)->f_numerator;
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   701
            if (_isSmallInteger(t)) {
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   702
                num = _intVal(t);
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   703
                t = _FractionInstPtr(aNumber)->f_denominator;
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   704
                if (_isSmallInteger(t)) {
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   705
                    den = _intVal(t);
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   706
                    RETURN ( _MKSMALLINT(_intVal(self) * den / num ));
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   707
                }
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   708
            }
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   709
        }
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   710
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   711
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   712
.
2
claus
parents: 1
diff changeset
   713
    (aNumber = 0) ifTrue:[
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   714
        DivisionByZeroSignal raise.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   715
        ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   716
    ].
2
claus
parents: 1
diff changeset
   717
    ^ self retry:#// coercing:aNumber
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   718
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   719
2
claus
parents: 1
diff changeset
   720
\\ aNumber
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   721
    "return the integer rest of the receivers value
a27a279701f8 Initial revision
claus
parents:
diff changeset
   722
     divided by the arguments value"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   723
a27a279701f8 Initial revision
claus
parents:
diff changeset
   724
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   725
    INT mySelf, val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   726
2
claus
parents: 1
diff changeset
   727
    if (_isSmallInteger(aNumber)) {
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   728
        mySelf = _intVal(self);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   729
        if (mySelf < 0) mySelf = -mySelf;
2
claus
parents: 1
diff changeset
   730
        val = _intVal(aNumber);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   731
        if (val != 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   732
            if (val < 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   733
                RETURN ( _MKSMALLINT(-(mySelf % -val)) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   734
            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   735
            RETURN ( _MKSMALLINT(mySelf % val) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   736
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   737
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   738
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   739
.
2
claus
parents: 1
diff changeset
   740
    (aNumber = 0) ifTrue:[
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   741
        DivisionByZeroSignal raise.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   742
        ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   743
    ].
2
claus
parents: 1
diff changeset
   744
    ^ self retry:#\\ coercing:aNumber
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   745
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   746
a27a279701f8 Initial revision
claus
parents:
diff changeset
   747
abs
a27a279701f8 Initial revision
claus
parents:
diff changeset
   748
    "return the absolute value of the receiver
a27a279701f8 Initial revision
claus
parents:
diff changeset
   749
     reimplemented here for speed"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   750
a27a279701f8 Initial revision
claus
parents:
diff changeset
   751
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   752
a27a279701f8 Initial revision
claus
parents:
diff changeset
   753
    INT val = _intVal(self);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   754
a27a279701f8 Initial revision
claus
parents:
diff changeset
   755
    if (val != _MIN_INT) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   756
        RETURN ( (val < 0) ? _MKSMALLINT(-val) : self );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   757
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   758
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   759
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   760
    "only reached for minVal"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   761
    ^ self negated
a27a279701f8 Initial revision
claus
parents:
diff changeset
   762
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   763
a27a279701f8 Initial revision
claus
parents:
diff changeset
   764
negated
a27a279701f8 Initial revision
claus
parents:
diff changeset
   765
    "return the negative value of the receiver
a27a279701f8 Initial revision
claus
parents:
diff changeset
   766
     reimplemented here for speed"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   767
a27a279701f8 Initial revision
claus
parents:
diff changeset
   768
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   769
a27a279701f8 Initial revision
claus
parents:
diff changeset
   770
    INT val = _intVal(self);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   771
a27a279701f8 Initial revision
claus
parents:
diff changeset
   772
    if (val != _MIN_INT) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   773
        RETURN ( _MKSMALLINT(- val) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   774
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   775
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   776
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   777
    ^ (LargeInteger value:(SmallInteger maxVal)) + 1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   778
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   779
a27a279701f8 Initial revision
claus
parents:
diff changeset
   780
!SmallInteger methodsFor:'modulu arithmetic'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   781
a27a279701f8 Initial revision
claus
parents:
diff changeset
   782
times:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   783
    "return the product of the receiver and the argument as SmallInteger. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   784
     If the result overflows integer range the value modulu the SmallInteger 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   785
     range is returned.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   786
     This is of course not always correct, but some code does a modulu anyway
a27a279701f8 Initial revision
claus
parents:
diff changeset
   787
     and can therefore speed things up by not going through LargeIntegers."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   788
a27a279701f8 Initial revision
claus
parents:
diff changeset
   789
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   790
a27a279701f8 Initial revision
claus
parents:
diff changeset
   791
    if (_isSmallInteger(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   792
        RETURN ( _MKSMALLINT((_intVal(self) * _intVal(aNumber)) & 0x7FFFFFFF) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   793
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   794
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   795
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   796
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   797
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   798
a27a279701f8 Initial revision
claus
parents:
diff changeset
   799
plus:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   800
    "return the sum of the receiver and the argument as SmallInteger.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   801
     If the result overflows integer range, the value modulu the SmallInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   802
     range is returned.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   803
     This is of course not always correct, but some code does a modulu anyway
a27a279701f8 Initial revision
claus
parents:
diff changeset
   804
     and can therefore speed things up by not going through LargeIntegers."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   805
a27a279701f8 Initial revision
claus
parents:
diff changeset
   806
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   807
a27a279701f8 Initial revision
claus
parents:
diff changeset
   808
    if (_isSmallInteger(aNumber)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   809
        RETURN ( _MKSMALLINT((_intVal(self) + _intVal(aNumber)) & 0x7FFFFFFF) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   810
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   811
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   812
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   813
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   814
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   815
a27a279701f8 Initial revision
claus
parents:
diff changeset
   816
!SmallInteger class methodsFor:'bit mask constants'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   817
a27a279701f8 Initial revision
claus
parents:
diff changeset
   818
bitMaskFor:index
a27a279701f8 Initial revision
claus
parents:
diff changeset
   819
    "return a bitmask for the index's bit (index starts at 1)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   820
a27a279701f8 Initial revision
claus
parents:
diff changeset
   821
    (index between:1 and:SmallInteger maxBits) ifFalse:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   822
        ^ self error:'index out of bounds'
a27a279701f8 Initial revision
claus
parents:
diff changeset
   823
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   824
    ^ 1 bitShift:(index - 1)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   825
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   826
a27a279701f8 Initial revision
claus
parents:
diff changeset
   827
!SmallInteger methodsFor:'bit operators'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   828
a27a279701f8 Initial revision
claus
parents:
diff changeset
   829
bitAt:index
a27a279701f8 Initial revision
claus
parents:
diff changeset
   830
    "return the value of the index's bit (index starts at 1)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   831
a27a279701f8 Initial revision
claus
parents:
diff changeset
   832
    |mask|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   833
a27a279701f8 Initial revision
claus
parents:
diff changeset
   834
    (index between:1 and:SmallInteger maxBits) ifFalse:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   835
        ^ self error:'index out of bounds'
a27a279701f8 Initial revision
claus
parents:
diff changeset
   836
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   837
    mask := 1 bitShift:(index - 1).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   838
    ((self bitAnd:mask) == 0) ifTrue:[^ 0].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   839
    ^ 1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   840
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   841
a27a279701f8 Initial revision
claus
parents:
diff changeset
   842
allMask:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   843
    "True if all bits in anInteger are 1 in the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   844
a27a279701f8 Initial revision
claus
parents:
diff changeset
   845
    ^(self bitAnd:anInteger) == anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   846
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   847
a27a279701f8 Initial revision
claus
parents:
diff changeset
   848
anyMask:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   849
    "True if any 1 bits in anInteger are 1 in the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   850
a27a279701f8 Initial revision
claus
parents:
diff changeset
   851
    ^(self bitAnd:anInteger) ~~ 0
a27a279701f8 Initial revision
claus
parents:
diff changeset
   852
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   853
a27a279701f8 Initial revision
claus
parents:
diff changeset
   854
noMask:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   855
    "True if no 1 bits in anInteger are 1 in the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   856
a27a279701f8 Initial revision
claus
parents:
diff changeset
   857
    ^(self bitAnd:anInteger) == 0
a27a279701f8 Initial revision
claus
parents:
diff changeset
   858
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   859
a27a279701f8 Initial revision
claus
parents:
diff changeset
   860
highBit
a27a279701f8 Initial revision
claus
parents:
diff changeset
   861
    "return the bitIndex of the highest bit set"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   862
a27a279701f8 Initial revision
claus
parents:
diff changeset
   863
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   864
a27a279701f8 Initial revision
claus
parents:
diff changeset
   865
    INT mask, index, bits;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   866
a27a279701f8 Initial revision
claus
parents:
diff changeset
   867
    bits = _intVal(self);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   868
    if (bits == 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   869
        RETURN ( _MKSMALLINT(-1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   870
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   871
#ifdef alpha
a27a279701f8 Initial revision
claus
parents:
diff changeset
   872
    mask = 0x2000000000000000;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   873
    index = 62;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   874
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   875
    mask = 0x20000000;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   876
    index = 30;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   877
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   878
    while (index) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   879
        if (bits & mask) break;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   880
        mask = mask >> 1;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   881
        index--;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   882
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   883
    RETURN ( _MKSMALLINT(index) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   884
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   885
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   886
a27a279701f8 Initial revision
claus
parents:
diff changeset
   887
lowBit
a27a279701f8 Initial revision
claus
parents:
diff changeset
   888
    "return the bitIndex of the lowest bit set"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   889
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   890
a27a279701f8 Initial revision
claus
parents:
diff changeset
   891
    INT mask, index, bits;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   892
a27a279701f8 Initial revision
claus
parents:
diff changeset
   893
    bits = _intVal(self);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   894
    if (bits == 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   895
        RETURN ( _MKSMALLINT(-1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   896
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   897
    mask = 1;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   898
    index = 1;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   899
#ifdef alpha
a27a279701f8 Initial revision
claus
parents:
diff changeset
   900
    while (index != 63) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   901
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   902
    while (index != 31) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   903
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   904
        if (bits & mask) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   905
            RETURN ( _MKSMALLINT(index) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   906
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   907
        mask = mask << 1;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   908
        index++;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   909
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   910
    RETURN ( _MKSMALLINT(-1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   911
    /* notreached */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   912
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   913
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   914
a27a279701f8 Initial revision
claus
parents:
diff changeset
   915
bitShift:shiftCount
a27a279701f8 Initial revision
claus
parents:
diff changeset
   916
    "return the value of the receiver shifted by shiftCount bits;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   917
     leftShift if shiftCount > 0; rightShift otherwise"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   918
a27a279701f8 Initial revision
claus
parents:
diff changeset
   919
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   920
a27a279701f8 Initial revision
claus
parents:
diff changeset
   921
    INT bits, count;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   922
a27a279701f8 Initial revision
claus
parents:
diff changeset
   923
    if (_isSmallInteger(shiftCount)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   924
        count = _intVal(shiftCount);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   925
        bits = _intVal(self);
a27a279701f8 Initial revision
claus
parents:
diff changeset
   926
        if (count > 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   927
            RETURN ( _MKSMALLINT(bits << count) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   928
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   929
        if (count < 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   930
            RETURN ( _MKSMALLINT(bits >> -count) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   931
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   932
        RETURN (self );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   933
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   934
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   935
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   936
    ^ self bitShift:(shiftCount coerce:1)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   937
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   938
a27a279701f8 Initial revision
claus
parents:
diff changeset
   939
bitOr:anInteger
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   940
    "return the bitwise-or of the receiver and the argument, anInteger"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   941
a27a279701f8 Initial revision
claus
parents:
diff changeset
   942
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   943
a27a279701f8 Initial revision
claus
parents:
diff changeset
   944
    /* oring the tags doesn't change it */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   945
    if (_isSmallInteger(anInteger)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   946
        RETURN ( ((OBJ) ((INT)self | (INT)anInteger)) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   947
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   948
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   949
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   950
    ^ self retry:#bitOr coercing:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   951
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   952
a27a279701f8 Initial revision
claus
parents:
diff changeset
   953
bitAnd:anInteger
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   954
    "return the bitwise-and of the receiver and the argument, anInteger"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   955
a27a279701f8 Initial revision
claus
parents:
diff changeset
   956
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   957
a27a279701f8 Initial revision
claus
parents:
diff changeset
   958
    /* anding the tags doesn't change it */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   959
    if (_isSmallInteger(anInteger)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   960
        RETURN ( ((OBJ) ((INT)self & (INT)anInteger)) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   961
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   962
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   963
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   964
    ^ self retry:#bitAnd coercing:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   965
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   966
a27a279701f8 Initial revision
claus
parents:
diff changeset
   967
bitXor:anInteger
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   968
    "return the bitwise-exclusive-or of the receiver and the argument, anInteger"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   969
a27a279701f8 Initial revision
claus
parents:
diff changeset
   970
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   971
a27a279701f8 Initial revision
claus
parents:
diff changeset
   972
    /* xoring the tags turns it off - or it in again */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   973
    if (_isSmallInteger(anInteger)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   974
        RETURN ( (OBJ)( ((INT)self ^ (INT)anInteger) | TAG_INT) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   975
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   976
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   977
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   978
    ^ self retry:#bitXor coercing:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   979
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   980
a27a279701f8 Initial revision
claus
parents:
diff changeset
   981
bitInvert
a27a279701f8 Initial revision
claus
parents:
diff changeset
   982
    "return the value of the receiver with all bits inverted"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   983
a27a279701f8 Initial revision
claus
parents:
diff changeset
   984
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   985
a27a279701f8 Initial revision
claus
parents:
diff changeset
   986
    /* invert anything except tag bits */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   987
    RETURN ( ((OBJ) ((INT)self ^ ~TAG_MASK)) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   988
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   989
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   990
a27a279701f8 Initial revision
claus
parents:
diff changeset
   991
bitTest:aMask
a27a279701f8 Initial revision
claus
parents:
diff changeset
   992
    "return true, if any bit from aMask is set in the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   993
a27a279701f8 Initial revision
claus
parents:
diff changeset
   994
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   995
a27a279701f8 Initial revision
claus
parents:
diff changeset
   996
    /* and all bits except tag */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   997
    if (_isSmallInteger(aMask)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   998
        RETURN ( ((INT)self & ((INT)aMask & ~TAG_MASK)) ? true : false );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   999
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1000
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1001
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1002
    ^ self retry:#bitTest coercing:aMask
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1003
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1004
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1005
!SmallInteger methodsFor:'byte access'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1006
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1007
digitLength
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1008
    "return the number bytes used by this Integer"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1009
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1010
    ^ self abs highBit - 1 // 8 + 1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1011
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1012
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1013
digitAt:index
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1014
    "return 8 bits of value, starting at byte index"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1015
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1016
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1017
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1018
    INT val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1019
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1020
    if (_isSmallInteger(index)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1021
        val = _intVal(self);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1022
        if (val < 0)
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1023
            val = -val;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1024
        switch (_intVal(index)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1025
            case 1:
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1026
                RETURN ( _MKSMALLINT( val & 0xFF) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1027
            case 2:
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1028
                RETURN ( _MKSMALLINT( (val >> 8) & 0xFF) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1029
            case 3:
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1030
                RETURN ( _MKSMALLINT( (val >> 16) & 0xFF) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1031
            case 4:
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1032
                RETURN ( _MKSMALLINT( (val >> 24) & 0xFF) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1033
#ifdef alpha
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1034
            case 5:
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1035
                RETURN ( _MKSMALLINT( (val >> 32) & 0xFF) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1036
            case 6:
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1037
                RETURN ( _MKSMALLINT( (val >> 40) & 0xFF) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1038
            case 7:
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1039
                RETURN ( _MKSMALLINT( (val >> 48) & 0xFF) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1040
            case 8:
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1041
                RETURN ( _MKSMALLINT( (val >> 56) & 0xFF) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1042
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1043
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1044
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1045
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1046
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1047
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1048
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1049
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1050
!SmallInteger methodsFor:'misc math functions'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1051
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1052
gcd:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1053
    "return the greatest common divisor (Euclid's algorithm).
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1054
     This has been redefined here for more speed since due to the
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1055
     use of gcd in Fraction code, it has become time-critical for
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1056
     some code. (thanx to MessageTally)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1057
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1058
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1059
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1060
    if (_isSmallInteger(anInteger)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1061
        INT orgArg, ttt, selfInt, temp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1062
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1063
        ttt = orgArg = _intVal(anInteger);
2
claus
parents: 1
diff changeset
  1064
        if (ttt) {
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1065
            selfInt = _intVal(self);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1066
            while (ttt != 0) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1067
                temp = selfInt % ttt;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1068
                selfInt = ttt;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1069
                ttt = temp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1070
            }
2
claus
parents: 1
diff changeset
  1071
            /*
claus
parents: 1
diff changeset
  1072
             * since its not defined in what the sign of
claus
parents: 1
diff changeset
  1073
             * a modulu result is when the arg is negative,
claus
parents: 1
diff changeset
  1074
             * change it explicitely here ...
claus
parents: 1
diff changeset
  1075
             */
claus
parents: 1
diff changeset
  1076
            if (orgArg < 0) {
claus
parents: 1
diff changeset
  1077
                /* result should be negative */
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1078
                if (selfInt > 0) selfInt = -selfInt;
2
claus
parents: 1
diff changeset
  1079
            } else {
claus
parents: 1
diff changeset
  1080
                /* result should be positive */
claus
parents: 1
diff changeset
  1081
                if (selfInt < 0) selfInt = -selfInt;
claus
parents: 1
diff changeset
  1082
            }
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1083
            RETURN ( _MKSMALLINT(selfInt) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1084
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1085
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1086
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1087
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1088
    ^ super gcd:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1089
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1090
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1091
intlog10
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1092
    "return the truncation of log10 of the receiver -
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1093
     stupid implementation; used to find out the number of digits needed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1094
     to print a number/and for conversion to a LargeInteger"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1095
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1096
    self <= 0 ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1097
        self error:'logarithm of negative integer'
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1098
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1099
    self < 10 ifTrue:[^ 1].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1100
    self < 100 ifTrue:[^ 2].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1101
    self < 1000 ifTrue:[^ 3].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1102
    self < 10000 ifTrue:[^ 4].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1103
    self < 100000 ifTrue:[^ 5].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1104
    self < 1000000 ifTrue:[^ 6].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1105
    self < 10000000 ifTrue:[^ 7].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1106
    self < 100000000 ifTrue:[^ 8].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1107
    self < 1000000000 ifTrue:[^ 9].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1108
    ^ 10
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1109
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1110
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1111
!SmallInteger methodsFor:'coercing and converting'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1112
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1113
coerce:aNumber
41
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
  1114
    "return aNumber converted into receivers type"
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
  1115
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1116
    ^ aNumber asInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1117
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1118
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1119
generality
41
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
  1120
    "return the generality value - see ArithmeticValue>>retry:coercing:"
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
  1121
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1122
    ^ 20
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1123
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1124
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1125
asFloat
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1126
    "return a Float with same value as receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1127
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1128
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1129
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1130
    OBJ newFloat;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1131
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1132
    _qAlignedNew(newFloat, sizeof(struct floatstruct), SENDER);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1133
    _InstPtr(newFloat)->o_class = Float;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1134
    _FloatInstPtr(newFloat)->f_floatvalue = _intVal(self);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1135
    RETURN ( newFloat );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1136
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1137
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1138
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1139
asLargeInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1140
    "return a LargeInteger with same value as receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1141
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1142
    ^ LargeInteger value:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1143
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1144
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1145
asCharacter
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1146
    "Return self as an ascii character"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1147
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1148
    ^ Character value:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1149
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1150
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1151
!SmallInteger methodsFor:'iterators'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1152
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1153
timesRepeat:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1154
    "evaluate the argument, aBlock self times"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1155
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1156
    |count "{ Class: SmallInteger }" |
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1157
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1158
    count := self.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1159
    [count > 0] whileTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1160
        aBlock value.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1161
        count := count - 1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1162
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1163
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1164
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1165
to:stop do:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1166
    "reimplemented for speed"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1167
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1168
    |home index|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1169
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1170
    REGISTER INT tmp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1171
    INT final;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1172
    REGISTER OBJFUNC code;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1173
    extern OBJ Block, _value_;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1174
    static struct inlineCache blockVal = _ILC1;
2
claus
parents: 1
diff changeset
  1175
    REGISTER OBJ rHome;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1176
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1177
    if (_isSmallInteger(stop)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1178
        tmp = _intVal(self);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1179
        final = _intVal(stop);
2
claus
parents: 1
diff changeset
  1180
        if (__isBlock(aBlock)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1181
         && ((code = _BlockInstPtr(aBlock)->b_code) != (OBJFUNC)nil)
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1182
         && (_BlockInstPtr(aBlock)->b_nargs == _MKSMALLINT(1))) {
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1183
#ifdef NEW_BLOCK_CALL
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1184
            while (tmp <= final) {
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1185
                if (InterruptPending != nil) interrupt(CONARG);
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1186
                (*code)(aBlock, CON_COMMA _MKSMALLINT(tmp));
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1187
                tmp++;
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1188
            }
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1189
#else
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1190
            /*
2
claus
parents: 1
diff changeset
  1191
             * arg is a compiled block - 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1192
             * directly call it without going through "Block-value"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1193
             */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1194
            home = _BlockInstPtr(aBlock)->b_home;
2
claus
parents: 1
diff changeset
  1195
            rHome = home;
claus
parents: 1
diff changeset
  1196
            if ((rHome == nil) || (_qSpace(rHome) >= STACKSPACE)) {
claus
parents: 1
diff changeset
  1197
                /*
claus
parents: 1
diff changeset
  1198
                 * home will not move - keep in in a register
claus
parents: 1
diff changeset
  1199
                 */
claus
parents: 1
diff changeset
  1200
                while (tmp <= final) {
claus
parents: 1
diff changeset
  1201
                    if (InterruptPending != nil) interrupt(CONARG);
claus
parents: 1
diff changeset
  1202
                    (*code)(rHome, CON_COMMA _MKSMALLINT(tmp));
claus
parents: 1
diff changeset
  1203
                    tmp++;
claus
parents: 1
diff changeset
  1204
                }
10
claus
parents: 5
diff changeset
  1205
            } else {
2
claus
parents: 1
diff changeset
  1206
                while (tmp <= final) {
claus
parents: 1
diff changeset
  1207
                    if (InterruptPending != nil) interrupt(CONARG);
claus
parents: 1
diff changeset
  1208
                    (*code)(home, CON_COMMA _MKSMALLINT(tmp));
claus
parents: 1
diff changeset
  1209
                    tmp++;
claus
parents: 1
diff changeset
  1210
                }
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1211
            }
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1212
#endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1213
        } else {
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1214
            /*
2
claus
parents: 1
diff changeset
  1215
             * arg is something else - call it with Block-value"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1216
             */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1217
            while (tmp <= final) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1218
                if (InterruptPending != nil) interrupt(CONARG);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1219
2
claus
parents: 1
diff changeset
  1220
                (*blockVal.ilc_func)(aBlock, _value_, CON_COMMA nil, &blockVal, 
claus
parents: 1
diff changeset
  1221
                                                      _MKSMALLINT(tmp));
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1222
                tmp++;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1223
            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1224
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1225
        RETURN ( self );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1226
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1227
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1228
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1229
    ^super to:stop do:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1230
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1231
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1232
to:stop by:incr do:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1233
    "reimplemented for speed"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1234
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1235
    |home index|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1236
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1237
    REGISTER INT tmp, step;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1238
    REGISTER INT final;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1239
    REGISTER OBJFUNC code;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1240
    extern OBJ Block, _value_;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1241
    static struct inlineCache blockVal = _ILC1;
2
claus
parents: 1
diff changeset
  1242
    REGISTER OBJ rHome;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1243
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1244
    if (_isSmallInteger(incr)
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1245
     && _isSmallInteger(stop)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1246
        tmp = _intVal(self);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1247
        final = _intVal(stop);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1248
        step = _intVal(incr);
2
claus
parents: 1
diff changeset
  1249
        if (__isBlock(aBlock)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1250
         && ((code = _BlockInstPtr(aBlock)->b_code) != (OBJFUNC)nil)
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1251
         && (_BlockInstPtr(aBlock)->b_nargs == _MKSMALLINT(1))) {
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1252
#ifdef NEW_BLOCK_CALL
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1253
            if (step < 0) {
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1254
                while (tmp >= final) {
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1255
                    if (InterruptPending != nil) interrupt(CONARG);
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1256
                    (*code)(aBlock, CON_COMMA _MKSMALLINT(tmp));
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1257
                    tmp += step;
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1258
                }
41
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
  1259
            } else {
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1260
                while (tmp <= final) {
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1261
                    if (InterruptPending != nil) interrupt(CONARG);
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1262
                    (*code)(aBlock, CON_COMMA _MKSMALLINT(tmp));
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1263
                    tmp += step;
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1264
                }
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1265
            }
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1266
#else
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1267
            /*
2
claus
parents: 1
diff changeset
  1268
             * arg is a compiled block - 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1269
             * directly call it without going through "Block-value"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1270
             */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1271
            home = _BlockInstPtr(aBlock)->b_home;
10
claus
parents: 5
diff changeset
  1272
            rHome = home;
2
claus
parents: 1
diff changeset
  1273
            if (step < 0) {
claus
parents: 1
diff changeset
  1274
                if ((rHome == nil) || (_qSpace(rHome) >= STACKSPACE)) {
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1275
                    /*
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1276
                     * home is on stack - will not move
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1277
                     */
2
claus
parents: 1
diff changeset
  1278
                    while (tmp >= final) {
claus
parents: 1
diff changeset
  1279
                        if (InterruptPending != nil) interrupt(CONARG);
claus
parents: 1
diff changeset
  1280
                        (*code)(rHome, CON_COMMA _MKSMALLINT(tmp));
claus
parents: 1
diff changeset
  1281
                        tmp += step;
claus
parents: 1
diff changeset
  1282
                    }
10
claus
parents: 5
diff changeset
  1283
                } else {
2
claus
parents: 1
diff changeset
  1284
                    while (tmp >= final) {
claus
parents: 1
diff changeset
  1285
                        if (InterruptPending != nil) interrupt(CONARG);
claus
parents: 1
diff changeset
  1286
                        (*code)(home, CON_COMMA _MKSMALLINT(tmp));
claus
parents: 1
diff changeset
  1287
                        tmp += step;
claus
parents: 1
diff changeset
  1288
                    }
claus
parents: 1
diff changeset
  1289
                }
claus
parents: 1
diff changeset
  1290
            } else {
claus
parents: 1
diff changeset
  1291
                if ((rHome == nil) || (_qSpace(rHome) >= STACKSPACE)) {
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1292
                    /*
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1293
                     * home is on stack - will not move
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1294
                     */
2
claus
parents: 1
diff changeset
  1295
                    while (tmp <= final) {
claus
parents: 1
diff changeset
  1296
                        if (InterruptPending != nil) interrupt(CONARG);
claus
parents: 1
diff changeset
  1297
                        (*code)(rHome, CON_COMMA _MKSMALLINT(tmp));
claus
parents: 1
diff changeset
  1298
                        tmp += step;
claus
parents: 1
diff changeset
  1299
                    }
10
claus
parents: 5
diff changeset
  1300
                } else {
2
claus
parents: 1
diff changeset
  1301
                    while (tmp <= final) {
claus
parents: 1
diff changeset
  1302
                        if (InterruptPending != nil) interrupt(CONARG);
claus
parents: 1
diff changeset
  1303
                        (*code)(home, CON_COMMA _MKSMALLINT(tmp));
claus
parents: 1
diff changeset
  1304
                        tmp += step;
claus
parents: 1
diff changeset
  1305
                    }
claus
parents: 1
diff changeset
  1306
                }
claus
parents: 1
diff changeset
  1307
            }
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1308
#endif
2
claus
parents: 1
diff changeset
  1309
        } else {
claus
parents: 1
diff changeset
  1310
            /*
claus
parents: 1
diff changeset
  1311
             * arg is something else - call it with Block-value"
claus
parents: 1
diff changeset
  1312
             */
claus
parents: 1
diff changeset
  1313
            if (step < 0) {
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1314
                while (tmp >= final) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1315
                    if (InterruptPending != nil) interrupt(CONARG);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1316
2
claus
parents: 1
diff changeset
  1317
                    (*blockVal.ilc_func)(aBlock, _value_, CON_COMMA nil, &blockVal,
claus
parents: 1
diff changeset
  1318
                                                          _MKSMALLINT(tmp));
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1319
                    tmp += step;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1320
                }
2
claus
parents: 1
diff changeset
  1321
            } else {
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1322
                while (tmp <= final) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1323
                    if (InterruptPending != nil) interrupt(CONARG);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1324
2
claus
parents: 1
diff changeset
  1325
                    (*blockVal.ilc_func)(aBlock, _value_, CON_COMMA nil, &blockVal,
claus
parents: 1
diff changeset
  1326
                                                          _MKSMALLINT(tmp));
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1327
                    tmp += step;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1328
                }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1329
            }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1330
        }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1331
        RETURN ( self );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1332
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1333
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1334
.
2
claus
parents: 1
diff changeset
  1335
    ^ super to:stop do:aBlock
claus
parents: 1
diff changeset
  1336
! !
claus
parents: 1
diff changeset
  1337
claus
parents: 1
diff changeset
  1338
!SmallInteger class methodsFor:'binary storage'!
claus
parents: 1
diff changeset
  1339
claus
parents: 1
diff changeset
  1340
binaryDefinitionFrom: stream manager: manager
claus
parents: 1
diff changeset
  1341
    "read the binary representation as stored in storeBinaryOn:"
claus
parents: 1
diff changeset
  1342
claus
parents: 1
diff changeset
  1343
    | value |
claus
parents: 1
diff changeset
  1344
claus
parents: 1
diff changeset
  1345
    value := stream next bitAnd: 16r7F.
claus
parents: 1
diff changeset
  1346
    value > 16r3F ifTrue: [
claus
parents: 1
diff changeset
  1347
        value := value - 16r80
claus
parents: 1
diff changeset
  1348
    ].
claus
parents: 1
diff changeset
  1349
    value := (value bitShift: 8) bitOr: stream next.
claus
parents: 1
diff changeset
  1350
    value := (value bitShift: 8) bitOr: stream next.
claus
parents: 1
diff changeset
  1351
    value := (value bitShift: 8) bitOr: stream next.
claus
parents: 1
diff changeset
  1352
    ^ value
claus
parents: 1
diff changeset
  1353
! !
claus
parents: 1
diff changeset
  1354
claus
parents: 1
diff changeset
  1355
!SmallInteger methodsFor:'binary storage'!
claus
parents: 1
diff changeset
  1356
claus
parents: 1
diff changeset
  1357
hasSpecialBinaryRepresentation
41
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
  1358
    "return true, if the receiver has a special binary representation"
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
  1359
2
claus
parents: 1
diff changeset
  1360
    ^ true
claus
parents: 1
diff changeset
  1361
!
claus
parents: 1
diff changeset
  1362
claus
parents: 1
diff changeset
  1363
storeBinaryOn: stream manager: manager
41
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
  1364
    "append a binary representation onto stream.
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
  1365
     Redefined since SmallIntegers are stored as their value with the 32nd bit 
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
  1366
     set as a tag.
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
  1367
     To make the binary file a bit more compact, zeros and single byte ints
a14247b04d03 *** empty log message ***
claus
parents: 13
diff changeset
  1368
     are stored with a more compact representation (using special type-codes)."
2
claus
parents: 1
diff changeset
  1369
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  1370
    self == 0 ifTrue:[
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  1371
        stream nextPut: manager codeForZero.
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  1372
        ^ self
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  1373
    ].
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  1374
    (self between:0 and:255) ifTrue:[
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  1375
        stream nextPut: manager codeForByteInteger.
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  1376
        stream nextPut: self.
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  1377
        ^ self
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  1378
    ].
2
claus
parents: 1
diff changeset
  1379
    stream nextPut: (((self bitShift: -24) bitAnd: 16rFF) bitOr: 16r80).
claus
parents: 1
diff changeset
  1380
    stream nextPut: ((self bitShift: -16) bitAnd: 16rFF).
claus
parents: 1
diff changeset
  1381
    stream nextPut: ((self bitShift: -8) bitAnd: 16rFF).
claus
parents: 1
diff changeset
  1382
    stream nextPut: (self bitAnd: 16rFF)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1383
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1384
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1385
!SmallInteger methodsFor:'printing & storing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1386
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1387
printString
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1388
    "return my printstring (base 10)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1389
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1390
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1391
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1392
    extern char *newNextPtr, *newEndPtr;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1393
    char buffer[30];
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1394
    OBJ newString;
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1395
#ifdef THISCONTEXT_IN_REGISTER
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1396
    OBJ sav = __thisContext;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1397
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1398
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1399
    sprintf(buffer, "%d", _intVal(self));
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1400
#ifdef THISCONTEXT_IN_REGISTER
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1401
    __thisContext = sav;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1402
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1403
    _qNew(newString, sizeof(struct stringheader) + strlen(buffer) + 1, SENDER);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1404
    _InstPtr(newString)->o_class = String;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1405
    strcpy(_stringVal(newString), buffer);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1406
    RETURN (newString);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1407
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1408
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1409
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1410
printStringRadix:radix
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1411
    "return my printstring (base 10)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1412
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1413
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1414
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1415
    extern char *newNextPtr, *newEndPtr;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1416
    char *format = (char *)0;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1417
    char buffer[30];
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1418
    OBJ newString;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1419
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1420
    if (_isSmallInteger(radix)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1421
        switch (_intVal(radix)) {
2
claus
parents: 1
diff changeset
  1422
            case 10:
claus
parents: 1
diff changeset
  1423
                format = "%d";
claus
parents: 1
diff changeset
  1424
                break;
claus
parents: 1
diff changeset
  1425
            case 16:
claus
parents: 1
diff changeset
  1426
                format = "%x";
claus
parents: 1
diff changeset
  1427
                break;
claus
parents: 1
diff changeset
  1428
            case 8:
claus
parents: 1
diff changeset
  1429
                format = "%o";
claus
parents: 1
diff changeset
  1430
                break;
claus
parents: 1
diff changeset
  1431
        }
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1432
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1433
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1434
    if (format) {
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1435
#ifdef THISCONTEXT_IN_REGISTER
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1436
        OBJ sav = __thisContext;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1437
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1438
        sprintf(buffer, format, _intVal(self));
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1439
#ifdef THISCONTEXT_IN_REGISTER
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1440
        __thisContext = sav;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1441
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1442
        _qNew(newString, sizeof(struct stringheader) + strlen(buffer) + 1, SENDER);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1443
        _InstPtr(newString)->o_class = String;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1444
        strcpy(_stringVal(newString), buffer);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1445
        RETURN (newString);
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1446
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1447
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1448
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1449
    ^ super printStringRadix:radix
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1450
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1451
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1452
printfPrintString:formatString
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1453
    "non-portable, but sometimes useful.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1454
     return a printed representation of the receiver
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1455
     as specified by formatString, which is defined by printf.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1456
     No checking for string overrun - must be shorter than 256 chars or else ..."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1457
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1458
%{  /* STACK: 400 */
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1459
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1460
    char buffer[256];
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1461
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1462
    if (_isString(formatString)) {
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1463
#ifdef THISCONTEXT_IN_REGISTER
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1464
        OBJ sav = __thisContext;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1465
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1466
        sprintf(buffer, _stringVal(formatString), _intVal(self));
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
  1467
#ifdef THISCONTEXT_IN_REGISTER
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1468
        __thisContext = sav;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1469
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1470
        RETURN ( _MKSTRING(buffer COMMA_SND) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1471
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1472
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1473
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1474
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1475
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1476
    "123 printfPrintString:'%%d -> %d'"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1477
    "123 printfPrintString:'%%6d -> %6d'"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1478
    "123 printfPrintString:'%%x -> %x'"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1479
    "123 printfPrintString:'%%4x -> %4x'"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1480
    "123 printfPrintString:'%%04x -> %04x'"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1481
! !