Number.st
author Claus Gittinger <cg@exept.de>
Wed, 01 Nov 1995 15:44:26 +0100
changeset 468 72dfba4603b4
parent 421 a0807a38319d
child 530 07d0bce293c9
permissions -rw-r--r--
Initial revision
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
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
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
ArithmeticValue subclass:#Number
a27a279701f8 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    15
       classVariableNames:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    16
       poolDictionaries:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    17
       category:'Magnitude-Numbers'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
Number comment:'
88
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    21
COPYRIGHT (c) 1988 by Claus Gittinger
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
    22
	      All Rights Reserved
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
    23
421
claus
parents: 384
diff changeset
    24
$Header: /cvs/stx/stx/libbasic/Number.st,v 1.21 1995-09-03 15:05:33 claus Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    25
'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    26
213
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
    27
!Number class methodsFor:'documentation'!
88
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    28
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    29
copyright
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    30
"
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    31
 COPYRIGHT (c) 1988 by Claus Gittinger
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
    32
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    33
88
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    34
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    35
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    36
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    37
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    38
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    39
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    40
"
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    41
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    42
88
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    43
version
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    44
"
421
claus
parents: 384
diff changeset
    45
$Header: /cvs/stx/stx/libbasic/Number.st,v 1.21 1995-09-03 15:05:33 claus Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    46
"
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    47
!
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    48
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    49
documentation
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    50
"
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    51
    abstract superclass for all kinds of numbers
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    52
"
81dacba7a63a *** empty log message ***
claus
parents: 56
diff changeset
    53
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    54
421
claus
parents: 384
diff changeset
    55
!Number methodsFor:'converting'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    56
a27a279701f8 Initial revision
claus
parents:
diff changeset
    57
@ aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
    58
    "return a Point with the receiver as x-coordinate and the argument
a27a279701f8 Initial revision
claus
parents:
diff changeset
    59
     as y-coordinate"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    60
a27a279701f8 Initial revision
claus
parents:
diff changeset
    61
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
    62
13
62303f84ff5f *** empty log message ***
claus
parents: 5
diff changeset
    63
    /*
56
be0ed17e6f85 *** empty log message ***
claus
parents: 39
diff changeset
    64
     * I cannot tell if this special code is worth anything
13
62303f84ff5f *** empty log message ***
claus
parents: 5
diff changeset
    65
     */
325
claus
parents: 296
diff changeset
    66
    if (_CanDoQuickNew(sizeof(struct __point))) {
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
    67
	OBJ newPoint;
293
31df3850e98c *** empty log message ***
claus
parents: 213
diff changeset
    68
	int spc;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    69
325
claus
parents: 296
diff changeset
    70
	_qCheckedAlignedNew(newPoint, sizeof(struct __point));
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
    71
	_InstPtr(newPoint)->o_class = Point;
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
    72
	_PointInstPtr(newPoint)->p_x = self;
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
    73
	_PointInstPtr(newPoint)->p_y = aNumber;
369
claus
parents: 345
diff changeset
    74
	if (! __bothSmallInteger(self, aNumber)) {
claus
parents: 345
diff changeset
    75
	    spc = __qSpace(newPoint);
claus
parents: 345
diff changeset
    76
	    __STORE_SPC(newPoint, aNumber, spc);
claus
parents: 345
diff changeset
    77
	    __STORE_SPC(newPoint, self, spc);
claus
parents: 345
diff changeset
    78
	}
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
    79
	RETURN ( newPoint );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    80
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
    81
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
    82
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    83
    ^ Point x:self y:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
    84
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    85
a27a279701f8 Initial revision
claus
parents:
diff changeset
    86
asPoint
a27a279701f8 Initial revision
claus
parents:
diff changeset
    87
    "return a new Point with the receiver as all coordinates;  
a27a279701f8 Initial revision
claus
parents:
diff changeset
    88
     often used to supply the same value in two dimensions, as with 
a27a279701f8 Initial revision
claus
parents:
diff changeset
    89
     symmetrical gridding or scaling."
a27a279701f8 Initial revision
claus
parents:
diff changeset
    90
a27a279701f8 Initial revision
claus
parents:
diff changeset
    91
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
    92
325
claus
parents: 296
diff changeset
    93
    if (_CanDoQuickNew(sizeof(struct __point))) {
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
    94
	OBJ newPoint;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    95
325
claus
parents: 296
diff changeset
    96
	_qCheckedAlignedNew(newPoint, sizeof(struct __point));
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
    97
	_InstPtr(newPoint)->o_class = Point;
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
    98
	_PointInstPtr(newPoint)->p_x = self;
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
    99
	_PointInstPtr(newPoint)->p_y = self;
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   100
	__STORE(newPoint, self);
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   101
	RETURN ( newPoint );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   102
    }
421
claus
parents: 384
diff changeset
   103
%}.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   104
    ^ Point x:self y:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   105
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   106
a27a279701f8 Initial revision
claus
parents:
diff changeset
   107
