Interval.st
author Stefan Vogel <sv@exept.de>
Tue, 10 Sep 2002 14:50:39 +0200
changeset 6747 6f749de322b2
parent 6745 c2c52940ec99
child 6748 604366d06326
permissions -rw-r--r--
#encodeInterval
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
216
a8abff749575 *** empty log message ***
claus
parents: 92
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
5521
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
    13
"{ Package: 'stx:libbasic' }"
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
    14
6132
615c4fe0f449 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5672
diff changeset
    15
ReadOnlySequenceableCollection subclass:#Interval
1290
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 759
diff changeset
    16
	instanceVariableNames:'start stop step'
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 759
diff changeset
    17
	classVariableNames:''
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 759
diff changeset
    18
	poolDictionaries:''
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 759
diff changeset
    19
	category:'Collections-Sequenceable'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    21
88
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    22
!Interval class methodsFor:'documentation'!
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    23
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    24
copyright
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    25
"
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    26
 COPYRIGHT (c) 1989 by Claus Gittinger
216
a8abff749575 *** empty log message ***
claus
parents: 92
diff changeset
    27
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    28
88
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    29
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    30
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    31
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    32
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    33
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    34
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    35
"
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    36
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    37
88
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    38
documentation
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    39
"
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    40
    Intervals represent a collection (or range) of numeric values specified by
269
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
    41
    a startValue, an endValue and a step. 
759
908363ce8a32 interest is written with one 'r' (shame on me)
Claus Gittinger <cg@exept.de>
parents: 629
diff changeset
    42
    The interesting thing is that the elements are computed, not stored.
88
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    43
    For example, the interval (1 to:5) containes the elements (1 2 3 4 5) and
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    44
    (1 to:6 by:2) contains (1 3 5).
339
claus
parents: 328
diff changeset
    45
claus
parents: 328
diff changeset
    46
    examples:
claus
parents: 328
diff changeset
    47
1998
9749a5f87238 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1422
diff changeset
    48
	(1 to:10) do:[:i | Transcript showCR:i]
339
claus
parents: 328
diff changeset
    49
claus
parents: 328
diff changeset
    50
      notice, that this is semantically equivalent to:
claus
parents: 328
diff changeset
    51
1998
9749a5f87238 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1422
diff changeset
    52
	1 to:10 do:[:i | Transcript showCR:i]
339
claus
parents: 328
diff changeset
    53
claus
parents: 328
diff changeset
    54
      however, the second is preferred, since loops using to:do: are
claus
parents: 328
diff changeset
    55
      much faster and do not create temporary garbage objects. 
claus
parents: 328
diff changeset
    56
      Therefore, Intervals are generally NOT used for this kind of loops.
claus
parents: 328
diff changeset
    57
1998
9749a5f87238 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1422
diff changeset
    58
	(1 to:10) asArray  
339
claus
parents: 328
diff changeset
    59
1998
9749a5f87238 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1422
diff changeset
    60
	(1 to:10 by:2) asOrderedCollection  
1290
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 759
diff changeset
    61
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 759
diff changeset
    62
    [author:]
1998
9749a5f87238 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1422
diff changeset
    63
	Claus Gittinger
88
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    64
"
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    65
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    66
a27a279701f8 Initial revision
claus
parents:
diff changeset
    67
!Interval class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    68
a27a279701f8 Initial revision
claus
parents:
diff changeset
    69
from:start to:stop
a27a279701f8 Initial revision
claus
parents:
diff changeset
    70
    "return a new interval with elements from start
a27a279701f8 Initial revision
claus
parents:
diff changeset
    71
     to stop by 1"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    72
2
claus
parents: 1
diff changeset
    73
    ^ self new setFrom:start to:stop by:1
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    74
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    75
a27a279701f8 Initial revision
claus
parents:
diff changeset
    76
from:start to:stop by:step
a27a279701f8 Initial revision
claus
parents:
diff changeset
    77
    "return a new interval with elements from start
a27a279701f8 Initial revision
claus
parents:
diff changeset
    78
     to stop by step"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    79
2
claus
parents: 1
diff changeset
    80
    ^ self new setFrom:start to:stop by:step
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    81
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
    82
5672
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
    83
!Interval class methodsFor:'converting'!
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
    84
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
    85
decodeFromLiteralArray:anArray
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
    86
    "create & return a new instance from information encoded in anArray.
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
    87
     Re-redefined, since the implementation in SeqColl creates instances with an initial
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
    88
     size, which is not allowed for intevals."
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
    89
