Bag.st
author claus
Mon, 04 Oct 1993 11:32:33 +0100
changeset 2 6526dde5f3ac
parent 1 a27a279701f8
child 3 24d81bf47225
permissions -rw-r--r--
2.7.2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1991-93 by Claus Gittinger
a27a279701f8 Initial revision
claus
parents:
diff changeset
     3
              All Rights Reserved
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
Collection subclass:#Bag
a27a279701f8 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:'contents'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    15
       classVariableNames:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    16
       poolDictionaries:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    17
       category:'Collections-Unordered'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
Bag comment:'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    21
a27a279701f8 Initial revision
claus
parents:
diff changeset
    22
COPYRIGHT (c) 1991-93 by Claus Gittinger
a27a279701f8 Initial revision
claus
parents:
diff changeset
    23
              All Rights Reserved
a27a279701f8 Initial revision
claus
parents:
diff changeset
    24
a27a279701f8 Initial revision
claus
parents:
diff changeset
    25
Bag implements collections whose elements are unordered and have no
2
claus
parents: 1
diff changeset
    26
external keys. Elements may occur more than once. The implementation
claus
parents: 1
diff changeset
    27
uses a dictionary to store the objects occurence count using the object
claus
parents: 1
diff changeset
    28
as key.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    29
a27a279701f8 Initial revision
claus
parents:
diff changeset
    30
Instance variables:
a27a279701f8 Initial revision
claus
parents:
diff changeset
    31
a27a279701f8 Initial revision
claus
parents:
diff changeset
    32
contents        <Dictionary>        for each element, the number of occurrences
a27a279701f8 Initial revision
claus
parents:
diff changeset
    33
a27a279701f8 Initial revision
claus
parents:
diff changeset
    34
%W% %E%
a27a279701f8 Initial revision
claus
parents:
diff changeset
    35
written jun 91 by claus
a27a279701f8 Initial revision
claus
parents:
diff changeset
    36
'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    37
a27a279701f8 Initial revision
claus
parents:
diff changeset
    38
!Bag class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    39
a27a279701f8 Initial revision
claus
parents:
diff changeset
    40
new
a27a279701f8 Initial revision
claus
parents:
diff changeset
    41
    "return a new empty Bag"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    42
a27a279701f8 Initial revision
claus
parents:
diff changeset
    43
    ^ super new initContents
a27a279701f8 Initial revision
claus
parents:
diff changeset
    44
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    45
a27a279701f8 Initial revision
claus
parents:
diff changeset
    46
new:size
a27a279701f8 Initial revision
claus
parents:
diff changeset
    47
    "return a new empty Bag with initial space for size elements"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    48
a27a279701f8 Initial revision
claus
parents:
diff changeset
    49
    ^ super new initContents:size
a27a279701f8 Initial revision
claus
parents:
diff changeset
    50
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
    51
a27a279701f8 Initial revision
claus
parents:
diff changeset
    52
!Bag methodsFor:'private'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    53
a27a279701f8 Initial revision
claus
parents:
diff changeset
    54
initContents
a27a279701f8 Initial revision
claus
parents:
diff changeset
    55
    "set the contents to be an empty Dictionary"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    56
a27a279701f8 Initial revision
claus
parents:
diff changeset
    57
    contents := Dictionary new
a27a279701f8 Initial revision
claus
parents:
diff changeset
    58
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    59
a27a279701f8 Initial revision
claus
parents:
diff changeset
    60
initContents:size
a27a279701f8 Initial revision
claus
parents:
diff changeset
    61
    "set the contents to be an empty Dictionary with initial size"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    62
a27a279701f8 Initial revision
claus
parents:
diff changeset
    63
    contents := Dictionary new:size
a27a279701f8 Initial revision
claus
parents:
diff changeset
    64
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
    65
a27a279701f8 Initial revision
claus
parents:
diff changeset
    66
!Bag methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    67
a27a279701f8 Initial revision
claus
parents:
diff changeset
    68
at:index
a27a279701f8 Initial revision
claus
parents:
diff changeset
    69
    "report an error: at: is not allowed for Bags"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    70
