NumberSet.st
author Claus Gittinger <cg@exept.de>
Thu, 09 May 1996 17:31:53 +0200
changeset 292 45529597a916
parent 199 dbd0f33191f7
child 293 2086fa8d3ef3
permissions -rw-r--r--
comments
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
     1
SequenceableCollection subclass:#NumberSet
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
     2
	instanceVariableNames:'intervals'
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
     3
	classVariableNames:''
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
     4
	poolDictionaries:''
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
     5
	category:'Collections-Ordered'
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
     6
!
0956de6a8c71 Initial revision
claus
parents:
diff changeset
     7
95
526a2179d9f1 documentation
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
     8
!NumberSet class methodsFor:'documentation'!
526a2179d9f1 documentation
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
     9
526a2179d9f1 documentation
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
    10
documentation
526a2179d9f1 documentation
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
    11
"
526a2179d9f1 documentation
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
    12
    NumberSets are Sets holding positive integers.
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    13
    This class has been written to represent number-ranges 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    14
    from .newsrc-files.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    15
    The implementation uses an array of intervals or numbers.
95
526a2179d9f1 documentation
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
    16
526a2179d9f1 documentation
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
    17
    Reading and writing is done in .newsrc-format.
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    18
95
526a2179d9f1 documentation
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
    19
    written spring 92 by claus
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    20
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    21
    [author:]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    22
        Claus Gittinger
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    23
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    24
    [see also:]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    25
        NewsHandler
95
526a2179d9f1 documentation
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
    26
"
526a2179d9f1 documentation
Claus Gittinger <cg@exept.de>
parents: 16
diff changeset
    27
! !
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    28
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    29
!NumberSet class methodsFor:'instance creation'!
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    30
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    31
with:aNumberOrInterval
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    32
    "return a new numberSet containing a single number
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    33
     or the numbers from an interval"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    34
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    35
    ^ self new setFirst:aNumberOrInterval
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    36
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    37
    "
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    38
     NumberSet with:69
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    39
     NumberSet with:(1 to:50)
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    40
    "
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    41
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    42
    "Modified: 9.5.1996 / 17:25:18 / cg"
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    43
! !
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    44
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    45
!NumberSet class methodsFor:'input from a stream'!
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    46
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    47
readFrom:aStream
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    48
    "read a NumberSet (in .newsrc format) from aStream.
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    49
     return an empty NumberSet if nothing can be read (or wrong format)"
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    50
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    51
    ^ self new readFrom:aStream
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    52
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    53
    "
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    54
     NumberSet readFrom:(ReadStream on:'0-62,69,82,84,86,88,91')
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    55
    "
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    56
! !
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    57
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    58
!NumberSet methodsFor:'accessing'!
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    59
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    60
lastOfFirstInterval
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    61
    "return the last element of the first interval.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    62
     Return nil if the receiver is empty."
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    63
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    64
    |element|
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    65
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    66
    intervals isNil ifTrue:[^ nil].
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    67
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    68
    element := intervals at:1.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    69
    (element isNumber) ifFalse:[^ element stop].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    70
    ^ element
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    71
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    72
    "Modified: 9.5.1996 / 17:31:37 / cg"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    73
