Interval.st
author Stefan Vogel <sv@exept.de>
Tue, 28 Apr 2020 14:41:21 +0200
changeset 25372 389daab3ee10
parent 24803 ebf8bfd3e5ba
permissions -rw-r--r--
#DOCUMENTATION by stefan class: ReadWriteStream category of: #isEmpty #isReadable
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
24565
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
     1
"{ Encoding: utf8 }"
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
     2
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     3
"
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
     4
 COPYRIGHT (c) 1989 by Claus Gittinger
8394
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
     5
              All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
"
5521
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
    14
"{ Package: 'stx:libbasic' }"
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
    15
18510
a8715bcdf70b class: Interval
Claus Gittinger <cg@exept.de>
parents: 16746
diff changeset
    16
"{ NameSpace: Smalltalk }"
a8715bcdf70b class: Interval
Claus Gittinger <cg@exept.de>
parents: 16746
diff changeset
    17
6132
615c4fe0f449 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5672
diff changeset
    18
ReadOnlySequenceableCollection subclass:#Interval
8940
b05bb4dd96b3 collect returns an Array if possible
Claus Gittinger <cg@exept.de>
parents: 8394
diff changeset
    19
	instanceVariableNames:'start stop step'
b05bb4dd96b3 collect returns an Array if possible
Claus Gittinger <cg@exept.de>
parents: 8394
diff changeset
    20
	classVariableNames:''
b05bb4dd96b3 collect returns an Array if possible
Claus Gittinger <cg@exept.de>
parents: 8394
diff changeset
    21
	poolDictionaries:''
b05bb4dd96b3 collect returns an Array if possible
Claus Gittinger <cg@exept.de>
parents: 8394
diff changeset
    22
	category:'Collections-Sequenceable'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    23
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    24
88
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    25
!Interval class methodsFor:'documentation'!
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    26
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    27
copyright
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    28
"
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    29
 COPYRIGHT (c) 1989 by Claus Gittinger
8394
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
    30
              All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    31
88
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    32
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    33
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    34
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    35
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    36
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    37
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    38
"
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    39
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    40
88
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    41
documentation
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    42
"
24565
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
    43
    Intervals represent a collection (or range) of numeric or character values specified by
269
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
    44
    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
    45
    The interesting thing is that the elements are computed, not stored.
11409
82874ed12ab4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11270
diff changeset
    46
    However, protocol-wise, intervals behave like any other (read-only) sequenceable collection.
82874ed12ab4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11270
diff changeset
    47
88
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    48
    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
    49
    (1 to:6 by:2) contains (1 3 5).
339
claus
parents: 328
diff changeset
    50
18511
f123160b648b class: Interval
Claus Gittinger <cg@exept.de>
parents: 18510
diff changeset
    51
    The step may be negative, to count backward:
f123160b648b class: Interval
Claus Gittinger <cg@exept.de>
parents: 18510
diff changeset
    52
    (5 to:1 by:-1) contains (5 4 3 2 1), and (6 to:1 by:-2) contains (6 4 2).
f123160b648b class: Interval
Claus Gittinger <cg@exept.de>
parents: 18510
diff changeset
    53
24565
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
    54
    examples:
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
    55
        (10 to: 20)         
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
    56
        (10 to: 20) asArray 
18511
f123160b648b class: Interval
Claus Gittinger <cg@exept.de>
parents: 18510
diff changeset
    57
24565
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
    58
        (20 to:10 by:-2)      
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
    59
        (20 to:10 by:-2) asArray    
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
    60
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
    61
        ($a to:$z)                
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
    62
        ($a to:$z) asString          
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
    63
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
    64
        ($a to:$z),($A to:$Z)       
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
    65
        (($a to:$z),($A to:$Z)) asString 
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
    66
        (($a to:$z),'bla')      
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
    67
        ('bla',($a to:$z))       
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
    68
        ((Character value:16r100) to:(Character value:16r120))           
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
    69
        ((Character value:16r100) to:(Character value:16r120)) asString      
339
claus
parents: 328
diff changeset
    70
8394
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
    71
        (1 to:10) do:[:i | Transcript showCR:i]
339
claus
parents: 328
diff changeset
    72
claus
parents: 328
diff changeset
    73
      notice, that this is semantically equivalent to:
claus
parents: 328
diff changeset
    74
8394
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
    75
        1 to:10 do:[:i | Transcript showCR:i]
339
claus
parents: 328
diff changeset
    76
claus
parents: 328
diff changeset
    77
      however, the second is preferred, since loops using to:do: are
claus
parents: 328
diff changeset
    78
      much faster and do not create temporary garbage objects. 
claus
parents: 328
diff changeset
    79
      Therefore, Intervals are generally NOT used for this kind of loops.
claus
parents: 328
diff changeset
    80
8394
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
    81
        (1 to:10) asArray  
339
claus
parents: 328
diff changeset
    82
8394
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
    83
        (1 to:10 by:2) asOrderedCollection  
1290
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 759
diff changeset
    84
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 759
diff changeset
    85
    [author:]