a27a279701f8 Initial revision
claus
parents:
diff changeset
    71
    ^ self errorNotKeyed
a27a279701f8 Initial revision
claus
parents:
diff changeset
    72
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    73
a27a279701f8 Initial revision
claus
parents:
diff changeset
    74
at:index put:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
    75
    "report an error: at:put: is not allowed for Bags"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    76
a27a279701f8 Initial revision
claus
parents:
diff changeset
    77
    ^ self errorNotKeyed
a27a279701f8 Initial revision
claus
parents:
diff changeset
    78
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
    79
a27a279701f8 Initial revision
claus
parents:
diff changeset
    80
!Bag methodsFor:'testing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    81
a27a279701f8 Initial revision
claus
parents:
diff changeset
    82
size
a27a279701f8 Initial revision
claus
parents:
diff changeset
    83
    "return the number of bag elements"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    84
a27a279701f8 Initial revision
claus
parents:
diff changeset
    85
    |count|
a27a279701f8 Initial revision
claus
parents:
diff changeset
    86
a27a279701f8 Initial revision
claus
parents:
diff changeset
    87
    count := 0.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    88
    contents do:[:element | count := count + element].
a27a279701f8 Initial revision
claus
parents:
diff changeset
    89
    ^ count
a27a279701f8 Initial revision
claus
parents:
diff changeset
    90
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    91
a27a279701f8 Initial revision
claus
parents:
diff changeset
    92
occurrencesOf:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
    93
    "return how many times anObject is in the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    94
a27a279701f8 Initial revision
claus
parents:
diff changeset
    95
    ^ contents at:anObject ifAbsent:[0]
a27a279701f8 Initial revision
claus
parents:
diff changeset
    96
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    97
a27a279701f8 Initial revision
claus
parents:
diff changeset
    98
includes:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
    99
    "return true, if anObject is in the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   100
a27a279701f8 Initial revision
claus
parents:
diff changeset
   101
    ^ contents includesKey:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
   102
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   103
a27a279701f8 Initial revision
claus
parents:
diff changeset
   104
!Bag methodsFor:'adding & removing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   105
a27a279701f8 Initial revision
claus
parents:
diff changeset
   106
add:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
   107
    "add the argument, anObject to the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   108
a27a279701f8 Initial revision
claus
parents:
diff changeset
   109
    ^ self add:anObject withOccurences:1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   110
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   111
a27a279701f8 Initial revision
claus
parents:
diff changeset
   112
add:newObject withOccurences:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   113
    "add the argument, anObject anInteger times to the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   114
a27a279701f8 Initial revision
claus
parents:
diff changeset
   115
    contents at:newObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
   116
            put:(self occurrencesOf:newObject) + anInteger.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   117
    ^ newObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
   118
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   119
a27a279701f8 Initial revision
claus
parents:
diff changeset
   120
remove:oldObject ifAbsent:anExceptionBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
   121
    "Remove oldObject from the collection and return it
a27a279701f8 Initial revision
claus
parents:
diff changeset
   122
     - if it was not present, return the value of the exceptionBlock."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   123
a27a279701f8 Initial revision
claus
parents:
diff changeset
   124
    |count|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   125
a27a279701f8 Initial revision
claus
parents:
diff changeset
   126
    count := self occurrencesOf:oldObject.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   127
    (count == 0) ifTrue:[^ anExceptionBlock value].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   128
    (count == 1) ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   129
        contents removeKey:oldObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
   130
    ] ifFalse:[ 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   131
        contents at:oldObject put:(count - 1)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   132
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   133
    ^ oldObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
   134
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   135
a27a279701f8 Initial revision
claus
parents:
diff changeset
   136
!Bag methodsFor:'enumerating'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   137
a27a279701f8 Initial revision
claus
parents:
diff changeset
   138
do:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
   139
    "Perform the block for all members in the collection."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   140
a27a279701f8 Initial revision
claus
parents:
diff changeset
   141
    contents associationsDo:[:assoc |
a27a279701f8 Initial revision
claus
parents:
diff changeset
   142
        assoc value timesRepeat:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   143
            aBlock value:(assoc key)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   144
        ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   145
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   146
! !