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