8394
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
    86
        Claus Gittinger
88
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    87
"
81dacba7a63a *** empty log message ***
claus
parents: 70
diff changeset
    88
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    89
a27a279701f8 Initial revision
claus
parents:
diff changeset
    90
!Interval class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    91
a27a279701f8 Initial revision
claus
parents:
diff changeset
    92
from:start to:stop
11409
82874ed12ab4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11270
diff changeset
    93
    "return a new interval with elements from start to stop by 1"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    94
2
claus
parents: 1
diff changeset
    95
    ^ self new setFrom:start to:stop by:1
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    96
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    97
a27a279701f8 Initial revision
claus
parents:
diff changeset
    98
from:start to:stop by:step
11409
82874ed12ab4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11270
diff changeset
    99
    "return a new interval with elements from start to stop by step"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   100
2
claus
parents: 1
diff changeset
   101
    ^ self new setFrom:start to:stop by:step
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   102
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   103
5672
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   104
!Interval class methodsFor:'converting'!
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   105
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   106
decodeFromLiteralArray:anArray
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   107
    "create & return a new instance from information encoded in anArray.
9411
5e2a6ab94c0a Fix comments.
Stefan Vogel <sv@exept.de>
parents: 8940
diff changeset
   108
     Re-redefined, since the implementation in SequencableCollection creates instances with an initial
5e2a6ab94c0a Fix comments.
Stefan Vogel <sv@exept.de>
parents: 8940
diff changeset
   109
     size, which is not allowed for intervals."
5672
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   110
6132
615c4fe0f449 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5672
diff changeset
   111
    ^ self new fromLiteralArrayEncoding:anArray.
615c4fe0f449 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5672
diff changeset
   112
! !
5672
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   113
24608
243fe7a2a7fb #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 24565
diff changeset
   114
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   115
!Interval methodsFor:'accessing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   116
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   117
at:index
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   118
    "return (i.e. compute) the index'th element"
2
claus
parents: 1
diff changeset
   119
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   120
    (index between:1 and:self size) ifTrue:[
5521
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   121
        ^ start + (step * (index - 1))
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   122
    ].
5521
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   123
    ^ self subscriptBoundsError:index
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   124
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   125
a27a279701f8 Initial revision
claus
parents:
diff changeset
   126
first
a27a279701f8 Initial revision
claus
parents:
diff changeset
   127
    "return the first element of the collection"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   128
