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