! !
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    74
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    75
!NumberSet methodsFor:'adding & removing'!
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    76
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    77
add:aNumber
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    78
    "add the argument, aNumber to the NumberSet"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    79
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    80
    |index endIndex searching element nextElement newIntervals|
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    81
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    82
    intervals isNil ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    83
        intervals := OrderedCollection with:aNumber.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    84
        ^ self
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
    85
    ].
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    86
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    87
    "/ search for an interval to expand (on the fly watch out if already there)
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    88
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    89
    index := 1.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    90
    endIndex := intervals size.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    91
    searching := true.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    92
    [searching] whileTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    93
        element := intervals at:index.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    94
        (element isNumber) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    95
            "make a number to an interval"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    96
            (element = (aNumber - 1)) ifTrue:[ 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    97
                intervals at:index put:(element to:aNumber).
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    98
                self tryMerge:index.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
    99
                ^ self
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   100
            ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   101
            (element = (aNumber + 1)) ifTrue:[ 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   102
                intervals at:index put:(aNumber to:element).
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   103
                self tryMerge:(index - 1).
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   104
                ^ self
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   105
            ]. 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   106
            "already in set"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   107
            (element = aNumber) ifTrue:[^ self].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   108
            "not in - stop search"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   109
            (element > aNumber) ifTrue:[searching := false]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   110
        ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   111
            "expand interval"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   112
            (element start = (aNumber + 1)) ifTrue:[ 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   113
                element start:aNumber.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   114
                self tryMerge:(index - 1).
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   115
                ^ self
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   116
            ]. 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   117
            (element stop = (aNumber - 1)) ifTrue:[ 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   118
                element stop:aNumber.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   119
                self tryMerge:index.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   120
                ^ self
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   121
            ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   122
            "already in set"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   123
            ((element start <= aNumber) and:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   124
             (element stop >= aNumber)]) ifTrue:[^ self].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   125
            "not in - stop search"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   126
            (element start > aNumber) ifTrue:[searching := false]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   127
        ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   128
        searching ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   129
            index := index + 1.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   130
            (index > endIndex) ifTrue:[searching := false]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   131
        ]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   132
    ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   133
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   134
    "/ append at end
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   135
    (index > endIndex) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   136
        intervals add:aNumber.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   137
        ^ self
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   138
    ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   139
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   140
    "/ insert before index
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   141
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   142
    intervals add:aNumber beforeIndex:index.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   143
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   144
    "Modified: 9.5.1996 / 17:31:05 / cg"
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   145
!
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   146
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   147
remove:aNumber ifAbsent:aBlock
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   148
    "remove the argument, aNumber from the NumberSet"
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   149
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   150
    |index endIndex element newIntervals|
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   151
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   152
    (intervals isNil or:[intervals size == 0]) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   153
        ^ aBlock value
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   154
    ].
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   155
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   156
    index := 1.
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   157
    endIndex := intervals size.
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   158
    [true] whileTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   159
        element := intervals at:index.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   160
        (element isNumber) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   161
            (element = aNumber) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   162
                (intervals size == 1) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   163
                    intervals := nil
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   164
                ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   165
                    intervals removeIndex:index
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   166
                ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   167
                ^ self
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   168
            ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   169
            "not in - stop search"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   170
            (element > aNumber) ifTrue:[^ aBlock value]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   171
        ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   172
            "can remove from interval ?"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   173
            (element start = aNumber) ifTrue:[ 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   174
                element start:(aNumber + 1).
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   175
                (element start = element stop) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   176
                    intervals at:index put:(element start)
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   177
                ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   178
                ^ self
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   179
            ]. 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   180
            (element stop = aNumber) ifTrue:[ 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   181
                element stop:(aNumber - 1).
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   182
                (element start = element stop) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   183
                    intervals at:index put:(element start)
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   184
                ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   185
                ^ self
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   186
            ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   187
            (element start > aNumber) ifTrue:[^ aBlock value].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   188
            ((element start <= aNumber) and:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   189
             (element stop >= aNumber)]) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   190
                "must make it two intervals"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   191
                newIntervals := OrderedCollection new:(endIndex + 1).
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   192
                newIntervals replaceFrom:1 to:(index - 1) with:intervals.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   193
                newIntervals replaceFrom:(index + 2) to:(endIndex + 1)
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   194
                                    with:intervals startingAt:(index + 1).
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   195
                (element start = (aNumber - 1)) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   196
                    newIntervals at:index put:element start
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   197
                ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   198
                    newIntervals at:index put:(element start to:(aNumber - 1))
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   199
                ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   200
                ((aNumber + 1) = element stop) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   201
                    newIntervals at:(index + 1) put:(aNumber + 1)
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   202
                ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   203
                    newIntervals at:(index + 1) put:((aNumber + 1) to:element stop)
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   204
                ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   205
                intervals := newIntervals.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   206
                ^ self
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   207
            ]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   208
        ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   209
        index := index + 1.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   210
        (index > endIndex) ifTrue:[^ aBlock value]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   211
    ]
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   212
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   213
    "Modified: 9.5.1996 / 17:30:52 / cg"
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   214
! !
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   215
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   216
!NumberSet methodsFor:'enumerating'!
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   217
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   218
do:aBlock
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   219
    "evaluate the argument, aBlock for each element in the numberSet"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   220
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   221
    intervals isNil ifTrue:[^ self].
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   222
    intervals do:[:element |
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   223
        (element isNumber) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   224
            aBlock value:element
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   225
        ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   226
            element do:aBlock
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   227
        ] 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   228
    ]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   229
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   230
    "Modified: 9.5.1996 / 17:30:19 / cg"
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   231
! !
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   232
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   233
!NumberSet methodsFor:'printing'!
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   234
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   235
displayString
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   236
    "return a nice string"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   237
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   238
    |first s|
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   239
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   240
    intervals size == 0 ifTrue:[^ 'NumberSet()'].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   241
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   242
    s := 'NumberSet('.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   243
    first := true.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   244
    intervals do:[:element |
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   245
        first ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   246
            first := false
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   247
        ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   248
            s := s , ','
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   249
        ]. 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   250
        (element isNumber) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   251
            s := s , (element printString)
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   252
        ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   253
            s := s , (element start printString).
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   254
            s := s , '-'.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   255
            s := s , (element stop printString)
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   256
        ] 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   257
    ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   258
    s := s , ')'.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   259
    ^ s
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   260
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   261
    "Modified: 9.5.1996 / 17:30:14 / cg"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   262