5521
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   129
    (((step < 0) and:[start < stop])
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   130
    or:[(step > 0) and:[stop < start]]) ifTrue:[
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   131
        ^ self emptyCollectionError
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   132
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   133
    ^ start
a27a279701f8 Initial revision
claus
parents:
diff changeset
   134
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   135
328
claus
parents: 269
diff changeset
   136
increment 
339
claus
parents: 328
diff changeset
   137
    "alias for #step; for ST-80 compatibility"
328
claus
parents: 269
diff changeset
   138
claus
parents: 269
diff changeset
   139
    ^ step
claus
parents: 269
diff changeset
   140
!
claus
parents: 269
diff changeset
   141
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   142
last
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   143
    "return the last element of the collection"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   144
5521
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   145
    (((step < 0) and:[start < stop])
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   146
    or:[(step > 0) and:[stop < start]]) ifTrue:[
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   147
        ^ self emptyCollectionError
7cad30b0ade9 fixed empty collection error handling
Claus Gittinger <cg@exept.de>
parents: 4155
diff changeset
   148
    ].
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   149
    ^ stop
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   150
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   151
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   152
start
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   153
    "return the first number of the range"
2
claus
parents: 1
diff changeset
   154
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   155
    ^ start
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   156
!
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   157
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   158
start:aNumber
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   159
    "set the first number of the range"
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
    start := aNumber
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   162
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   163
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   164
step
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   165
    "return the step increment of the range.
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   166
     OBSOLETE: 
8394
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
   167
        Please use #increment for ST-80 compatibility."
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   168
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   169
    ^ step
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   170
!
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   171
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   172
step:aNumber
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   173
    "set the step increment of the range"
2
claus
parents: 1
diff changeset
   174
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   175
    step := aNumber
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   176
!
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   177
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   178
stop
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   179
    "return the end number of the range"
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   180
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   181
    ^ stop
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   182
!
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   183
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   184
stop:aNumber
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   185
    "set the end number of the range"
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   186
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   187
    stop := aNumber
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   188
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   189
11477
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   190
!Interval methodsFor:'bulk operations'!
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   191
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   192
sum
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   193
    "sum up all elements."
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   194
19253
45c2b67527f1 #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 18511
diff changeset
   195
    "/              n*(n+1)
45c2b67527f1 #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 18511
diff changeset
   196
    "/ sum(1..n) is -------
11503
f41906ac7352 changed #sum
Claus Gittinger <cg@exept.de>
parents: 11477
diff changeset
   197
    "/                 2
19253
45c2b67527f1 #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 18511
diff changeset
   198
    
11477
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   199
    start < stop ifTrue:[
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   200
        step == 1 ifTrue:[
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   201
            start == 1 ifTrue:[
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   202
                ^ (stop * (stop + 1) / 2)
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   203
            ].
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   204
            ^ (stop * (stop + 1) / 2) - ((start-1) * (start ) / 2)
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   205
        ]
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   206
    ].
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   207
    "/ could add more optimizations here, but who needs them?
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   208
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   209
    ^ super sum
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   210
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   211
    "
11503
f41906ac7352 changed #sum
Claus Gittinger <cg@exept.de>
parents: 11477
diff changeset
   212
     (1 to:10) sum         
f41906ac7352 changed #sum
Claus Gittinger <cg@exept.de>
parents: 11477
diff changeset
   213
     (1 to:10) asArray sum 
11477
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   214
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   215
     (2 to:10) sum           
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   216
     (2 to:10) asArray sum   
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   217
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   218
     (5 to:10) sum    
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   219
     (5 to:10) asArray sum     
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   220
    "
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   221
! !
2a46e08433d3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11409
diff changeset
   222
6745
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   223
!Interval methodsFor:'comparing'!
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   224
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   225
= anInterval
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   226
    anInterval class == self class ifTrue:[
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   227
        ^ start = anInterval start
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   228
        and:[ stop = anInterval stop
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   229
        and:[ step = anInterval step]]
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   230
    ].
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   231
    ^ super = anInterval
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   232
!
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   233
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   234
hash
6748
604366d06326 hash: must be same as SeqColl hash; inherit
Claus Gittinger <cg@exept.de>
parents: 6747
diff changeset
   235
    ^ super hash "/ do not redefine: must generate same hash as SeqColl.
6745
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   236
! !
c2c52940ec99 better hash and compare
Claus Gittinger <cg@exept.de>
parents: 6712
diff changeset
   237
5672
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   238
!Interval methodsFor:'converting'!
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   239
20695
9d2b822f6162 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 19462
diff changeset
   240
asInterval
9d2b822f6162 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 19462
diff changeset
   241
    ^ self.
9d2b822f6162 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 19462
diff changeset
   242
!
9d2b822f6162 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 19462
diff changeset
   243
5672
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   244
fromLiteralArrayEncoding:encoding
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   245
    "read my values from an encoding.
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   246
     The encoding is supposed to be either of the form: 
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   247
        (#Interval start stop step)
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   248
     This is the reverse operation to #literalArrayEncoding."
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   249
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   250
    start := (encoding at:2).
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   251
    stop := (encoding at:3). 
10794
b37d77576d77 allow for missing step in literalArrayEncoding
Michael Beyl <mb@exept.de>
parents: 9411
diff changeset
   252
    (encoding size > 3) ifTrue:[ 
b37d77576d77 allow for missing step in literalArrayEncoding
Michael Beyl <mb@exept.de>
parents: 9411
diff changeset
   253
        step := (encoding at:4).
b37d77576d77 allow for missing step in literalArrayEncoding
Michael Beyl <mb@exept.de>
parents: 9411
diff changeset
   254
    ] ifFalse:[
b37d77576d77 allow for missing step in literalArrayEncoding
Michael Beyl <mb@exept.de>
parents: 9411
diff changeset
   255
        step := 1.
b37d77576d77 allow for missing step in literalArrayEncoding
Michael Beyl <mb@exept.de>
parents: 9411
diff changeset
   256
    ]
5672
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   257
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   258
    "
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   259
     Interval new fromLiteralArrayEncoding:((1 to:10) literalArrayEncoding)  
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   260
     Interval new fromLiteralArrayEncoding:((1 to:10 by:2) literalArrayEncoding) 
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   261
     Interval decodeFromLiteralArray:((1 to:10 by:2) literalArrayEncoding) 
6132
615c4fe0f449 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5672
diff changeset
   262
    "
615c4fe0f449 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5672
diff changeset
   263
!
5672
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   264
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   265
literalArrayEncoding
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   266
    "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
   267
     can be reconstructed with #decodeAsLiteralArray."
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   268
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   269
    ^ Array
9411
5e2a6ab94c0a Fix comments.
Stefan Vogel <sv@exept.de>
parents: 8940
diff changeset
   270
        with:self class name
5672
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   271
        with:start
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   272
        with:stop
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   273
        with:step
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   274
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   275
    "
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   276
     (1 to:10) literalArrayEncoding      
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   277
     (1 to:10 by:2) literalArrayEncoding
6132
615c4fe0f449 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5672
diff changeset
   278
    "
615c4fe0f449 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 5672
diff changeset
   279
! !
5672
bd82b2b8c930 literalArrayEncoding fixed
Claus Gittinger <cg@exept.de>
parents: 5557
diff changeset
   280
8374
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   281
!Interval methodsFor:'converting-reindexed'!
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   282
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   283
from:startIndex
19462
4f67bb0b9182 #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 19253
diff changeset
   284
    "return a new collection representing the receiver's elements starting at startIndex."
8374
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   285
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   286
    step == 1 ifTrue:[
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   287
        ^ start+startIndex-1 to:stop
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   288
    ].
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   289
    "could be more intelligent here"
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   290
    ^ super from:startIndex
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   291
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   292
    "
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   293
     (1 to:100) from:2  
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   294
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   295
     (1 to:20 by:2) from:2           
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   296
     (1 to:20 by:2) asArray from:2    
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   297
     ((1 to:20 by:2) from:2) asArray   
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   298
    "
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   299
!
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   300
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   301
to:endIndex
19462
4f67bb0b9182 #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 19253
diff changeset
   302
    "return a new collection representing the receiver's elements upTo and including endIndex."
8374
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   303
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   304
    ^ start to:(endIndex min:stop) by:step
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   305
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   306
    "
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   307
     (1 to:100) to:50    
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   308
     (1 to:100 by:2) to:50    
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   309
    "
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   310
! !
a5d76d47cc70 reindexing methods
Claus Gittinger <cg@exept.de>
parents: 7823
diff changeset
   311
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   312
!Interval methodsFor:'enumerating'!
39
bcf183a31bbb *** empty log message ***
claus
parents: 5
diff changeset
   313
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   314
collect:aBlock
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   315
    "evaluate the argument, aBlock for every element in the collection
11270
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   316
     and return a collection of the results.
14128
32cf030cebca changed: #collect:
Claus Gittinger <cg@exept.de>
parents: 13074
diff changeset
   317
     Redefined since the inherited method (SeqColl) accesses the receiver via at:, 
32cf030cebca changed: #collect:
Claus Gittinger <cg@exept.de>
parents: 13074
diff changeset
   318
     which is slow for intervals"
2
claus
parents: 1
diff changeset
   319
22297
8ce92cf4fafc #TUNING by stefan
Stefan Vogel <sv@exept.de>
parents: 21541
diff changeset
   320
    |elementValue newCollection
8ce92cf4fafc #TUNING by stefan
Stefan Vogel <sv@exept.de>
parents: 21541
diff changeset
   321
     mySize "{Class: SmallInteger}"|
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   322
14128
32cf030cebca changed: #collect:
Claus Gittinger <cg@exept.de>
parents: 13074
diff changeset
   323
    elementValue := start.
22297
8ce92cf4fafc #TUNING by stefan
Stefan Vogel <sv@exept.de>
parents: 21541
diff changeset
   324
    mySize := self size.
8ce92cf4fafc #TUNING by stefan
Stefan Vogel <sv@exept.de>
parents: 21541
diff changeset
   325
    newCollection := self species newWithSize:mySize.
14128
32cf030cebca changed: #collect:
Claus Gittinger <cg@exept.de>
parents: 13074
diff changeset
   326
    1 to: mySize do:[:i |
32cf030cebca changed: #collect:
Claus Gittinger <cg@exept.de>
parents: 13074
diff changeset
   327
        newCollection at:i put:(aBlock value:elementValue).
32cf030cebca changed: #collect:
Claus Gittinger <cg@exept.de>
parents: 13074
diff changeset
   328
        elementValue := elementValue + step.
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   329
    ].
14128
32cf030cebca changed: #collect:
Claus Gittinger <cg@exept.de>
parents: 13074
diff changeset
   330
    ^ newCollection    
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   331
269
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   332
    "
14128
32cf030cebca changed: #collect:
Claus Gittinger <cg@exept.de>
parents: 13074
diff changeset
   333
     (1 to:20 by:2) collect:[:i | i*i]              
269
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   334
    "
11270
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   335
14129
b0b377ad4df1 changed: #collect:
Claus Gittinger <cg@exept.de>
parents: 14128
diff changeset
   336
    "Modified: / 04-05-2012 / 13:03:56 / cg"
22297
8ce92cf4fafc #TUNING by stefan
Stefan Vogel <sv@exept.de>
parents: 21541
diff changeset
   337
    "Modified: / 09-10-2017 / 16:59:10 / stefan"
44
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   338
!
b262907c93ea *** empty log message ***
claus
parents: 39
diff changeset
   339
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   340
do:aBlock
11270
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   341
    "evaluate the argument, aBlock for every element in the receiver-interval. 
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   342
     Redefined since SeqColl accesses the receiver with at:, which is slow for intervals."
2
claus
parents: 1
diff changeset
   343
3986
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   344
    |aValue iter|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   345
a27a279701f8 Initial revision
claus
parents:
diff changeset
   346
    aValue := start.
3986
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   347
    aValue isInteger ifTrue:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   348
        step < 0 ifTrue:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   349
            [stop <= aValue] whileTrue:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   350
                aBlock value:aValue.
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   351
                aValue := aValue + step
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   352
            ]
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   353
        ] ifFalse:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   354
            [stop >= aValue] whileTrue:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   355
                aBlock value:aValue.
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   356
                aValue := aValue + step
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   357
            ]
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   358
        ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   359
    ] ifFalse:[
3986
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   360
        "/ the code below avoids rounding errors
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   361
        "/ to accumulate if floats are enumerated.
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   362
        iter := 1.
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   363
        step < 0 ifTrue:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   364
            [stop <= aValue] whileTrue:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   365
                aBlock value:aValue.
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   366
                aValue := start + (iter * step).
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   367
                iter := iter + 1.
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   368
            ]
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   369
        ] ifFalse:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   370
            [stop >= aValue] whileTrue:[
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   371
                aBlock value:aValue.
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   372
                aValue := start + (iter * step).
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   373
                iter := iter + 1.
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   374
            ]
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   375
        ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   376
    ]