degreesToRadians
a27a279701f8 Initial revision
claus
parents:
diff changeset
   108
    "interpreting the receiver as radians, return the degrees"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   109
a27a279701f8 Initial revision
claus
parents:
diff changeset
   110
    ^ (self * (Float pi)) / 180.0
a27a279701f8 Initial revision
claus
parents:
diff changeset
   111
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   112
a27a279701f8 Initial revision
claus
parents:
diff changeset
   113
radiansToDegrees
a27a279701f8 Initial revision
claus
parents:
diff changeset
   114
    "interpreting the receiver as degrees, return the radians"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   115
a27a279701f8 Initial revision
claus
parents:
diff changeset
   116
    ^ (self * 180.0) / (Float pi)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   117
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   118
421
claus
parents: 384
diff changeset
   119
literalArrayEncoding
claus
parents: 384
diff changeset
   120
    "encode myself as an array literal."
claus
parents: 384
diff changeset
   121
claus
parents: 384
diff changeset
   122
    ^ self
claus
parents: 384
diff changeset
   123
claus
parents: 384
diff changeset
   124
    "Modified: 1.9.1995 / 02:25:26 / claus"
claus
parents: 384
diff changeset
   125
! !
claus
parents: 384
diff changeset
   126
claus
parents: 384
diff changeset
   127
!Number methodsFor:'coercing'!
claus
parents: 384
diff changeset
   128
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   129
coerce:aNumber
39
bcf183a31bbb *** empty log message ***
claus
parents: 13
diff changeset
   130
    "return aNumber converted into receivers type"
bcf183a31bbb *** empty log message ***
claus
parents: 13
diff changeset
   131
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   132
    ^ self subclassResponsibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
   133
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   134
a27a279701f8 Initial revision
claus
parents:
diff changeset
   135
generality
39
bcf183a31bbb *** empty log message ***
claus
parents: 13
diff changeset
   136
    "return the generality value - see ArithmeticValue>>retry:coercing:"
bcf183a31bbb *** empty log message ***
claus
parents: 13
diff changeset
   137
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   138
    ^ 40
a27a279701f8 Initial revision
claus
parents:
diff changeset
   139
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   140
a27a279701f8 Initial revision
claus
parents:
diff changeset
   141
retry:aSymbol coercing:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   142
    "Arithmetic represented by the binary operator, aSymbol,
a27a279701f8 Initial revision
claus
parents:
diff changeset
   143
    could not be performed with the receiver and the argument,
a27a279701f8 Initial revision
claus
parents:
diff changeset
   144
    aNumber, because of the differences in representation.  Coerce either
a27a279701f8 Initial revision
claus
parents:
diff changeset
   145
    the receiver or the argument, depending on which has higher generality, and
a27a279701f8 Initial revision
claus
parents:
diff changeset
   146
    try again.  If the operation is comapre for same value (=), return false if