6132
615c4fe0f449 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5672
diff changeset
    90
    ^ self new fromLiteralArrayEncoding:anArray.
615c4fe0f449 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5672
diff changeset
    91
! !
5672
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
    92
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    93
!Interval methodsFor:'accessing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    94
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    95
at:index
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    96
    "return (i.e. compute) the index'th element"
2
claus
parents: 1
diff changeset
    97
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    98
    (index between:1 and:self size) ifTrue:[
5521
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
    99
        ^ start + (step * (index - 1))
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   100
    ].
5521
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   101
    ^ self subscriptBoundsError:index
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   102
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   103
a27a279701f8 Initial revision
claus
parents:
diff changeset
   104
first
a27a279701f8 Initial revision
claus
parents:
diff changeset
   105
    "return the first element of the collection"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   106
5521
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   107
    (((step < 0) and:[start < stop])
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   108
    or:[(step > 0) and:[stop < start]]) ifTrue:[
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   109
        ^ self emptyCollectionError
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   110
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   111
    ^ start
a27a279701f8 Initial revision
claus
parents:
diff changeset
   112
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   113
328
claus
parents: 269
diff changeset
   114
increment 
339
claus
parents: 328
diff changeset
   115
    "alias for #step; for ST-80 compatibility"
328
claus
parents: 269
diff changeset
   116
claus
parents: 269
diff changeset
   117
    ^ step
claus
parents: 269
diff changeset
   118
!
claus
parents: 269
diff changeset
   119
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   120
last
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   121
    "return the last element of the collection"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   122
5521
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   123
    (((step < 0) and:[start < stop])
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   124
    or:[(step > 0) and:[stop < start]]) ifTrue:[
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   125
        ^ self emptyCollectionError
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   126
    ].
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   127
    ^ stop
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   128
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   129
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   130
start
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   131
    "return the first number of the range"
2
claus
parents: 1
diff changeset
   132
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   133
    ^ start
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   134
!
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   135
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   136
start:aNumber
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   137
    "set the first number of the range"
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   138
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   139
    start := aNumber
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   140
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   141
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   142
step
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   143
    "return the step increment of the range.
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   144
     OBSOLETE: 
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   145
	Please use #increment for ST-80 compatibility."
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   146
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   147
    ^ step
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   148
!
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   149
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   150
step:aNumber
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   151
    "set the step increment of the range"
2
claus
parents: 1
diff changeset
   152
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   153
    step := aNumber
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   154
!
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   155
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   156
stop
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   157
    "return the end number of the range"
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   158
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   159
    ^ stop
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   160
!
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   161
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   162
stop:aNumber
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   163
    "set the end number of the range"
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   164
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   165
    stop := aNumber
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   166
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   167
6745
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   168
!Interval methodsFor:'comparing'!
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   169
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   170
= anInterval
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   171
    anInterval class == self class ifTrue:[
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   172
        ^ start = anInterval start
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   173
        and:[ stop = anInterval stop
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   174
        and:[ step = anInterval step]]
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   175
    ].
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   176
    ^ super = anInterval
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   177
!
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   178
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   179
hash
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   180
    ^ ((((step hash bitShift:5) + start hash) bitShift:5) + stop hash) bitAnd:16r3FFFFFFF.
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   181
! !
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   182
5672
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   183
!Interval methodsFor:'converting'!
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   184
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   185
fromLiteralArrayEncoding:encoding
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   186
    "read my values from an encoding.
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   187
     The encoding is supposed to be either of the form: 
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   188
        (#Interval start stop step)
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   189
     This is the reverse operation to #literalArrayEncoding."
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   190
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   191
    start := (encoding at:2).
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   192
    stop := (encoding at:3). 
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   193
    step := (encoding at:4).
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   194
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   195
    "
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   196
     Interval new fromLiteralArrayEncoding:((1 to:10) literalArrayEncoding)  
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   197
     Interval new fromLiteralArrayEncoding:((1 to:10 by:2) literalArrayEncoding) 
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   198
     Interval decodeFromLiteralArray:((1 to:10 by:2) literalArrayEncoding) 
6132
615c4fe0f449 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5672
diff changeset
   199
    "
615c4fe0f449 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5672
diff changeset
   200
!
5672
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   201
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   202
literalArrayEncoding
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   203
    "encode myself as an array literal, from which a copy of the receiver
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   204
     can be reconstructed with #decodeAsLiteralArray."
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   205
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   206
    ^ Array
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   207
        with:self class name asSymbol
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   208
        with:start
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   209
        with:stop
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   210
        with:step
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   211
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   212
    "
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   213
     (1 to:10) literalArrayEncoding      
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   214
     (1 to:10 by:2) literalArrayEncoding
6132
615c4fe0f449 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5672
diff changeset
   215
    "
615c4fe0f449 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5672
diff changeset
   216
! !
5672
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   217
6747
6f749de322b2 #encodeInterval
Stefan Vogel <sv@exept.de>
parents: 6745
diff changeset
   218
!Interval methodsFor:'encoding'!
6f749de322b2 #encodeInterval
Stefan Vogel <sv@exept.de>
parents: 6745
diff changeset
   219
6f749de322b2 #encodeInterval
Stefan Vogel <sv@exept.de>
parents: 6745
diff changeset
   220
encodeOn:anEncoder with:aParameter
6f749de322b2 #encodeInterval
Stefan Vogel <sv@exept.de>
parents: 6745
diff changeset
   221
    "this is special. Some encoders want to encode this as a sequenceable collection,
6f749de322b2 #encodeInterval
Stefan Vogel <sv@exept.de>
parents: 6745
diff changeset
   222
     some want to encode a less expensive representation"
6f749de322b2 #encodeInterval
Stefan Vogel <sv@exept.de>
parents: 6745
diff changeset
   223
6f749de322b2 #encodeInterval
Stefan Vogel <sv@exept.de>
parents: 6745
diff changeset
   224
    anEncoder encodeInterval:self with:aParameter
6f749de322b2 #encodeInterval
Stefan Vogel <sv@exept.de>
parents: 6745
diff changeset
   225
! !
6f749de322b2 #encodeInterval
Stefan Vogel <sv@exept.de>
parents: 6745
diff changeset
   226
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   227
!Interval methodsFor:'enumerating'!
39
bcf183a31bbb *** empty log message ***
claus
parents: 5
diff changeset
   228
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   229
collect:aBlock
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   230
    "evaluate the argument, aBlock for every element in the collection
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   231
     and return a collection of the results - Redefined since SeqColl
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   232
     accesses the receiver via at:, which is slow for intervals"
2
claus
parents: 1
diff changeset
   233
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   234
    |newCollection|
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   235
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   236
    newCollection := self species new:(self size).
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   237
    self do:[:each |
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   238
	newCollection add:(aBlock value:each)
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   239
    ].
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   240
    ^ newCollection
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   241
269
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   242
    "
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   243
     (1 to:20) collect:[:i | i*i]
269
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   244
    "
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   245
!
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   246
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   247
do:aBlock
2
claus
parents: 1
diff changeset
   248
    "evaluate the argument, aBlock for every element in the
269
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   249
     receiver-interval. 
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   250
     Redefined since SeqColl accesses the receiver with at:, which is
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   251
     slow for intervals."
2
claus
parents: 1
diff changeset
   252
3986
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   253
    |aValue iter|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   254
a27a279701f8 Initial revision
claus
parents:
diff changeset
   255
    aValue := start.
3986
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   256
    aValue isInteger ifTrue:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   257
        step < 0 ifTrue:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   258
            [stop <= aValue] whileTrue:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   259
                aBlock value:aValue.
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   260
                aValue := aValue + step
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   261
            ]
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   262
        ] ifFalse:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   263
            [stop >= aValue] whileTrue:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   264
                aBlock value:aValue.
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   265
                aValue := aValue + step
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   266
            ]
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   267
        ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   268
    ] ifFalse:[
3986
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   269
        "/ the code below avoids rounding errors
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   270
        "/ to accumulate if floats are enumerated.
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   271
        iter := 1.
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   272
        step < 0 ifTrue:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   273
            [stop <= aValue] whileTrue:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   274
                aBlock value:aValue.
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   275
                aValue := start + (iter * step).
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   276
                iter := iter + 1.
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   277
            ]
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   278
        ] ifFalse:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   279
            [stop >= aValue] whileTrue:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   280
                aBlock value:aValue.
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   281
                aValue := start + (iter * step).
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   282
                iter := iter + 1.
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   283
            ]
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   284
        ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   285
    ]