!
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   263
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   264
printOn:aStream
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   265
    "output the NumberSet (in .newsrc format) on aStream"
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   266
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   267
    |first|
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   268
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   269
    intervals isNil ifTrue:[^ self].
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   270
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   271
    first := true.
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   272
    intervals do:[:element |
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   273
        first ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   274
            first := false
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   275
        ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   276
            aStream nextPut:$,
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   277
        ]. 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   278
        (element isNumber) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   279
            aStream nextPutAll:(element printString)
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   280
        ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   281
            aStream nextPutAll:(element start printString).
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   282
            aStream nextPut:$-.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   283
            aStream nextPutAll:(element stop printString)
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   284
        ] 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   285
    ]
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   286
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   287
    "Modified: 9.5.1996 / 17:30:10 / cg"
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   288
! !
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   289
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   290
!NumberSet methodsFor:'private'!
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   291
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   292
readFrom:aStream
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   293
    "read my value from aStream (in .newsrc format)"
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   294
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   295
    |nextChar arr start stop done|
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   296
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   297
    aStream skipSeparators.
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   298
    aStream atEnd ifTrue:[^ nil].
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   299
199
dbd0f33191f7 no longer use VariableArray
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   300
    intervals := OrderedCollection new.
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   301
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   302
    done := false.
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   303
    [done] whileFalse:[
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   304
        aStream atEnd ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   305
            done := true
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   306
        ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   307
            start := Number readFrom:aStream.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   308
            start isNil ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   309
                done := true
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   310
            ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   311
                aStream skipSeparators.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   312
                aStream atEnd ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   313
                    intervals add:start. 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   314
                    done := true
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   315
                ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   316
                    nextChar := aStream peek.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   317
                    (nextChar == $-) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   318
                        aStream next.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   319
                        stop := Number readFrom:aStream.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   320
                        intervals add:(start to:stop)
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   321
                    ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   322
                        intervals add:start
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   323
                    ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   324
                    aStream skipSeparators.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   325
                    aStream atEnd ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   326
                        done := true
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   327
                    ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   328
                        nextChar := aStream peek.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   329
                        (nextChar == $,) ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   330
                             done := true
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   331
                        ] ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   332
                             aStream next
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   333
                        ]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   334
                    ]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   335
                ]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   336
            ]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   337
        ]
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   338
    ].
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   339
    (intervals size == 0) ifTrue:[
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   340
        intervals := nil
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   341
    ]
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   342
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   343
    "
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   344
     NumberSet new readFrom:(ReadStream on:'0-62,69,82,84,86,88,91')
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   345
    "
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   346
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   347
    "Modified: 9.5.1996 / 17:30:02 / cg"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   348
!
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   349
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   350
tryMerge:index
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   351
    "try to make element at index and index + 1 be one element"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   352
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   353
    |element first last first2 last2 nextElement|
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   354
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   355
    (index > 0) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   356
        (index < (intervals size)) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   357
            element := intervals at:index.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   358
            (element isNumber) ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   359
                first := element start.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   360
                last := element stop
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   361
            ] ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   362
                first := element.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   363
                last := element
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   364
            ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   365
    
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   366
            nextElement := intervals at:(index + 1).
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   367
            (nextElement isNumber) ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   368
                first2 := nextElement start.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   369
                last2 := nextElement stop
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   370
            ] ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   371
                first2 := nextElement.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   372
                last2 := nextElement
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   373
            ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   374
    
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   375
            (last >= (first2 - 1)) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   376
                intervals at:index put:(first to:last2).
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   377
                intervals removeIndex:(index + 1)
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   378
            ]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   379
        ]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   380
    ]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   381
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   382
    "Modified: 9.5.1996 / 17:29:50 / cg"
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   383
! !
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   384
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   385
!NumberSet methodsFor:'private accessing'!
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   386
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   387
setFirst:aNumberOrInterval 
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   388
    "set the first element"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   389