3986
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   377
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   378
    "
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   379
     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
   380
     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
   381
     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
   382
     $a to:$z do:[:v | Transcript showCR:v]
3986
2ad4ebb5ebbb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1998
diff changeset
   383
    "
11270
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   384
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   385
    "Modified: / 22-10-2008 / 12:47:30 / cg"
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   386
!
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   387
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   388
reverseDo:aBlock
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   389
    "evaluate the argument, aBlock for every element in the receiver-interval in
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   390
     reverse order. 
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   391
     Redefined since SeqColl accesses the receiver with at:, which is slow for intervals."
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   392
24608
243fe7a2a7fb #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 24565
diff changeset
   393
    self reversed do:aBlock
11270
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   394
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   395
    "
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   396
     (1 to:10) do:[:el | Transcript showCR:el ].
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   397
     (1 to:10) reverseDo:[:el | Transcript showCR:el ].
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   398
    "
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   399
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   400
    "Modified: / 22-10-2008 / 12:49:28 / cg"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   401
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   402
a27a279701f8 Initial revision
claus
parents:
diff changeset
   403
select:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
   404
    "evaluate the argument, aBlock for every element in the collection
24803
ebf8bfd3e5ba #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 24608
diff changeset
   405
     and return a collection of all elements for which the block returns true. 
