KeyedCollection.st
author Claus Gittinger <cg@exept.de>
Sun, 03 May 2020 13:20:12 +0200
changeset 25379 609d492f29a7
parent 25375 b784fc06a5eb
permissions -rw-r--r--
#DOCUMENTATION by cg class: Object comment/format in: #perform:ifNotUnderstood:
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     1
"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     2
 COPYRIGHT (c) 1998 by eXept Software AG
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
              All Rights Reserved
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
 This software is furnished under a license and may be used
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
 hereby transferred.
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
"
9482
7bebdb8e4c60 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9480
diff changeset
    12
"{ Package: 'stx:libbasic' }"
8893
99996b25482e +isAbstract
Claus Gittinger <cg@exept.de>
parents: 3615
diff changeset
    13
19469
e43475084bb5 #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17120
diff changeset
    14
"{ NameSpace: Smalltalk }"
e43475084bb5 #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17120
diff changeset
    15
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
Collection subclass:#KeyedCollection
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
	instanceVariableNames:''
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
	classVariableNames:''
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
	poolDictionaries:''
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
	category:'Collections-Abstract'
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
!
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
!KeyedCollection class methodsFor:'documentation'!
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
copyright
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
 COPYRIGHT (c) 1998 by eXept Software AG
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
              All Rights Reserved
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
 This software is furnished under a license and may be used
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
 only in accordance with the terms of that license and with the
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
 inclusion of the above copyright notice.   This software may not
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
 be provided or otherwise made available to, or used by, any
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
 other person.  No title to or ownership of the software is
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
 hereby transferred.
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
!
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
documentation
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
    Abstract superclass for collections which have a key->value mapping.
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
    This abstract class provides functionality common to those collections,
17120
246d9198d84e class: KeyedCollection
Claus Gittinger <cg@exept.de>
parents: 13045
diff changeset
    44
    without knowing how the concrete class implements things. 
246d9198d84e class: KeyedCollection
Claus Gittinger <cg@exept.de>
parents: 13045
diff changeset
    45
    Thus, all methods found here depend on some basic mechanisms 
246d9198d84e class: KeyedCollection
Claus Gittinger <cg@exept.de>
parents: 13045
diff changeset
    46
    to be defined in the concrete class. 
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
    These basic methods are usually defined as #subclassResponsibility here.
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    48
    Some methods are also redefined for better performance.
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    49
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    50
    Subclasses should at least implement:
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
        at:ifAbsent:        - accessing elements
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    52
        removeKey:ifAbsent  - removing
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    53
        keysAndValuesDo:    - enumerating
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    54
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    55
    [author:]
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
        Claus Gittinger
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
! !
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
    60
!KeyedCollection class methodsFor:'instance creation'!
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
    61
23354
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    62
decodeFromLiteralArray:anArray
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    63
    "create & return a new instance from information encoded in anArray."
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    64
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    65
    |dictionary
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    66
     sz "{ Class: SmallInteger }"|
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    67
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    68
    sz := anArray size.
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    69
    dictionary := self new:sz//2.
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    70
    2 to:sz by:2 do:[:idx | |key val|
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    71
        key := (anArray at:idx) decodeAsLiteralArray.
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    72
        val := (anArray at:idx+1) decodeAsLiteralArray.
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    73
        dictionary at:key put:val
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    74
    ].
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    75
    ^ dictionary
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    76
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    77
    "
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    78
     (SmallDictionary new
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    79
         at:1 put:'one';
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    80
         at:2 put:'two';
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    81
         yourself
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    82
     ) literalArrayEncoding decodeAsLiteralArray
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    83
    "
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    84
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    85
    "Created: / 17-09-2018 / 14:51:59 / Stefan Vogel"
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    86
!
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
    87
25375
b784fc06a5eb #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 24814
diff changeset
    88
newWithCapacity:size
b784fc06a5eb #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 24814
diff changeset
    89
    "return a new empty Collection preferrably with capacity for n elements"
b784fc06a5eb #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 24814
diff changeset
    90
b784fc06a5eb #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 24814
diff changeset
    91
    ^ self new:size.
b784fc06a5eb #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 24814
diff changeset
    92
b784fc06a5eb #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 24814
diff changeset
    93
    "Created: / 28-04-2020 / 15:57:08 / Stefan Vogel"
b784fc06a5eb #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 24814
diff changeset
    94
!
b784fc06a5eb #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 24814
diff changeset
    95
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
    96
withAll:aCollection
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
    97
    "create a KeyedCollection from another Collection with keys"
21655
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
    98
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
    99
    |newDict|
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   100
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   101
    newDict := self new:aCollection size.
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   102
    aCollection keysAndValuesDo:[:key :value |
21655
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   103
        newDict at:key put:value.
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   104
    ].
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   105
    ^ newDict
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   106
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   107
    "
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   108
        |d|
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   109
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   110
        d := Dictionary withKeys:#(a b c d e) andValues:#(1 2 3 4 5).
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   111
        SmallDictionary withAll:d.
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   112
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   113
        SmallDictionary withAll:#('one' 'two' 'three' 'four').