3986
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   286
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   287
    "
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   288
     1e7 to:1e7+1 by:0.25 do:[:v | Transcript showCR:v]
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   289
     1.0 to:2.0 by:0.25 do:[:v | Transcript showCR:v]
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   290
     2.0 to:1.0 by:-0.25 do:[:v | Transcript showCR:v]
6532
e6bd5b495eee checkin from browser
Claus Gittinger <cg@exept.de>
parents: 6132
diff changeset
   291
     $a to:$z do:[:v | Transcript showCR:v]
3986
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   292
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   293
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   294
a27a279701f8 Initial revision
claus
parents:
diff changeset
   295
select:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
   296
    "evaluate the argument, aBlock for every element in the collection
a27a279701f8 Initial revision
claus
parents:
diff changeset
   297
     and return a collection of all elements for which the block return
269
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   298
     true. Redefined since SeqColl accesses the receiver with at:, which is
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   299
     slow for intervals."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   300
a27a279701f8 Initial revision
claus
parents:
diff changeset
   301
    |newColl|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   302
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 44
diff changeset
   303
    newColl := self species new:(self size).
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   304
    self do:[:each |
216
a8abff749575 *** empty log message ***
claus
parents: 92
diff changeset
   305
	(aBlock value:each) ifTrue:[newColl add:each]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   306
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   307
    ^ newColl
269
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   308
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   309
    "
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   310
     (1 to:20) select:[:i | i even]
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   311
    "
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   312
! !
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   313
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   314
!Interval methodsFor:'printing & storing'!
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   315
6709
1b91cb019bd6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 6671
diff changeset
   316
displayString
1b91cb019bd6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 6671
diff changeset
   317
    ^ self printString
1b91cb019bd6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 6671
diff changeset
   318
1b91cb019bd6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 6671
diff changeset
   319
    "
1b91cb019bd6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 6671
diff changeset
   320
     (1 to:10) 
1b91cb019bd6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 6671
diff changeset
   321
     (1 to:10 by:2) 
1b91cb019bd6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 6671
diff changeset
   322
    "
1b91cb019bd6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 6671
diff changeset
   323
!
1b91cb019bd6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 6671
diff changeset
   324
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   325
printOn:aStream
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   326
    "append a printed representation to aStream"
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   327
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   328
    start printOn:aStream.
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   329
    aStream nextPutAll:' to:'.
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   330
    stop printOn:aStream.
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   331
    step ~= 1 ifTrue:[
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   332
	aStream nextPutAll:' by:'.
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   333
	step printOn:aStream.
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   334
    ].
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   335
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   336
    "
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   337
     (1 to:10) printOn:Transcript
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   338
     (1 to:10 by:2) printOn:Transcript
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   339
     (1 to:10) printString
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   340
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   341
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   342
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   343
storeOn:aStream
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   344
    "store a representation which can reconstruct the receiver to aStream"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   345
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   346
    aStream nextPut:$(.
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   347
    self printOn:aStream.
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   348
    aStream nextPut:$).
269
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   349
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   350
    "
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   351
     (1 to:10) storeOn:Transcript
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   352
     (1 to:10 by:2) storeOn:Transcript
269
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   353
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   354
! !
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   355
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   356
!Interval methodsFor:'private'!
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   357
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   358
setFrom:startInteger to:stopInteger by:stepInteger
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   359
    "set start, stop and step components"
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   360
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   361
    start := startInteger.
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   362
    stop := stopInteger.
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   363
    step := stepInteger
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   364
!
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   365
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   366
species
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   367
    "return the type of collection to be returned by collect, select etc."
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   368
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   369
    ^ OrderedCollection
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   370
! !
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   371
5557
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   372
!Interval methodsFor:'queries'!
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   373
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   374
size
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   375
    "return the number of elements in the collection"
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   376
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   377
    (step < 0) ifTrue:[
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   378
	(start < stop) ifTrue:[
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   379
	    ^ 0
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   380
	].
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   381
	^ stop - start // step + 1
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   382
    ].
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   383
    (stop < start) ifTrue:[
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   384
	^ 0
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   385
    ].
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   386
    ^ stop - start // step + 1
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   387
! !
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   388
6671
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   389
!Interval methodsFor:'testing'!
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   390
6712
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   391
includes:anElement
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   392
    |rest|
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   393
    stop >= start ifTrue:[
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   394
        (anElement between:start and:stop) ifFalse:[^ false].
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   395
    ] ifFalse:[
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   396
        (anElement between:stop and:start) ifFalse:[^ false].
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   397
    ].
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   398
    rest := (anElement - start) rem:step.
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   399
    ^ rest = 0
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   400
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   401
    "
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   402
     (1 to:15) includes:0
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   403
     (1 to:15) includes:16
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   404
     (1 to:15) includes:1    
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   405
     (1 to:15) includes:15   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   406
     (1 to:15) includes:5    
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   407
     (1 to:15) includes:14   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   408
     (1 to:15) includes:4.0   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   409
     (1 to:15) includes:4.4   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   410
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   411
     (1 to:15 by:3) includes:0
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   412
     (1 to:15 by:3) includes:16
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   413
     (1 to:15 by:3) includes:1    
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   414
     (1 to:15 by:3) includes:15   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   415
     (1 to:15 by:3) includes:5    
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   416
     (1 to:15 by:3) includes:4    
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   417
     (1 to:15 by:3) includes:13   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   418
     (1 to:15 by:3) includes:14   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   419
     (1 to:15 by:3) includes:4.0   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   420
     (1 to:15 by:3) includes:4.4   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   421
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   422
     (10 to:-10 by:-3) includes:11   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   423
     (10 to:-10 by:-3) includes:10   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   424
     (10 to:-10 by:-3) includes:9   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   425
     (10 to:-10 by:-3) includes:8   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   426
     (10 to:-10 by:-3) includes:7   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   427
     (10 to:-10 by:-3) includes:4   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   428
     (10 to:-10 by:-3) includes:0   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   429
     (10 to:-10 by:-3) includes:-1   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   430
     (10 to:-10 by:-3) includes:-2   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   431
     (10 to:-10 by:-3) includes:-8     
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   432
     (10 to:-10 by:-3) includes:-9     
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   433
     (10 to:-10 by:-3) includes:-10    
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   434
     (10 to:-10 by:-3) includes:-11    
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   435
     (10 to:-10 by:-3) includes:-2.4   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   436
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   437
     (-10 to:-20 by:-2) includes:-16   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   438
     (-10 to:-20 by:-2) includes:-20   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   439
     (-10 to:-20 by:-2) includes:-23   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   440
     (-10 to:-20 by:-2) includes:-24   
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   441
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   442
    "
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   443
!
cd031a65139a better #includes:
Claus Gittinger <cg@exept.de>
parents: 6709
diff changeset
   444
6671
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   445
max
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   446
    "return the maximum value in the receiver collection,
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   447
     redefined, since this can be easily computed.
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   448
     Raises an error, if the receiver is empty."
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   449
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   450
    step == 1 ifTrue:[stop >= start ifTrue:[^ stop]].
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   451
    step < 0 ifTrue:[stop <= start ifTrue:[^ start]].
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   452
    ^ super max
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   453
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   454
    "
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   455
     (0 to:15) max           
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   456
     (0 to:15 by:2) max      
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   457
     (0 to:15 by:8) max      
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   458
     (15 to:0) max           -> error
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   459
     (15 to:0 by:4) max      -> error      
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   460
     (-1 to:-15 by:-1) max    
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   461
     (-1 to:-15 by:-4) max    
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   462
     (-1 to:15 by:-1) max    -> error  
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   463
    "
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   464
!
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   465
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   466
min
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   467
    "return the minimum value in the receiver collection,
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   468
     redefined, since this can be easily computed.
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   469
     Raises an error, if the receiver is empty."
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   470
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   471
    step == -1 ifTrue:[stop <= start ifTrue:[^ stop]].
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   472
    step > 0 ifTrue:[stop >= start ifTrue:[^ start]].
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   473
    ^ super min
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   474
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   475
    "
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   476
     (0 to:15) min           
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   477
     (0 to:15 by:2) min      
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   478
     (0 to:15 by:8) min      
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   479
     (15 to:0) min          -> error
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   480
     (15 to:0 by:4) min     -> error     
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   481
     (-1 to:-15 by:-1) min    
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   482
     (-1 to:-15 by:-4) min    
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   483
     (-1 to:15 by:-1) min   -> error   
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   484
    "
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   485
! !
31fcea1083b6 improved #min and #max
Claus Gittinger <cg@exept.de>
parents: 6532
diff changeset
   486
629
2ceefe9b5a19 version at the end
Claus Gittinger <cg@exept.de>
parents: 606
diff changeset
   487
!Interval class methodsFor:'documentation'!
2ceefe9b5a19 version at the end
Claus Gittinger <cg@exept.de>
parents: 606
diff changeset
   488
2ceefe9b5a19 version at the end
Claus Gittinger <cg@exept.de>
parents: 606
diff changeset
   489
version
6747
6f749de322b2 #encodeInterval
Stefan Vogel <sv@exept.de>
parents: 6745
diff changeset
   490
    ^ '$Header: /cvs/stx/stx/libbasic/Interval.st,v 1.35 2002-09-10 12:50:39 stefan Exp $'
629
2ceefe9b5a19 version at the end
Claus Gittinger <cg@exept.de>
parents: 606
diff changeset
   491
! !