11270
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   406
     Redefined since SeqColl accesses the receiver with at:, which is slow for intervals."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   407
a27a279701f8 Initial revision
claus
parents:
diff changeset
   408
    |newColl|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   409
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 44
diff changeset
   410
    newColl := self species new:(self size).
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   411
    self do:[:each |
8394
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
   412
        (aBlock value:each) ifTrue:[newColl add:each]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   413
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   414
    ^ newColl
269
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   415
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   416
    "
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   417
     (1 to:20) select:[:i | i even]
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   418
    "
11270
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   419
a616ba9b7f81 +reverseDo:
Claus Gittinger <cg@exept.de>
parents: 11266
diff changeset
   420
    "Modified: / 22-10-2008 / 12:47:41 / cg"
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   421
! !
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   422
16709
447e55afc5fe class: Interval
Claus Gittinger <cg@exept.de>
parents: 14129
diff changeset
   423
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   424
!Interval methodsFor:'printing & storing'!
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   425
13074
cbbd50931549 Implement display with #displayOn: instead of #displayString
Stefan Vogel <sv@exept.de>
parents: 11903
diff changeset
   426
displayOn:aGCOrStream
cbbd50931549 Implement display with #displayOn: instead of #displayString
Stefan Vogel <sv@exept.de>
parents: 11903
diff changeset
   427
cbbd50931549 Implement display with #displayOn: instead of #displayString
Stefan Vogel <sv@exept.de>
parents: 11903
diff changeset
   428
    "/ what a kludge - Dolphin and Squeak mean: printOn: a stream;
21541
882a0e63f32a #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 20695
diff changeset
   429
    "/ old ST80 means: draw-yourself on a GC.
882a0e63f32a #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 20695
diff changeset
   430
    (aGCOrStream isStream) ifFalse:[
882a0e63f32a #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 20695
diff changeset
   431
        ^ super displayOn:aGCOrStream
13074
cbbd50931549 Implement display with #displayOn: instead of #displayString
Stefan Vogel <sv@exept.de>
parents: 11903
diff changeset
   432
    ].
21541
882a0e63f32a #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 20695
diff changeset
   433
882a0e63f32a #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 20695
diff changeset
   434
    self printOn:aGCOrStream.
6709
1b91cb019bd6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 6671
diff changeset
   435
1b91cb019bd6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 6671
diff changeset
   436
    "
1b91cb019bd6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 6671
diff changeset
   437
     (1 to:10) 
1b91cb019bd6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 6671
diff changeset
   438
     (1 to:10 by:2) 
1b91cb019bd6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 6671
diff changeset
   439
    "
21541
882a0e63f32a #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 20695
diff changeset
   440
882a0e63f32a #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 20695
diff changeset
   441
    "Modified: / 22-02-2017 / 17:00:56 / cg"
6709
1b91cb019bd6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 6671
diff changeset
   442
!
1b91cb019bd6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 6671
diff changeset
   443
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   444
printOn:aStream
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   445
    "append a printed representation to aStream"
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   446
24565
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
   447
    start storeOn:aStream.
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   448
    aStream nextPutAll:' to:'.
24565
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
   449
    stop storeOn:aStream.
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   450
    step ~= 1 ifTrue:[
8394
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
   451
        aStream nextPutAll:' by:'.
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
   452
        step printOn:aStream.
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   453
    ].
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   454
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   455
    "
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   456
     (1 to:10) printOn:Transcript
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   457
     (1 to:10 by:2) printOn:Transcript
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   458
     (1 to:10) printString
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   459
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   460
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   461
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   462
storeOn:aStream
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   463
    "store a representation which can reconstruct the receiver to aStream"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   464
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   465
    aStream nextPut:$(.
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   466
    self printOn:aStream.
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   467
    aStream nextPut:$).
269
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   468
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   469
    "
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   470
     (1 to:10) storeOn:Transcript
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   471
     (1 to:10 by:2) storeOn:Transcript
269
93162487a94b *** empty log message ***
claus
parents: 216
diff changeset
   472
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   473
! !
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   474
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   475
!Interval methodsFor:'private'!
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   476
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   477
setFrom:startInteger to:stopInteger by:stepInteger
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   478
    "set start, stop and step components"
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   479
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   480
    start := startInteger.
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   481
    stop := stopInteger.
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   482
    step := stepInteger
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   483
!
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   484
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   485
species
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   486
    "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
   487
24565
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
   488
    start isCharacter ifTrue:[
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
   489
        ^ String speciesForCharacterSize:(start characterSize max:stop characterSize).
15958103b2af #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 23704
diff changeset
   490
    ].
606
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   491
    ^ OrderedCollection
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   492
! !
7a9ab63a6757 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   493
5557
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   494
!Interval methodsFor:'queries'!
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   495
23704
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   496
includes:anElement
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   497
    "return true if anElement is in the interval (Numeric compare using =)"
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   498
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   499
    |rest|
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   500
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   501
    stop >= start ifTrue:[
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   502
        (anElement between:start and:stop) ifFalse:[^ false].
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   503
    ] ifFalse:[
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   504
        (anElement between:stop and:start) ifFalse:[^ false].
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   505
    ].
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   506
    rest := (anElement - start) rem:step.
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   507
    ^ rest = 0
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   508
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   509
    "
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   510
     (1 to:15) includes:0
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   511
     (1 to:15) includes:16
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   512
     (1 to:15) includes:1    
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   513
     (1 to:15) includes:15   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   514
     (1 to:15) includes:5    
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   515
     (1 to:15) includes:14   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   516
     (1 to:15) includes:4   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   517
     (1 to:15) includes:4.0   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   518
     (1 to:15) includes:4.4   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   519
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   520
     (1 to:15 by:3) includes:0
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   521
     (1 to:15 by:3) includes:16
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   522
     (1 to:15 by:3) includes:1    
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   523
     (1 to:15 by:3) includes:15   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   524
     (1 to:15 by:3) includes:5    
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   525
     (1 to:15 by:3) includes:4    
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   526
     (1 to:15 by:3) includes:13   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   527
     (1 to:15 by:3) includes:14   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   528
     (1 to:15 by:3) includes:4.0   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   529
     (1 to:15 by:3) includes:4.4   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   530
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   531
     (10 to:-10 by:-3) includes:11   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   532
     (10 to:-10 by:-3) includes:10   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   533
     (10 to:-10 by:-3) includes:9   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   534
     (10 to:-10 by:-3) includes:8   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   535
     (10 to:-10 by:-3) includes:7   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   536
     (10 to:-10 by:-3) includes:4   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   537
     (10 to:-10 by:-3) includes:0   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   538
     (10 to:-10 by:-3) includes:-1   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   539
     (10 to:-10 by:-3) includes:-2   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   540
     (10 to:-10 by:-3) includes:-8     
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   541
     (10 to:-10 by:-3) includes:-9     
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   542
     (10 to:-10 by:-3) includes:-10    
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   543
     (10 to:-10 by:-3) includes:-11    
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   544
     (10 to:-10 by:-3) includes:-2.4   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   545
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   546
     (-10 to:-20 by:-2) includes:-16   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   547
     (-10 to:-20 by:-2) includes:-20   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   548
     (-10 to:-20 by:-2) includes:-23   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   549
     (-10 to:-20 by:-2) includes:-24   
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   550
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   551
    "
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   552
!
bb2dd8bedf16 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23687
diff changeset
   553
23687
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   554
isEmpty
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   555
    "return true, if the receiver is empty"
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   556
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   557
    step > 0 ifTrue:[
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   558
        ^ stop < start
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   559
    ].
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   560
    ^ stop > start
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   561
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   562
    "
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   563
     self assert:(1 to:1) isEmpty not
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   564
     self assert:(1 to:0) isEmpty 
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   565
     self assert:(0 to:1) isEmpty not
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   566
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   567
     self assert:(1 to:1 by:-1) isEmpty not
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   568
     self assert:(1 to:0 by:-1) isEmpty not
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   569
     self assert:(0 to:1 by:-1) isEmpty
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   570
    "
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   571
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   572
    "Created: / 09-02-2019 / 15:24:32 / Claus Gittinger"
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   573
!
d50488d89e81 #TUNING by cg
Claus Gittinger <cg@exept.de>
parents: 22297
diff changeset
   574
7823
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   575
max
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   576
    "return the maximum value in the receiver collection,
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   577
     redefined, since this can be easily computed.
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   578
     Raises an error, if the receiver is empty."
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   579
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   580
    step == 1 ifTrue:[stop >= start ifTrue:[^ stop]].
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   581
    step < 0 ifTrue:[stop <= start ifTrue:[^ start]].
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   582
    ^ super max
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   583
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   584
    "
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   585
     (0 to:15) max           
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   586
     (0 to:15 by:2) max      
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   587
     (0 to:15 by:8) max      
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   588
     (15 to:0) max           -> error
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   589
     (15 to:0 by:4) max      -> error      
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   590
     (-1 to:-15 by:-1) max    
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   591
     (-1 to:-15 by:-4) max    
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   592
     (-1 to:15 by:-1) max    -> error  
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   593
    "
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   594
!
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   595
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   596
min
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   597
    "return the minimum value in the receiver collection,
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   598
     redefined, since this can be easily computed.
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   599
     Raises an error, if the receiver is empty."
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   600
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   601
    step == -1 ifTrue:[stop <= start ifTrue:[^ stop]].
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   602
    step > 0 ifTrue:[stop >= start ifTrue:[^ start]].
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   603
    ^ super min
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   604
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   605
    "
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   606
     (0 to:15) min           
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   607
     (0 to:15 by:2) min      
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   608
     (0 to:15 by:8) min      
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   609
     (15 to:0) min          -> error
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   610
     (15 to:0 by:4) min     -> error     
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   611
     (-1 to:-15 by:-1) min    
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   612
     (-1 to:-15 by:-4) min    
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   613
     (-1 to:15 by:-1) min   -> error   
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   614
    "
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   615
!
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   616
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   617
minMax
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   618
    "return the minimum and maximum values in the receiver collection
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   619
     as a two element array.
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   620
     Raises an error, if the receiver is empty."
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   621
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   622
    step == -1 ifTrue:[
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   623
        stop <= start ifTrue:[
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   624
            ^ Array with:stop with:start
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   625
        ]
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   626
    ].
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   627
    step == 1 ifTrue:[
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   628
        stop >= start ifTrue:[
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   629
            ^ Array with:start with:stop
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   630
        ]
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   631
    ].
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   632
    ^ super minMax
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   633
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   634
    "
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   635
     (0 to:15) minMax           
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   636
     (0 to:15 by:2) minMax      
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   637
     (0 to:15 by:8) minMax      
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   638
     (15 to:0) minMax          -> error
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   639
     (15 to:0 by:4) minMax     -> error     
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   640
     (-1 to:-15 by:-1) minMax    
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   641
     (-1 to:-15 by:-4) minMax    
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   642
     (-1 to:15 by:-1) minMax   -> error   
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   643
    "
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   644
!
4a31fa10c6eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 7821
diff changeset
   645
5557
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   646
size
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   647
    "return the number of elements in the collection"
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   648
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   649
    (step < 0) ifTrue:[
8394
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
   650
        (start < stop) ifTrue:[
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
   651
            ^ 0
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
   652
        ].
18510
a8715bcdf70b class: Interval
Claus Gittinger <cg@exept.de>
parents: 16746
diff changeset
   653
        ^ (start - stop) // step abs + 1
5557
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   654
    ].
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   655
    (stop < start) ifTrue:[
8394
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
   656
        ^ 0
5557
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   657
    ].
18510
a8715bcdf70b class: Interval
Claus Gittinger <cg@exept.de>
parents: 16746
diff changeset
   658
    ^ (stop - start) // step + 1
5557
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   659
! !
f5f8d236027c category change
Claus Gittinger <cg@exept.de>
parents: 5521
diff changeset
   660
11902
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   661
!Interval methodsFor:'set operations'!
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   662
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   663
intersect:aCollection
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   664
    "return a new interval containing all elements of the receiver, 
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   665
     which are also contained in the argument collection"
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   666
11903
51f288f62b3b +intersect:
Claus Gittinger <cg@exept.de>
parents: 11902
diff changeset
   667
    "/ could be much more intelligent here...
11902
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   668
    aCollection class == Interval ifTrue:[
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   669
        aCollection step = step ifTrue:[
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   670
            step = 1 ifTrue:[
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   671
                (self includes:aCollection start) ifTrue:[
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   672
                    ^ (start max:(aCollection start)) to:(stop min:(aCollection stop))
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   673
                ].
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   674
                (self includes:aCollection stop) ifTrue:[
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   675
                    ^ (start max:(aCollection start)) to:(stop min:(aCollection stop))
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   676
                ]
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   677
            ]
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   678
        ].
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   679
    ].
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   680
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   681
    ^ super intersect:aCollection
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   682
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   683
    "
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   684
     (1 to:10) intersect:(4 to:20)      
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   685
     (1 to:10) intersect:(11 to:20)      
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   686
     (1 to:10) intersect:(10 to:20)      
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   687
     (4 to:20) intersect:(1 to:10)      
11903
51f288f62b3b +intersect:
Claus Gittinger <cg@exept.de>
parents: 11902
diff changeset
   688
     (4 to:20) intersect:(1 to:10 by:2)      
11902
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   689
    "
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   690
! !
46d00f94328e +intersect:
Claus Gittinger <cg@exept.de>
parents: 11503
diff changeset
   691
11266
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   692
!Interval methodsFor:'sorting & reordering'!
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   693
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   694
reversed
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   695
    "return a copy with elements in reverse order"
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   696
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   697
    "this can be tricky, if stepping from start does not reach stop exactly.
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   698
     So what is the reverse of: (2 to:5 by: 2) ?
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   699
     I think, that the correct semantic is to behave transparent to the type
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   700
     of collection and generate the same elements as another collection would.
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   701
     In other words, the same as (1 to:5 by: 2) asOrderedCollection reversed
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   702
     would. That means, we get: #(4 2).
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   703
     This also means, that (2 to:5 by: 2) reversed reversed does not return the
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   704
     original, but another interval which generates the same elements !! (2 to:4 by: 2)"
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   705
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   706
    |rest|
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   707
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   708
    step isInteger ifTrue:[
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   709
        rest := ((stop - step) rem: step).
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   710
        ^ (stop-rest) to:start by:step negated
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   711
    ].
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   712
    ^ super reversed
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   713
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   714
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   715
    "
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   716
     (1 to:4) reversed asOrderedCollection   
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   717
     (1 to:4) reversed reversed asOrderedCollection 
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   718
     (1 to:4) asOrderedCollection reversed    
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   719
     (1 to:4) asOrderedCollection reversed reversed 
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   720
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   721
     (2 to:5 by: 2) asOrderedCollection     
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   722
     (2 to:5 by: 2) asOrderedCollection reversed    
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   723
     (2 to:5 by: 2) asOrderedCollection reversed reversed  
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   724
     (2 to:5 by: 2) reversed asOrderedCollection         
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   725
     (2 to:5 by: 2) reversed reversed asOrderedCollection   
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   726
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   727
     (1 to:2 by: 0.3) asOrderedCollection        
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   728
     (1 to:2 by: 0.3) asOrderedCollection reversed  
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   729
     (1 to:2 by: 0.3) asOrderedCollection reversed reversed  
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   730
     (1 to:2 by: 0.3) reversed asOrderedCollection     
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   731
     (1 to:2 by: 0.3) reversed reversed asOrderedCollection     
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   732
    "
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   733
! !
4f9e413eba36 reversed
Claus Gittinger <cg@exept.de>
parents: 10794
diff changeset
   734
8394
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
   735
!Interval methodsFor:'visiting'!
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
   736
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
   737
acceptVisitor:aVisitor with:aParameter
16722
bd92f75ab297 comment/format only
Claus Gittinger <cg@exept.de>
parents: 16709
diff changeset
   738
    "dispatch for visitor pattern; send #visitInterval:with: to aVisitor.
bd92f75ab297 comment/format only
Claus Gittinger <cg@exept.de>
parents: 16709
diff changeset
   739
     this is special. Some encoders want to encode this as a sequenceable collection,
8394
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
   740
     some want to encode a less expensive representation"
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
   741
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
   742
    ^ aVisitor visitInterval:self with:aParameter
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
   743
! !
da194de43766 Generalize visitor pattern and define #visit...:with: -methods instead
Stefan Vogel <sv@exept.de>
parents: 8374
diff changeset
   744
629
2ceefe9b5a19 version at the end
Claus Gittinger <cg@exept.de>
parents: 606
diff changeset
   745
!Interval class methodsFor:'documentation'!
2ceefe9b5a19 version at the end
Claus Gittinger <cg@exept.de>
parents: 606
diff changeset
   746
2ceefe9b5a19 version at the end
Claus Gittinger <cg@exept.de>
parents: 606
diff changeset
   747
version
18510
a8715bcdf70b class: Interval
Claus Gittinger <cg@exept.de>
parents: 16746
diff changeset
   748
    ^ '$Header$'
13074
cbbd50931549 Implement display with #displayOn: instead of #displayString
Stefan Vogel <sv@exept.de>
parents: 11903
diff changeset
   749
!
cbbd50931549 Implement display with #displayOn: instead of #displayString
Stefan Vogel <sv@exept.de>
parents: 11903
diff changeset
   750
cbbd50931549 Implement display with #displayOn: instead of #displayString
Stefan Vogel <sv@exept.de>
parents: 11903
diff changeset
   751
version_CVS
18510
a8715bcdf70b class: Interval
Claus Gittinger <cg@exept.de>
parents: 16746
diff changeset
   752
    ^ '$Header$'
629
2ceefe9b5a19 version at the end
Claus Gittinger <cg@exept.de>
parents: 606
diff changeset
   753
! !
16709
447e55afc5fe class: Interval
Claus Gittinger <cg@exept.de>
parents: 14129
diff changeset
   754