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