a27a279701f8 Initial revision
claus
parents:
diff changeset
   147
    the argument is not a Number. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   148
    If the generalities are the same, create an error message."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   149
a27a279701f8 Initial revision
claus
parents:
diff changeset
   150
    |myGenerality otherGenerality|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   151
a27a279701f8 Initial revision
claus
parents:
diff changeset
   152
    (aSymbol == #=) ifTrue:[
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   153
	(aNumber respondsTo:#generality) ifFalse:[^ false]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   154
    ] ifFalse:[
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   155
	(aNumber respondsTo:#generality) ifFalse:[
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   156
	    self error:'retry:coercing: argument is not a number'.
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   157
	    ^ self
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   158
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   159
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   160
    myGenerality := self generality.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   161
    otherGenerality := aNumber generality.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   162
    (myGenerality > otherGenerality) ifTrue:[
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   163
	^ self perform:aSymbol with:(self coerce:aNumber)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   164
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   165
    (myGenerality < otherGenerality) ifTrue:[
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   166
	^ (aNumber coerce:self) perform:aSymbol with:aNumber
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   167
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   168
    self error:'retry:coercing: oops - same generality'
a27a279701f8 Initial revision
claus
parents:
diff changeset
   169
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   170
13
62303f84ff5f *** empty log message ***
claus
parents: 5
diff changeset
   171
!Number methodsFor:'testing'!
62303f84ff5f *** empty log message ***
claus
parents: 5
diff changeset
   172
62303f84ff5f *** empty log message ***
claus
parents: 5
diff changeset
   173
isLiteral
39
bcf183a31bbb *** empty log message ***
claus
parents: 13
diff changeset
   174
    "return true, if the receiver can be used as a literal
bcf183a31bbb *** empty log message ***
claus
parents: 13
diff changeset
   175
     (i.e. can be used in constant arrays)"
13
62303f84ff5f *** empty log message ***
claus
parents: 5
diff changeset
   176
62303f84ff5f *** empty log message ***
claus
parents: 5
diff changeset
   177
    ^ true
62303f84ff5f *** empty log message ***
claus
parents: 5
diff changeset
   178
!
62303f84ff5f *** empty log message ***
claus
parents: 5
diff changeset
   179
62303f84ff5f *** empty log message ***
claus
parents: 5
diff changeset
   180
isNumber
62303f84ff5f *** empty log message ***
claus
parents: 5
diff changeset
   181
    "return true, if the receiver is a kind of number"
62303f84ff5f *** empty log message ***
claus
parents: 5
diff changeset
   182
62303f84ff5f *** empty log message ***
claus
parents: 5
diff changeset
   183
    ^ true
329
claus
parents: 325
diff changeset
   184
!
claus
parents: 325
diff changeset
   185
claus
parents: 325
diff changeset
   186
isZero
claus
parents: 325
diff changeset
   187
    ^ self = 0
13
62303f84ff5f *** empty log message ***
claus
parents: 5
diff changeset
   188
! !
62303f84ff5f *** empty log message ***
claus
parents: 5
diff changeset
   189
345
claus
parents: 339
diff changeset
   190
!Number class methodsFor:'error reporting'!
claus
parents: 339
diff changeset
   191
claus
parents: 339
diff changeset
   192
raise:aSignalSymbol receiver:someNumber selector:sel errorString:text 
claus
parents: 339
diff changeset
   193
    "ST-80 compatible signal raising. Provided for PD numeric classes"
claus
parents: 339
diff changeset
   194
claus
parents: 339
diff changeset
   195
    |msg|
claus
parents: 339
diff changeset
   196
claus
parents: 339
diff changeset
   197
    msg := MessageSend
claus
parents: 339
diff changeset
   198
		receiver:someNumber
claus
parents: 339
diff changeset
   199
		selector:sel
claus
parents: 339
diff changeset
   200
		arguments:#().
claus
parents: 339
diff changeset
   201
    ^ (self perform:aSignalSymbol)
claus
parents: 339
diff changeset
   202
	 raiseRequestWith:msg 
claus
parents: 339
diff changeset
   203
	 errorString:text 
claus
parents: 339
diff changeset
   204
	 in:thisContext sender
claus
parents: 339
diff changeset
   205
claus
parents: 339
diff changeset
   206
    "
claus
parents: 339
diff changeset
   207
     Number raise:#domainErrorSignal
claus
parents: 339
diff changeset
   208
	    receiver:1.0
claus
parents: 339
diff changeset
   209
	    selector:#foo 
claus
parents: 339
diff changeset
   210
	    errorString:'foo bar test'
claus
parents: 339
diff changeset
   211
    "
claus
parents: 339
diff changeset
   212
!
claus
parents: 339
diff changeset
   213
claus
parents: 339
diff changeset
   214
raise:aSignalSymbol receiver:someNumber selector:sel arg:arg errorString:text 
claus
parents: 339
diff changeset
   215
    "ST-80 compatible signal raising. Provided for PD numeric classes"
claus
parents: 339
diff changeset
   216
claus
parents: 339
diff changeset
   217
    |msg|
claus
parents: 339
diff changeset
   218
claus
parents: 339
diff changeset
   219
    msg := MessageSend
claus
parents: 339
diff changeset
   220
		receiver:someNumber
claus
parents: 339
diff changeset
   221
		selector:sel
claus
parents: 339
diff changeset
   222
		arguments:(Array with:arg).
claus
parents: 339
diff changeset
   223
    ^ (self perform:aSignalSymbol)
claus
parents: 339
diff changeset
   224
	 raiseRequestWith:msg 
claus
parents: 339
diff changeset
   225
	 errorString:text 
claus
parents: 339
diff changeset
   226
	 in:thisContext sender
claus
parents: 339
diff changeset
   227
claus
parents: 339
diff changeset
   228
    "
claus
parents: 339
diff changeset
   229
     Number raise:#domainErrorSignal
claus
parents: 339
diff changeset
   230
	    receiver:1.0
claus
parents: 339
diff changeset
   231
	    selector:#sin
claus
parents: 339
diff changeset
   232
	    arg:nil
claus
parents: 339
diff changeset
   233
	    errorString:'foo bar test'
claus
parents: 339
diff changeset
   234
    "
claus
parents: 339
diff changeset
   235
! !
claus
parents: 339
diff changeset
   236
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   237
!Number methodsFor:'printing & storing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   238
a27a279701f8 Initial revision
claus
parents:
diff changeset
   239
storeString
56
be0ed17e6f85 *** empty log message ***
claus
parents: 39
diff changeset
   240
    "return a string for storing 
be0ed17e6f85 *** empty log message ***
claus
parents: 39
diff changeset
   241
     - since numbers are literals, they store as they print."
13
62303f84ff5f *** empty log message ***
claus
parents: 5
diff changeset
   242
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   243
    ^ self printString
56
be0ed17e6f85 *** empty log message ***
claus
parents: 39
diff changeset
   244
!
be0ed17e6f85 *** empty log message ***
claus
parents: 39
diff changeset
   245
be0ed17e6f85 *** empty log message ***
claus
parents: 39
diff changeset
   246
storeOn:aStream
be0ed17e6f85 *** empty log message ***
claus
parents: 39
diff changeset
   247
    "append a string for storing the receiver onto the argument,
be0ed17e6f85 *** empty log message ***
claus
parents: 39
diff changeset
   248
     aStream - since numbers are literals,they store as they print."
be0ed17e6f85 *** empty log message ***
claus
parents: 39
diff changeset
   249
be0ed17e6f85 *** empty log message ***
claus
parents: 39
diff changeset
   250
    ^ self printOn:aStream
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   251
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   252
a27a279701f8 Initial revision
claus
parents:
diff changeset
   253
!Number methodsFor:'intervals'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   254
a27a279701f8 Initial revision
claus
parents:
diff changeset
   255
to:stop
a27a279701f8 Initial revision
claus
parents:
diff changeset
   256
    "return an interval from receiver up to the argument, incrementing by 1"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   257
a27a279701f8 Initial revision
claus
parents:
diff changeset
   258
    ^ Interval from:self to:stop
a27a279701f8 Initial revision
claus
parents:
diff changeset
   259
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   260
a27a279701f8 Initial revision
claus
parents:
diff changeset
   261
to:stop by:step
a27a279701f8 Initial revision
claus
parents:
diff changeset
   262
    "return an interval from receiver up to the argument, incrementing by step"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   263
a27a279701f8 Initial revision
claus
parents:
diff changeset
   264
    ^ Interval from:self to:stop by:step
a27a279701f8 Initial revision
claus
parents:
diff changeset
   265
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   266
a27a279701f8 Initial revision
claus
parents:
diff changeset
   267
!Number methodsFor:'iteration'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   268
a27a279701f8 Initial revision
claus
parents:
diff changeset
   269
timesRepeat:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
   270
    "evaluate the argument, aBlock self times"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   271
a27a279701f8 Initial revision
claus
parents:
diff changeset
   272
    |count|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   273
a27a279701f8 Initial revision
claus
parents:
diff changeset
   274
    count := self.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   275
    [count > 0] whileTrue:[
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   276
	aBlock value.
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   277
	count := count - 1
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
to:stop do:aBlock
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   282
    "For each element of the interval from the receiver up to the argument stop,
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   283
     evaluate aBlock, passing the number as argument."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   284
a27a279701f8 Initial revision
claus
parents:
diff changeset
   285
    |tmp|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   286
a27a279701f8 Initial revision
claus
parents:
diff changeset
   287
    tmp := self.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   288
    [tmp <= stop] whileTrue:[
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   289
	aBlock value:tmp.
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   290
	tmp := tmp+1
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   291
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   292
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   293
a27a279701f8 Initial revision
claus
parents:
diff changeset
   294
to:stop by:incr do:aBlock
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   295
    "For each element of the interval from the receiver up to the argument stop, incrementing
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   296
     by step, evaluate aBlock passing the element as argument."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   297
a27a279701f8 Initial revision
claus
parents:
diff changeset
   298
    |tmp|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   299
a27a279701f8 Initial revision
claus
parents:
diff changeset
   300
    tmp := self.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   301
    (incr > 0) ifTrue:[
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   302
	[tmp <= stop] whileTrue:[
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   303
	    aBlock value:tmp.
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   304
	    tmp := tmp+incr
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   305
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   306
    ] ifFalse:[
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   307
	[tmp >= stop] whileTrue:[
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   308
	    aBlock value:tmp.
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   309
	    tmp := tmp+incr
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   310
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   311
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   312
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   313
a27a279701f8 Initial revision
claus
parents:
diff changeset
   314
!Number class methodsFor:'private'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   315
a27a279701f8 Initial revision
claus
parents:
diff changeset
   316
readMantissaFrom:aStream radix:radix
a27a279701f8 Initial revision
claus
parents:
diff changeset
   317
    "helper for readFrom: -
a27a279701f8 Initial revision
claus
parents:
diff changeset
   318
     return the mantissa from the (character-)stream aStream;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   319
     no whitespace-skipping; error if no number available"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   320
a27a279701f8 Initial revision
claus
parents:
diff changeset
   321
    |nextChar value factor|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   322
a27a279701f8 Initial revision
claus
parents:
diff changeset
   323
    value := 0.0.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   324
    factor := 1.0 / radix.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   325
    nextChar := aStream peek.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   326
    [nextChar notNil and:[nextChar isDigitRadix:radix]] whileTrue:[
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   327
	value := value + (nextChar digitValue * factor).
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   328
	factor := factor / radix.
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   329
	nextChar := aStream nextPeek
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   330
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   331
    ^ value
a27a279701f8 Initial revision
claus
parents:
diff changeset
   332
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   333
a27a279701f8 Initial revision
claus
parents:
diff changeset
   334
!Number class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   335
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   336
readFrom:aStream onError:exceptionBlock
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   337
    "return the next Number from the (character-)stream aStream;
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   338
     skipping all whitespace first; return the value of exceptionBlock,
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   339
     if no number can be read."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   340
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   341
    |nextChar radix value negative signExp freakOut|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   342
339
claus
parents: 329
diff changeset
   343
    Object errorSignal handle:[:ex |
claus
parents: 329
diff changeset
   344
	^ exceptionBlock value
claus
parents: 329
diff changeset
   345
    ] do:[
claus
parents: 329
diff changeset
   346
	nextChar := aStream skipSeparators.
claus
parents: 329
diff changeset
   347
	nextChar isNil ifTrue:[^ exceptionBlock value].
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   348
339
claus
parents: 329
diff changeset
   349
	freakOut := [^ exceptionBlock value].
claus
parents: 329
diff changeset
   350
claus
parents: 329
diff changeset
   351
	(nextChar == $-) ifTrue:[
claus
parents: 329
diff changeset
   352
	    negative := true.
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   353
	    nextChar := aStream nextPeek
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   354
	] ifFalse:[
339
claus
parents: 329
diff changeset
   355
	    negative := false.
claus
parents: 329
diff changeset
   356
	    (nextChar == $+) ifTrue:[
claus
parents: 329
diff changeset
   357
		nextChar := aStream nextPeek
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   358
	    ]
40ca7cc6fb9c *** empty log message ***
claus
parents: 93
diff changeset
   359
	].
339
claus
parents: 329
diff changeset
   360
	nextChar isDigit ifFalse:[
claus
parents: 329
diff changeset
   361
	    ^ exceptionBlock value.
claus
parents: 329
diff changeset
   362
"/          value := super readFrom:aStream.
claus
parents: 329
diff changeset
   363
"/          negative ifTrue:[value := value negated].
claus
parents: 329
diff changeset
   364
"/          ^ value
claus
parents: 329
diff changeset
   365
	].
claus
parents: 329
diff changeset
   366
	value := Integer readFrom:aStream radix:10 onError:freakOut.
claus
parents: 329
diff changeset
   367
	nextChar := aStream peek.
claus
parents: 329
diff changeset
   368
	((nextChar == $r) or:[ nextChar == $R]) ifTrue:[
claus
parents: 329
diff changeset
   369
	    aStream next.
claus
parents: 329
diff changeset
   370
	    radix := value.
claus
parents: 329
diff changeset
   371
	    value := Integer readFrom:aStream radix:radix onError:freakOut.
claus
parents: 329
diff changeset
   372
	] ifFalse:[
claus
parents: 329
diff changeset
   373
	    radix := 10
claus
parents: 329
diff changeset
   374
	].
claus
parents: 329
diff changeset
   375
	(nextChar == $.) ifTrue:[
claus
parents: 329
diff changeset
   376
	    nextChar := aStream nextPeek.
claus
parents: 329
diff changeset
   377
	    (nextChar notNil and:[nextChar isDigitRadix:radix]) ifTrue:[
claus
parents: 329
diff changeset
   378
		value := value asFloat 
claus
parents: 329
diff changeset
   379
			 + (Number readMantissaFrom:aStream radix:radix).
claus
parents: 329
diff changeset
   380
		nextChar := aStream peek
claus
parents: 329
diff changeset
   381
	    ]
claus
parents: 329
diff changeset
   382
	].
claus
parents: 329
diff changeset
   383
	((nextChar == $e) or:[nextChar == $E]) ifTrue:[
claus
parents: 329
diff changeset
   384
	    nextChar := aStream nextPeek.
claus
parents: 329
diff changeset
   385
	    signExp := 1.
claus
parents: 329
diff changeset
   386
	    (nextChar == $+) ifTrue:[
claus
parents: 329
diff changeset
   387
		nextChar := aStream nextPeek
claus
parents: 329
diff changeset
   388
	    ] ifFalse:[
claus
parents: 329
diff changeset
   389
		(nextChar == $-) ifTrue:[
claus
parents: 329
diff changeset
   390
		    nextChar := aStream nextPeek.
claus
parents: 329
diff changeset
   391
		    signExp := -1
claus
parents: 329
diff changeset
   392
		]
claus
parents: 329
diff changeset
   393
	    ].
claus
parents: 329
diff changeset
   394
	    (nextChar notNil and:[(nextChar isDigitRadix:radix)]) ifTrue:[
claus
parents: 329
diff changeset
   395
		value := value asFloat 
claus
parents: 329
diff changeset
   396
			 * (10.0 raisedToInteger:
claus
parents: 329
diff changeset
   397
				    ((Integer readFrom:aStream radix:radix onError:freakOut) * signExp))
claus
parents: 329
diff changeset
   398
	    ]
claus
parents: 329
diff changeset
   399
	].
claus
parents: 329
diff changeset
   400
	negative ifTrue:[
claus
parents: 329
diff changeset
   401
	    ^ value negated
claus
parents: 329
diff changeset
   402
	].
claus
parents: 329
diff changeset
   403
	^ value
claus
parents: 329
diff changeset
   404
    ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   405
329
claus
parents: 325
diff changeset
   406
    "
claus
parents: 325
diff changeset
   407
     Number readFrom:(ReadStream on:'54.32e-01')      
claus
parents: 325
diff changeset
   408
     Number readFrom:(ReadStream on:'12345678901234567890') 
claus
parents: 325
diff changeset
   409
     Number readFrom:(ReadStream on:'16rAAAAFFFFAAAAFFFF') 
claus
parents: 325
diff changeset
   410
     '+00000123.45' asNumber  
claus
parents: 325
diff changeset
   411
    "
296
754358c5508a *** empty log message ***
claus
parents: 293
diff changeset
   412
!
754358c5508a *** empty log message ***
claus
parents: 293
diff changeset
   413
754358c5508a *** empty log message ***
claus
parents: 293
diff changeset
   414
readSmalltalkSyntaxFrom:aStream
754358c5508a *** empty log message ***
claus
parents: 293
diff changeset
   415
    "ST-80 compatibility (thanks to a note from alpha testers)
754358c5508a *** empty log message ***
claus
parents: 293
diff changeset
   416
     read and return the next Number in smalltalk syntax from the 
329
claus
parents: 325
diff changeset
   417
     (character-)stream aStream."
claus
parents: 325
diff changeset
   418
claus
parents: 325
diff changeset
   419
    ^ Compiler evaluate:aStream compile:false "/ self readFrom:aStream.
296
754358c5508a *** empty log message ***
claus
parents: 293
diff changeset
   420
329
claus
parents: 325
diff changeset
   421
    "
claus
parents: 325
diff changeset
   422
     Number readSmalltalkSyntaxFrom:(ReadStream on:'54.32e-01')    
claus
parents: 325
diff changeset
   423
     Number readSmalltalkSyntaxFrom:(ReadStream on:'12345678901234567890')
claus
parents: 325
diff changeset
   424
     Number readSmalltalkSyntaxFrom:(ReadStream on:'16rAAAAFFFFAAAAFFFF')
claus
parents: 325
diff changeset
   425
     Number readSmalltalkSyntaxFrom:(ReadStream on:'(1/10)') 
claus
parents: 325
diff changeset
   426
     Number readFrom:(ReadStream on:'(1/10)') 
claus
parents: 325
diff changeset
   427
     Number readSmalltalkSyntaxFrom:(ReadStream on:'+00000123.45')  
claus
parents: 325
diff changeset
   428
     Number readFrom:(ReadStream on:'+00000123.45')  
claus
parents: 325
diff changeset
   429
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   430
! !