199
dbd0f33191f7 no longer use VariableArray
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   390
    intervals := OrderedCollection with:aNumberOrInterval
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   391
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   392
    "Modified: 9.5.1996 / 17:26:26 / cg"
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   393
! !
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   394
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   395
!NumberSet methodsFor:'queries'!
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   396
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   397
first
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   398
    "answer the first i.e. lowest number in the set.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   399
     If the receiver is empty, return nil."
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   400
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   401
    |element|
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   402
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   403
    intervals isNil ifTrue:[^ nil].
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   404
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   405
    element := intervals at:1.
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   406
    (element isNumber) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   407
        ^ element
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   408
    ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   409
    ^ element start
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   410
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   411
    "Modified: 9.5.1996 / 17:29:14 / cg"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   412
!
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   413
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   414
includes:aNumber
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   415
    "answer true, if aNumber is in the set"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   416
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   417
    |endIndex index middle delta element start stop|
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   418
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   419
    intervals isNil ifTrue:[^ false].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   420
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   421
    index := 1.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   422
    endIndex := intervals size.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   423
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   424
    "/ use a binary search, to limit search
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   425
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   426
    middle := (endIndex + index) // 2.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   427
    [(middle > (index + 1)) and:[middle < (endIndex - 1)]] whileTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   428
        element := intervals at:middle.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   429
        (element isNumber) ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   430
            (element stop <= aNumber) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   431
                index := middle
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   432
            ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   433
                (element start >= aNumber) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   434
                    endIndex := middle
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   435
                ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   436
                    (element includes:aNumber) ifTrue:[^ true]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   437
                ]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   438
            ]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   439
        ] ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   440
            (element <= aNumber) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   441
                (element == aNumber) ifTrue:[^ true].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   442
                index := middle
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   443
            ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   444
                endIndex := middle
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   445
            ]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   446
        ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   447
        middle := (endIndex + index) // 2
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   448
    ].
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   449
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   450
    [index <= endIndex] whileTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   451
        element := intervals at:index.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   452
        (element isNumber) ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   453
            (element start > aNumber) ifTrue:[ ^ false].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   454
            (element stop >= aNumber) ifTrue:[ ^ true]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   455
        ] ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   456
            (element > aNumber) ifTrue:[ ^ false].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   457
            (element = aNumber) ifTrue:[ ^ true]
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   458
        ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   459
        index := index + 1
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   460
    ]. 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   461
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   462
    ^ false
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   463
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   464
    "Modified: 9.5.1996 / 17:29:05 / cg"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   465
!
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   466
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   467
last
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   468
    "answer the last i.e. highest number in the set.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   469
     If the receiver is empty, return nil."
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   470
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   471
    |element|
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   472
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   473
    intervals isNil ifTrue:[^ nil].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   474
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   475
    element := intervals last.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   476
    (element isNumber) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   477
        ^ element
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   478
    ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   479
    ^ element stop
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   480
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   481
    "Modified: 9.5.1996 / 17:29:10 / cg"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   482
!
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   483
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   484
size
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   485
    "return the number of elements in the Set"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   486
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   487
    |tally|
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   488
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   489
    intervals isNil ifTrue:[^ 0].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   490
    tally := 0.
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   491
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   492
    intervals do:[:element |
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   493
        (element isNumber) ifTrue:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   494
            tally := tally + 1
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   495
        ] ifFalse:[
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   496
            tally := tally + element size
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   497
        ] 
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   498
    ].
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   499
    ^ tally
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   500
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   501
    "Modified: 9.5.1996 / 17:29:20 / cg"
16
0956de6a8c71 Initial revision
claus
parents:
diff changeset
   502
! !
292
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   503
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   504
!NumberSet class methodsFor:'documentation'!
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   505
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   506
version
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   507
"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   508
$Header: /cvs/stx/stx/libbasic2/NumberSet.st,v 1.5 1996-05-09 15:31:53 cg Exp $
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   509
"
45529597a916 comments
Claus Gittinger <cg@exept.de>
parents: 199
diff changeset
   510
! !