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