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