21655
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   114
    "
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   115
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   116
    "Created: / 17-03-2017 / 11:29:09 / stefan"
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   117
    "Modified (comment): / 14-09-2018 / 17:54:12 / Stefan Vogel"
21655
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   118
!
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   119
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   120
withAssociations:aCollectionOfAssociations
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   121
    "return a new instance where associations are taken from the argument"
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   122
21655
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   123
    |newDict|
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   124
21655
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   125
    newDict := self new:aCollectionOfAssociations size.
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   126
    aCollectionOfAssociations do:[:assoc |
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   127
        newDict at:assoc key put:assoc value
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   128
    ].
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   129
    ^ newDict
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   130
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   131
    "
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   132
     SmallDictionary withAssociations:{ #'one'->1 .
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   133
                                   #'two'->2 .
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   134
                                   #'three'->3 .
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   135
                                   #'four'->4 }
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   136
    "
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   137
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   138
    "Created: / 16-03-2017 / 12:15:38 / stefan"
21655
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   139
    "Modified: / 17-03-2017 / 11:30:55 / stefan"
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   140
    "Modified (comment): / 14-09-2018 / 17:45:56 / Stefan Vogel"
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   141
!
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   142
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   143
withKeyValuePairs:aCollection
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   144
    "return a new instance where keys and values are taken from 
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   145
     elements of aCollection, which are pairs (2-element SeuqenceableCollection) of key and value"
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   146
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   147
    |newDict|
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   148
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   149
    newDict := self new:(aCollection size).
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   150
    aCollection do:[:pair |
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   151
        newDict at:(pair first) put:(pair second)
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   152
    ].
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   153
    ^ newDict
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   154
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   155
    "
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   156
     SmallDictionary withKeyValuePairs:#( ('one' 1) ('two' 2) ('three' 3) ('four' 4))
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   157
    "
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   158
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   159
    "Created: / 14-09-2018 / 17:44:35 / Stefan Vogel"
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   160
!
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   161
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   162
withKeys:keyCollection andValues:valueCollection
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   163
    "return a new instance where keys and values are taken from
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   164
     the argumentArrays."
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   165
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   166
    |newColl sz "{ Class: SmallInteger }"|
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   167
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   168
    sz := keyCollection size.
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   169
    newColl := self new:sz.
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   170
    1 to:sz do:[:index |
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   171
        newColl at:(keyCollection at:index) put:(valueCollection at:index).
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   172
    ].
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   173
    ^ newColl
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   174
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   175
    "Created: / 16-03-2017 / 11:06:51 / stefan"
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   176
    "Modified (format): / 16-03-2017 / 12:12:09 / stefan"
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   177
    "Modified (format): / 14-09-2018 / 17:50:05 / Stefan Vogel"
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   178
!
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   179
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   180
withKeysAndValues:aSequenceableCollection
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   181
    "return a new instance where keys and values are taken from alternating
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   182
     elements of aSequenceableCollection"
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   183
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   184
    |newDict sz "{ Class: SmallInteger }"|
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   185
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   186
    sz := aSequenceableCollection size.
23398
15d76e8be04c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23363
diff changeset
   187
    sz odd ifTrue:[
15d76e8be04c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23363
diff changeset
   188
        SubscriptOutOfBoundsError
15d76e8be04c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23363
diff changeset
   189
            raiseRequestWith:sz+1
15d76e8be04c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23363
diff changeset
   190
            errorString:('odd number of elements - subscript (' , (sz+1) printString , ') would be out of bounds')
15d76e8be04c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23363
diff changeset
   191
    ].
21655
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   192
    newDict := self new:sz.
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   193
    1 to:sz by:2 do:[:i |
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   194
        newDict at:(aSequenceableCollection at:i) put:(aSequenceableCollection at:i+1)
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   195
    ].
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   196
    ^ newDict
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   197
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   198
    "
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   199
     SmallDictionary withKeysAndValues:#('one' 1 'two' 2 'three' 3 'four' 4)
23398
15d76e8be04c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23363
diff changeset
   200
     SmallDictionary withKeysAndValues:#('one' 1 'two' 2 'three' 3 'incomplete')
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   201
    "
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   202
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   203
    "Created: / 16-03-2017 / 12:13:27 / stefan"
21655
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   204
    "Modified: / 17-03-2017 / 11:32:42 / stefan"
23398
15d76e8be04c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23363
diff changeset
   205
    "Modified (comment): / 04-10-2018 / 10:09:46 / Stefan Vogel"
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   206
! !
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   207
8893
99996b25482e +isAbstract
Claus Gittinger <cg@exept.de>
parents: 3615
diff changeset
   208
!KeyedCollection class methodsFor:'queries'!
99996b25482e +isAbstract
Claus Gittinger <cg@exept.de>
parents: 3615
diff changeset
   209
99996b25482e +isAbstract
Claus Gittinger <cg@exept.de>
parents: 3615
diff changeset
   210
isAbstract
11222
7e8b37ffc6ca comment
Claus Gittinger <cg@exept.de>
parents: 10533
diff changeset
   211
    "Return if this class is an abstract class.
7e8b37ffc6ca comment
Claus Gittinger <cg@exept.de>
parents: 10533
diff changeset
   212
     True is returned for KeyedCollection here; false for subclasses.
19469
e43475084bb5 #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17120
diff changeset
   213
     Abstract subclasses must redefine this again."
11222
7e8b37ffc6ca comment
Claus Gittinger <cg@exept.de>
parents: 10533
diff changeset
   214
8893
99996b25482e +isAbstract
Claus Gittinger <cg@exept.de>
parents: 3615
diff changeset
   215
    ^ self == KeyedCollection
99996b25482e +isAbstract
Claus Gittinger <cg@exept.de>
parents: 3615
diff changeset
   216
! !
99996b25482e +isAbstract
Claus Gittinger <cg@exept.de>
parents: 3615
diff changeset
   217
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   218
!KeyedCollection methodsFor:'accessing'!
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   219
21653
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   220
associationAt:aKey 
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   221
    "return an association consisting of aKey and the element indexed 
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   222
     by aKey - 
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   223
     report an error, if no element is stored under aKey."
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   224
21653
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   225
    ^ self associationAt:aKey ifAbsent:[self errorKeyNotFound:aKey]
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   226
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   227
    "Modified: / 16-03-2017 / 17:19:52 / stefan"
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   228
!
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   229
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   230
associationAt:aKey ifAbsent:exceptionBlock
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   231
    "return an association consisting of aKey and the element indexed by aKey -
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   232
     return result of exceptionBlock if no element is stored under aKey.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   233
     Warning: this is a comatibility interface only, with a different semantic as
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   234
              the original ST80 implementation. The returned assoc is created on the fly,
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   235
              and not the one stored in the receiver (there are not assocs there)"
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   236
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   237
    |value|
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   238
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   239
    value := self at:aKey ifAbsent:[^ exceptionBlock value].
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   240
    ^ Association key:aKey value:value.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   241
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   242
    "Created: / 16-03-2017 / 17:17:05 / stefan"
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   243
!
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   244
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   245
associations
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   246
    "return an ordered collection containing the receiver's associations."
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   247
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   248
    |coll|
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   249
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   250
    coll := OrderedCollection new.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   251
    self associationsDo:[:assoc | coll add:assoc].
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   252
    ^ coll
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   253
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   254
    "Created: / 16-03-2017 / 17:30:47 / stefan"
21649
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   255
!
4a09b7965b34 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21369
diff changeset
   256
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   257
at:key
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   258
    "return the value stored under akey.
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   259
     Raise an error if not found"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   260
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   261
    ^ self at:key ifAbsent:[self errorKeyNotFound:key].
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   262
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   263
    "Modified: / 19.6.1998 / 00:48:27 / cg"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   264
!
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   265
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   266
at:key ifAbsent:exceptionBlock
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   267
    "return the value stored under akey.
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   268
     Return the value from evaluating exceptionBlock if not found"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   269
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   270
    ^ self subclassResponsibility
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   271
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   272
    "Created: / 19.6.1998 / 00:48:23 / cg"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   273
!
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   274
21653
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   275
at:aKey ifAbsent:default update:aBlock
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   276
    "update the element stored under aKey with the result from
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   277
     evaluating aBlock with the previous stored value as argument, or with default,
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   278
     if there was no such key initially.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   279
     Return the new value stored."
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   280
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   281
    ^ self at:aKey put:(aBlock value:(self at:aKey ifAbsent:default))
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   282
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   283
    "Created: / 16-03-2017 / 17:28:15 / stefan"
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   284
!
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   285
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   286
at:aKey ifAbsentPut:valueBlock
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   287
    "return the element indexed by aKey if present,
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   288
     if not present, store the result of evaluating valueBlock
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   289
     under aKey and return it.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   290
     WARNING: do not add elements while iterating over the receiver.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   291
              Iterate over a copy to do this."
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   292
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   293
    ^ self at:aKey ifAbsent:[self at:aKey put:valueBlock value].
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   294
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   295
    "Created: / 16-03-2017 / 17:23:07 / stefan"
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   296
!
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   297
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   298
at:aKey put:anObject
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   299
    "add the argument anObject under key, aKey to the receiver.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   300
     Return anObject (sigh).
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   301
     WARNING: do not add elements while iterating over the receiver.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   302
              Iterate over a copy to do this."
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   303
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   304
    ^ self subclassResponsibility
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   305
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   306
    "Created: / 16-03-2017 / 17:33:12 / stefan"
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   307
!
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   308
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   309
at:aKey put:anObject ifPresent:aBlock
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   310
    "if the receiver contains an element stored under aKey,
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   311
     retrieve it and evaluate aBlock passing the element as argument,
23888
ecd7ab5136be #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23706
diff changeset
   312
     return the block's value.
21653
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   313
     If not, store aValue under the key.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   314
     Use this with an error-reporting block, to ensure that no keys are reused"
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   315
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   316
    |value isAbsent|
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   317
21655
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   318
    value := self at:aKey ifAbsentPut:[isAbsent := true. anObject].
21653
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   319
    isAbsent notNil ifTrue:[
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   320
        ^ value.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   321
    ].
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   322
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   323
    ^ aBlock value:value.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   324
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   325
    "Created: / 16-03-2017 / 17:38:00 / stefan"
21655
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   326
    "Modified: / 17-03-2017 / 11:37:26 / stefan"
23888
ecd7ab5136be #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 23706
diff changeset
   327
    "Modified (comment): / 13-03-2019 / 10:26:05 / Claus Gittinger"
21653
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   328
!
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   329
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   330
at:aKey update:aBlock
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   331
    "update the element stored under aKey with the result from
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   332
     evaluating aBlock with the previous stored value as argument.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   333
     Report an error if there was no such key initially.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   334
     Return the new value stored."
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   335
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   336
    ^ self at:aKey put:(aBlock value:(self at:aKey))
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   337
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   338
    "Created: / 16-03-2017 / 17:29:22 / stefan"
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   339
!
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   340
21368
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   341
keyAtEqualValue:value
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   342
    "return the key under which value is stored.
21368
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   343
     Raise an error if not found.
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   344
     This is a slow access, since the receiver is searched sequentially.
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   345
     NOTICE:
21369
d7b0866974d9 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 21368
diff changeset
   346
        The value is searched using equality compare"
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   347
21368
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   348
    ^ self keyAtEqualValue:value ifAbsent:[self errorValueNotFound:value].
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   349
21368
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   350
    "Created: / 07-02-2017 / 11:11:41 / cg"
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   351
!
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   352
21368
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   353
keyAtEqualValue:value ifAbsent:exceptionBlock
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   354
    "return the key under which value is stored.
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   355
     If not found, return the value from evaluating exceptionBlock.
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   356
     This is a slow access, since the receiver is searched sequentially.
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   357
     NOTICE:
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   358
        The value is searched using equality compare"
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   359
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   360
    self keysAndValuesDo:[:elKey :elValue |
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   361
        value = elValue ifTrue:[^ elKey]
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   362
    ].
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   363
    ^ exceptionBlock value
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   364
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   365
    "Created: / 07-02-2017 / 11:12:03 / cg"
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   366
!
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   367
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   368
keyAtIdenticalValue:value
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   369
    "return the key under which value is stored.
21368
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   370
     Raise an error if not found.
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   371
     This is a slow access, since the receiver is searched sequentially.
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   372
     NOTICE:
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   373
        The value is searched using identity compare"
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   374
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   375
    ^ self keyAtIdenticalValue:value ifAbsent:[self errorValueNotFound:value].
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   376
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   377
    "Created: / 07-02-2017 / 11:12:23 / cg"
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   378
!
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   379
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   380
keyAtIdenticalValue:value ifAbsent:exceptionBlock
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   381
    "return the key under which value is stored.
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   382
     If not found, return the value from evaluating exceptionBlock.
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   383
     This is a slow access, since the receiver is searched sequentially.
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   384
     NOTICE:
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   385
        The value is searched using identity compare"
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   386
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   387
    self keysAndValuesDo:[:elKey :elValue |
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   388
        value == elValue ifTrue:[^ elKey]
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   389
    ].
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   390
    ^ exceptionBlock value
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   391
21368
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   392
    "Created: / 07-02-2017 / 11:12:46 / cg"
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   393
!
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   394
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   395
keyAtValue:value
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   396
    "return the key under which value is stored.
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   397
     Raise an error if not found.
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   398
     This is a slow access, since the receiver is searched sequentially.
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   399
     NOTICE:
21653
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   400
        The value is searched using equality compare"
21368
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   401
21653
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   402
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   403
    ^ self keyAtEqualValue:value.
21368
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   404
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   405
    "Created: / 19-06-1998 / 00:49:16 / cg"
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   406
    "Modified (comment): / 07-02-2017 / 11:13:29 / cg"
21653
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   407
    "Modified (comment): / 16-03-2017 / 18:00:28 / stefan"
21368
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   408
!
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   409
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   410
keyAtValue:value ifAbsent:exceptionBlock
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   411
    "return the key under which value is stored.
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   412
     If not found, return the value from evaluating exceptionBlock.
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   413
     This is a slow access, since the receiver is searched sequentially.
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   414
     NOTICE:
21653
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   415
        The value is searched using equality compare"
21368
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   416
21653
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   417
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   418
    ^ self keyAtEqualValue:value ifAbsent:exceptionBlock.
21368
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   419
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   420
    "Created: / 19-06-1998 / 00:50:34 / cg"
1e4c41f4d3af #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19844
diff changeset
   421
    "Modified: / 07-02-2017 / 11:13:20 / cg"
21653
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   422
    "Modified (comment): / 16-03-2017 / 18:00:37 / stefan"
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   423
!
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   424
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   425
keys
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   426
    "return a collection containing the keys of the receiver"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   427
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   428
    |keyCollection|
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   429
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   430
    keyCollection := OrderedCollection new.
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   431
    self keysDo:[:aKey |
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   432
        keyCollection add:aKey
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   433
    ].
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   434
    ^ keyCollection
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   435
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   436
    "Modified: / 19.6.1998 / 00:48:27 / cg"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   437
    "Created: / 19.6.1998 / 00:51:49 / cg"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   438
! !
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   439
23338
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   440
!KeyedCollection methodsFor:'adding'!
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   441
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   442
addAll:aCollection
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   443
    "ANSI 5.7.2.1:
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   444
     Message:  addAll: dictionary
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   445
      Synopsis
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   446
        Store the elements of dictionary in the receiver at the
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   447
        corresponding keys from dictionary.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   448
      Definition: <abstractDictionary>
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   449
        This message is equivalent to repeatedly sending the #at:put:
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   450
        message to the receiver with each of the keys and elements in
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   451
        dictionary in turn.  If a key in dictionary is key equivalent
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   452
        to a key in the receiver, the associated element in dictionary
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   453
        replaces the element in the receiver.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   454
24612
1ac50ebe401a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 23888
diff changeset
   455
     Returns the argument, aCollection.
23338
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   456
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   457
     WARNING: do not add elements while iterating over the receiver.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   458
              Iterate over a copy to do this."
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   459
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   460
    self ~~ aCollection ifTrue:[
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   461
        aCollection isSequenceable ifTrue:[
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   462
            aCollection do:[:eachPair |
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   463
                self at:eachPair key put:eachPair value.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   464
            ].
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   465
        ] ifFalse:[
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   466
            aCollection keysAndValuesDo:[:eachKey :eachValue |
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   467
                self at:eachKey put:eachValue.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   468
            ]
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   469
        ].
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   470
    ].
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   471
    ^ aCollection
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   472
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   473
    "
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   474
     |d1 d2|
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   475
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   476
     d1 := Dictionary new.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   477
     d1 at:1 put:'one'.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   478
     d1 at:2 put:'two'.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   479
     d2 := Dictionary new.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   480
     d2 at:3 put:'three'.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   481
     d2 at:4 put:'four'.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   482
     d1 addAll:d2.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   483
     d1.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   484
    "
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   485
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   486
    "Created: / 14-09-2018 / 16:41:49 / Stefan Vogel"
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   487
!
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   488
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   489
declareAllFrom:aDictionaryOrNil
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   490
    "merge all key-value pairs from aDictionary into the receiver.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   491
     Values present in the arg will always end up in the receiver;
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   492
     i.e. a value coming from the argument is already in the receiver,
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   493
     the value from aDictionaryOrNil is stored into the receiver.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   494
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   495
     sigh:
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   496
        For compatibility with #declare:from: the behavior should be changed as following:
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   497
        If the receiver already contains a key, the existing value is retained.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   498
        To keep the compatibility with other smalltalks, the semantics of this remains
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   499
        as is, and #declareAllNewFrom: was added for convenience.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   500
        See #declareAllNewFrom: which does exactly what this name implies."
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   501
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   502
    (aDictionaryOrNil notNil and:[self ~~ aDictionaryOrNil]) ifTrue:[
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   503
        aDictionaryOrNil keysAndValuesDo:[:key :value |
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   504
            self at:key put:value.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   505
        ].
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   506
    ]
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   507
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   508
    "Created: / 14-09-2018 / 16:46:38 / Stefan Vogel"
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   509
!
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   510
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   511
declareAllNewFrom:aDictionaryOrNil
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   512
    "merge all new key-value pairs from aDictionary into the receiver
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   513
     i.e. If the receiver already contains a key, the existing value is retained.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   514
     See also #declareAllFrom:"
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   515
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   516
    (aDictionaryOrNil notNil and:[self ~~ aDictionaryOrNil]) ifTrue:[
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   517
        aDictionaryOrNil keysAndValuesDo:[:key :value |
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   518
            (self includesKey:key) ifFalse:[
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   519
                self at:key put:value.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   520
            ].
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   521
        ]
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   522
    ]
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   523
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   524
    "Created: / 14-09-2018 / 16:56:36 / Stefan Vogel"
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   525
! !
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   526
23354
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   527
!KeyedCollection methodsFor:'converting'!
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   528
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   529
literalArrayEncoding
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   530
    |literalArray idx|
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   531
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   532
    literalArray := Array new:(self size * 2)+1.
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   533
    literalArray at:1 put:self class name.
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   534
    idx := 2.
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   535
    self keysAndValuesDo:[:eachKey :eachValue |
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   536
        literalArray
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   537
            at:idx   put:eachKey literalArrayEncoding;
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   538
            at:idx+1 put:eachValue literalArrayEncoding.
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   539
        idx := idx + 2.
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   540
    ].
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   541
    ^ literalArray
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   542
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   543
    "
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   544
      |dict|
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   545
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   546
      dict := SmallDictionary new.
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   547
      dict at:1 put:'bla'.
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   548
      dict at:'fasel' put:#[1 2 3 4].
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   549
      dict literalArrayEncoding
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   550
    "
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   551
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   552
    "Created: / 17-09-2018 / 14:49:52 / Stefan Vogel"
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   553
! !
bcd17ecee2c6 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23341
diff changeset
   554
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   555
!KeyedCollection methodsFor:'enumerating'!
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   556
21655
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   557
associationsDo:aBlock
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   558
    "perform the block for all associations in the collection.
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   559
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   560
     See also:
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   561
        #do:              (which passes values to its block)
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   562
        #keysDo:          (which passes only keys to its block)
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   563
        #keysAndValuesDo: (which passes keys&values)
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   564
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   565
     This is much like #keysAndValuesDo:, but aBlock gets the
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   566
     key and value as a single association argument.
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   567
     #keysAndValuesDo: and is a bit faster therefore (no intermediate objects).
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   568
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   569
     WARNING: do not add/remove elements while iterating over the receiver.
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   570
              Iterate over a copy to do this."
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   571
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   572
    self keysAndValuesDo:[:eachKey :eachValue|
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   573
        aBlock value:(Association key:eachKey value:eachValue).
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   574
    ].
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   575
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   576
    "Created: / 17-03-2017 / 11:05:29 / stefan"
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   577
!
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   578
23338
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   579
associationsSelect:aBlock
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   580
    "return a new collection with all elements from the receiver, for which
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   581
     the argument aBlock evaluates to true.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   582
     The block gets keys and values as an association argument.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   583
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   584
     See also: #keysAndValuesSelect: (which is slightly faster),
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   585
               #select: (which only passes the value)
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   586
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   587
     This is much like #keysAndValuesSelect:, but aBlock gets the
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   588
     key and value as a single association argument.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   589
     #keysAndValuesSelect: and is a bit faster therefore (no intermediate objects).
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   590
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   591
     WARNING: do not add/remove elements while iterating over the receiver.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   592
              Iterate over a copy to do this."
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   593
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   594
    |newCollection|
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   595
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   596
    newCollection := self species new.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   597
    self keysAndValuesDo:[:key :value |
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   598
        (aBlock value:(Association key:key value:value)) ifTrue:[
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   599
            newCollection at:key put:value
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   600
        ]
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   601
    ].
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   602
    ^ newCollection
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   603
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   604
    "
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   605
     |ages|
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   606
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   607
     ages := Dictionary new.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   608
     ages at:'cg' put:37.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   609
     ages at:'ca' put:33.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   610
     ages at:'sv' put:36.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   611
     ages at:'tk' put:28.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   612
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   613
     ages associationsSelect:[:assoc |
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   614
                (assoc key startsWith:'c') or:[assoc value < 30]].
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   615
    "
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   616
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   617
    "Created: / 14-09-2018 / 16:44:11 / Stefan Vogel"
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   618
!
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   619
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   620
do:aBlock
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   621
    "evaluate aBlock for each value"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   622
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   623
    self keysAndValuesDo:[:elKey :elValue | aBlock value:elValue]
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   624
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   625
    "Created: / 19.6.1998 / 00:56:24 / cg"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   626
!
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   627
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   628
keysAndValuesDo:aBlock
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   629
    "evaluate aBlock for each key and value"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   630
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   631
    ^ self subclassResponsibility
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   632
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   633
    "Created: / 19.6.1998 / 00:56:52 / cg"
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   634
!
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   635
23363
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   636
keysAndValuesSelect:aBlock
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   637
    "return a new collection with all elements from the receiver, for which
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   638
     the argument aBlock evaluates to true.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   639
     The block gets keys and values as separate arguments.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   640
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   641
     See also:
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   642
        #associationsSelect:    (which passes key-value pairs),
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   643
        #keysSelect:            (which passes key values),
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   644
        #select:                (which only passes the value)
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   645
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   646
     This is much like #associationsSelect:, but aBlock gets the
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   647
     key and value as two separate arguments.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   648
     #associationsSelect: is a bit slower.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   649
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   650
     WARNING: do not add/remove elements while iterating over the receiver.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   651
              Iterate over a copy to do this."
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   652
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   653
    |newCollection|
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   654
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   655
    newCollection := self species new.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   656
    self keysAndValuesDo:[:key :value |
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   657
        (aBlock value:key value:value) ifTrue:[
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   658
            newCollection at:key put:value
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   659
        ]
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   660
    ].
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   661
    ^ newCollection
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   662
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   663
    "
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   664
     |ages|
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   665
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   666
     ages := SmallDictionary new.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   667
     ages at:'cg' put:37.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   668
     ages at:'ca' put:33.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   669
     ages at:'sv' put:36.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   670
     ages at:'tk' put:28.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   671
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   672
     ages keysAndValuesSelect:[:name :age |
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   673
                (name startsWith:'c') or:[age < 30]].
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   674
    "
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   675
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   676
    "Created: / 18-09-2018 / 15:22:05 / Stefan Vogel"
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   677
!
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   678
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   679
keysSelect:aBlock
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   680
    "return a new collection with all elements from the receiver, for which
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   681
     the argument aBlock evaluates to true.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   682
     The block gets the individual keys as its single argument.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   683
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   684
     See also:
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   685
        #associationsSelect:            (which passes key->value associations),
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   686
        #keysAndValuesSelect:           (which passes key & value args)
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   687
        #select:                        (which passes values as arg),
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   688
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   689
     WARNING: do not add/remove elements while iterating over the receiver.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   690
              Iterate over a copy to do this."
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   691
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   692
    |newCollection|
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   693
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   694
    newCollection := self species new.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   695
    self keysAndValuesDo:[:key :value |
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   696
        (aBlock value:key) ifTrue:[
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   697
            newCollection at:key put:value
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   698
        ]
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   699
    ].
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   700
    ^ newCollection
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   701
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   702
    "
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   703
     |d|
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   704
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   705
     d := SmallDictionary new.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   706
     d at:#foo put:#bar.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   707
     d at:#bar put:#baz.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   708
     d at:#baz put:#foo.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   709
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   710
     d keysSelect:[:el | el startsWith:'b'].
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   711
    "
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   712
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   713
    "Created: / 18-09-2018 / 15:23:26 / Stefan Vogel"
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   714
!
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   715
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   716
printElementsDo:aBlock
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   717
    "redefined, so #printOn: prints associations"
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   718
24612
1ac50ebe401a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 23888
diff changeset
   719
    self associationsDo:aBlock
23341
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   720
1fdd8b7e859c #QUALITY by stefan
Stefan Vogel <sv@exept.de>
parents: 23338
diff changeset
   721
    "Created: / 14-09-2018 / 17:47:48 / Stefan Vogel"
23363
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   722
!
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   723
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   724
select:aBlock
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   725
    "return a new collection with all elements from the receiver, for which
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   726
     the argument aBlock evaluates to true.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   727
     The block gets the individual values as its single argument.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   728
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   729
     See also:
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   730
        #associationsSelect:            (which passes key->value associations),
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   731
        #keysAndValuesSelect:           (which passes key & value args)
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   732
        #keysSelect:                    (which passes key values),
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   733
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   734
     WARNING: do not add/remove elements while iterating over the receiver.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   735
              Iterate over a copy to do this."
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   736
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   737
    |newCollection|
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   738
24814
08643b39ee9a #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 24729
diff changeset
   739
    newCollection := self speciesForAdding new.
23363
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   740
    self keysAndValuesDo:[:key :value |
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   741
        (aBlock value:value) ifTrue:[
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   742
            newCollection at:key put:value
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   743
        ]
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   744
    ].
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   745
    ^ newCollection
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   746
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   747
    "
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   748
     |d|
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   749
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   750
     d := SmallDictionary new.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   751
     d at:#foo put:#bar.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   752
     d at:#bar put:#baz.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   753
     d at:#baz put:#foo.
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   754
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   755
     d select:[:el | el startsWith:'b'].
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   756
    "
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   757
3d39badc34e9 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 23354
diff changeset
   758
    "Created: / 18-09-2018 / 15:25:15 / Stefan Vogel"
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   759
! !
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   760
21655
058cafb6c2f6 #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21653
diff changeset
   761
23706
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   762
!KeyedCollection methodsFor:'queries'!
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   763
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   764
includesAssociation:anAssociation
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   765
    "return true, if there is an association in the receiver with the
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   766
     same key and value as the argument, anAssociation.
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   767
     NOTICE: in contrast to #includes:, this compares both key and value."
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   768
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   769
    |val|
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   770
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   771
    val := self at:(anAssociation key) ifAbsent:[^ false].
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   772
    ^ val = anAssociation value
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   773
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   774
    "Created: / 14-09-2018 / 16:48:10 / Stefan Vogel"
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   775
!
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   776
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   777
includesIdenticalKey:aKey
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   778
    "return true, if the argument, aKey is a key in the receiver"
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   779
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   780
    self keysDo:[:elKey | aKey == elKey ifTrue:[^ true]].
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   781
    ^ false
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   782
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   783
    "Created: / 19.6.1998 / 00:55:05 / cg"
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   784
!
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   785
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   786
includesKey:aKey
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   787
    "return true, if the argument, aKey is a key in the receiver"
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   788
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   789
    self keysDo:[:elKey | aKey = elKey ifTrue:[^ true]].
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   790
    ^ false
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   791
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   792
    "Created: / 19.6.1998 / 00:55:05 / cg"
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   793
! !
2ff9f4268f74 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 23398
diff changeset
   794
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   795
!KeyedCollection methodsFor:'removing'!
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   796
21732
0fd83e26247f #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21655
diff changeset
   797
removeAllKeys:aCollection
0fd83e26247f #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21655
diff changeset
   798
    "remove all keys of the argument, aCollection from the receiver.
0fd83e26247f #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21655
diff changeset
   799
     Raises an error, if some element-to-remove is not in the receiver."
0fd83e26247f #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21655
diff changeset
   800
0fd83e26247f #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21655
diff changeset
   801
    aCollection do:[:element | self removeKey:element].
0fd83e26247f #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21655
diff changeset
   802
0fd83e26247f #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21655
diff changeset
   803
    "Modified (comment): / 28-04-2017 / 13:36:15 / stefan"
0fd83e26247f #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21655
diff changeset
   804
!
0fd83e26247f #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 21655
diff changeset
   805
23338
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   806
removeAssociation:assoc
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   807
    "remove the association from the collection.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   808
     If it was not in the collection report an error.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   809
     Only the key is used in the passed argument, and a new
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   810
     association, for the key and the previously stored value is returned.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   811
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   812
     WARNING: do not remove elements while iterating over the receiver.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   813
              See #saveRemoveKey: to do this."
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   814
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   815
    |key|
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   816
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   817
    key := assoc key.
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   818
    ^ Association key:key value:(self removeKey:key)
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   819
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   820
    "Created: / 14-09-2018 / 16:20:47 / Stefan Vogel"
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   821
!
e2290d3eb871 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21732
diff changeset
   822
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   823
removeKey:aKey
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   824
    "remove key (and the value stored under that key) from the
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   825
     receiver; raise an error if no such element is contained"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   826
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   827
    ^ self removeKey:aKey ifAbsent:[self errorKeyNotFound:aKey]
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   828
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   829
    "Created: / 19.6.1998 / 00:53:25 / cg"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   830
    "Modified: / 19.6.1998 / 00:54:02 / cg"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   831
!
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   832
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   833
removeKey:aKey ifAbsent:exceptionBlock
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   834
    "remove key (and the value stored under that key) from the
19844
9a7234d4b08c #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19469
diff changeset
   835
     receiver; return the value which was stored previously there.
9a7234d4b08c #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 19469
diff changeset
   836
     If no such element is contained, return the value
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   837
     from evaluating exceptionBlock"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   838
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   839
    ^ self subclassResponsibility
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   840
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   841
    "Created: / 19.6.1998 / 00:53:58 / cg"
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   842
! !
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   843
21653
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   844
!KeyedCollection methodsFor:'searching'!
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   845
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   846
findFirst:aBlock ifNone:exceptionValue
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   847
    "find the index of the first element, for which evaluation of the argument, aBlock returns true;
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   848
     return its index or the value from exceptionValue if none detected.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   849
     This is much like #detect:ifNone:, however, here an INDEX is returned,
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   850
     while #detect:ifNone: returns the element.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   851
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   852
     Here we return the first key for which aBlock matches the value.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   853
     Note that there is no order in a Dictionary, so any element is first."
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   854
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   855
    self keysAndValuesDo:[:eachKey :eachValue| (aBlock value:eachValue) ifTrue:[^ eachKey]].
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   856
    ^ exceptionValue value.
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   857
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   858
    "
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   859
        (KeyValueList withKeys:#('a' 'b' 'c') andValues:#('bla' 'hello' 'hallo'))
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   860
            findFirst:[:v| v first = $h].
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   861
    "
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   862
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   863
    "Created: / 16-03-2017 / 17:46:02 / stefan"
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   864
!
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   865
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   866
findFirstKey:aBlock
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   867
    "find and return the first key, for which evaluation of the argument, aBlock
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   868
     returns true; return nil if none is detected."
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   869
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   870
    self keysDo:[:key |
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   871
        (aBlock value:key) ifTrue:[^ key].
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   872
    ].
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   873
    ^ nil
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   874
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   875
    "Created: 8.10.1996 / 22:01:31 / cg"
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   876
    "Modified: 8.10.1996 / 22:02:03 / cg"
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   877
! !
baee5890dca8 #FEATURE by stefan
Stefan Vogel <sv@exept.de>
parents: 21649
diff changeset
   878
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   879
!KeyedCollection class methodsFor:'documentation'!
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   880
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   881
version
19469
e43475084bb5 #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17120
diff changeset
   882
    ^ '$Header$'
12667
4297ecfffa96 #values moved up
Claus Gittinger <cg@exept.de>
parents: 11222
diff changeset
   883
!
4297ecfffa96 #values moved up
Claus Gittinger <cg@exept.de>
parents: 11222
diff changeset
   884
4297ecfffa96 #values moved up
Claus Gittinger <cg@exept.de>
parents: 11222
diff changeset
   885
version_CVS
19469
e43475084bb5 #DOCUMENTATION
Claus Gittinger <cg@exept.de>
parents: 17120
diff changeset
   886
    ^ '$Header$'
3615
c0f82feaf6a7 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   887
! !
17120
246d9198d84e class: KeyedCollection
Claus Gittinger <cg@exept.de>
parents: 13045
diff changeset
   888