HierarchicalItem.st
author Claus Gittinger <cg@exept.de>
Thu, 18 Dec 2008 11:33:20 +0100
changeset 3613 440f0aa671ce
parent 3562 188996f5b78b
child 3615 b2e2242fd240
permissions -rw-r--r--
return value fixed (consistent)
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1431
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
     1
"
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
     2
 COPYRIGHT (c) 1999 by eXept Software AG
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
     3
              All Rights Reserved
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
     4
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
     5
 This software is furnished under a license and may be used
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
     6
 only in accordance with the terms of that license and with the
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
     8
 be provided or otherwise made available to, or used by, any
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
     9
 other person.  No title to or ownership of the software is
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    10
 hereby transferred.
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    11
"
1794
029df2e76784 *** empty log message ***
ca
parents: 1733
diff changeset
    12
"{ Package: 'stx:libwidg2' }"
029df2e76784 *** empty log message ***
ca
parents: 1733
diff changeset
    13
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
Object subclass:#HierarchicalItem
1606
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
    15
	instanceVariableNames:'parent children isExpanded height width'
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
	classVariableNames:''
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
	poolDictionaries:''
1430
ae9e48cc7b9d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1409
diff changeset
    18
	category:'Views-Support'
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
HierarchicalItem subclass:#Example
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
	instanceVariableNames:'label icon'
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
	classVariableNames:'PenguinIcon'
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
	poolDictionaries:''
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
	privateIn:HierarchicalItem
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
!HierarchicalItem class methodsFor:'documentation'!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
1431
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    30
copyright
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    31
"
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    32
 COPYRIGHT (c) 1999 by eXept Software AG
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    33
              All Rights Reserved
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    34
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    35
 This software is furnished under a license and may be used
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    36
 only in accordance with the terms of that license and with the
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    37
 inclusion of the above copyright notice.   This software may not
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    38
 be provided or otherwise made available to, or used by, any
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    39
 other person.  No title to or ownership of the software is
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    40
 hereby transferred.
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    41
"
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    42
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    43
!
0cc20a8f2f7c docu & copyright
Claus Gittinger <cg@exept.de>
parents: 1430
diff changeset
    44
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    45
documentation
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    46
"
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
    Hierarchical Items are mostly like Models, but the list of
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    48
    dependencies are kept by its HierarchicalList.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    49
    The class is used to build up hierarchical trees.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    50
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
    [Instance variables:]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    52
        parent      <Item, List or nil>         parent or my HierarchicalList.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    53
        children    <Collection or nil>         list of children
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    54
        isExpanded  <Boolean>                   indicates whether the item is
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    55
                                                expanded or collapsed
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
    [author:]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
        Claus Atzkern
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
    [see also:]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    61
        HierarchicalList
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
        HierarchicalListView
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    63
"
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    64
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
!HierarchicalItem class methodsFor:'instance creation'!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
new
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
    ^ (self basicNew) initialize
2314
3cd113583526 *** empty log message ***
ca
parents: 2313
diff changeset
    72
!
3cd113583526 *** empty log message ***
ca
parents: 2313
diff changeset
    73
3cd113583526 *** empty log message ***
ca
parents: 2313
diff changeset
    74
parent:aParent
3cd113583526 *** empty log message ***
ca
parents: 2313
diff changeset
    75
    |item|
3cd113583526 *** empty log message ***
ca
parents: 2313
diff changeset
    76
3cd113583526 *** empty log message ***
ca
parents: 2313
diff changeset
    77
    item := self new.
3cd113583526 *** empty log message ***
ca
parents: 2313
diff changeset
    78
    item parent:aParent.
3cd113583526 *** empty log message ***
ca
parents: 2313
diff changeset
    79
  ^ item
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
    82
!HierarchicalItem class methodsFor:'protocol'!
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
    83
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
    84
doResetExtentOnChange
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
    85
    "true: the extent of the item is reset if a change
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
    86
     notification is raised from the item. the default is true
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
    87
    "
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
    88
    ^ true
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
    89
! !
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
    90
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
!HierarchicalItem methodsFor:'accessing'!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
    93
getChildren
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
    94
    "returns the children at it is; not going to the model ...
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
    95
    "
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
    96
    ^ children
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
    97
!
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
    98
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    99
level
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   100
    "returns the level starting with 1
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   101
    "
2386
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   102
    |item level|
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   103
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   104
    "/ for optimization we try to suppress a block
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   105
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   106
    item  := self.
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   107
2386
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   108
    (item := item parentOrModel) isNil ifTrue:[^ 0].
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   109
    (item := item parentOrModel) isNil ifTrue:[^ 1].
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   110
    (item := item parentOrModel) isNil ifTrue:[^ 2].
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   111
    (item := item parentOrModel) isNil ifTrue:[^ 3].
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   112
    (item := item parentOrModel) isNil ifTrue:[^ 4].
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   113
    (item := item parentOrModel) isNil ifTrue:[^ 5].
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   114
    (item := item parentOrModel) isNil ifTrue:[^ 6].
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   115
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   116
    level := 7.
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   117
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   118
    [(item := item parentOrModel) notNil] whileTrue:[
3090
6204e0aa85d9 *** empty log message ***
fm
parents: 3071
diff changeset
   119
        level := level + 1.
3562
Claus Gittinger <cg@exept.de>
parents: 3337
diff changeset
   120
        level > 100000 ifTrue:[
Claus Gittinger <cg@exept.de>
parents: 3337
diff changeset
   121
            self halt:'possibly recursive item hierarchy'
Claus Gittinger <cg@exept.de>
parents: 3337
diff changeset
   122
        ].
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   123
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   124
    ^ level
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   125
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   126
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   127
parent
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   128
    "returns the parent or nil
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   129
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   130
    ^ (parent notNil and:[parent isHierarchicalItem]) ifTrue:[parent]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   131
                                                     ifFalse:[nil]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   132
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   133
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   134
parent:aParent
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   135
    "set the parent (or the model if the item is the root item)
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   136
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   137
    parent := aParent
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   138
1883
7da039ab6677 added: access-methode for rootItem
tm
parents: 1876
diff changeset
   139
!
7da039ab6677 added: access-methode for rootItem
tm
parents: 1876
diff changeset
   140
7da039ab6677 added: access-methode for rootItem
tm
parents: 1876
diff changeset
   141
rootItem
7da039ab6677 added: access-methode for rootItem
tm
parents: 1876
diff changeset
   142
    "returns the root item
7da039ab6677 added: access-methode for rootItem
tm
parents: 1876
diff changeset
   143
    "
7da039ab6677 added: access-methode for rootItem
tm
parents: 1876
diff changeset
   144
    parent isHierarchicalItem ifTrue:[
7da039ab6677 added: access-methode for rootItem
tm
parents: 1876
diff changeset
   145
        ^ parent rootItem
7da039ab6677 added: access-methode for rootItem
tm
parents: 1876
diff changeset
   146
    ].
7da039ab6677 added: access-methode for rootItem
tm
parents: 1876
diff changeset
   147
    ^ self
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   148
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   149
1818
fe99c5c721e9 category changes
Claus Gittinger <cg@exept.de>
parents: 1804
diff changeset
   150
!HierarchicalItem methodsFor:'accessing-children'!
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   151
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   152
at:anIndex
1900
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   153
    "return the child at anIndex if valid;
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   154
     if the index is invalid, nil is returned"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   155
1900
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   156
    ^ self at:anIndex ifAbsent:nil
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   157
!
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   158
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   159
at:anIndex ifAbsent:exceptionBlock
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   160
    "return the child at anIndex if valid; if the index is
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   161
     invalid, the result of evaluating the exceptionBlock is returned."
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   162
1900
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   163
    |list|
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   164
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   165
    (list := self children) notNil ifTrue:[
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   166
        ^ list at:anIndex ifAbsent:exceptionBlock
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   167
    ].
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   168
    ^ exceptionBlock value
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   169
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   170
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   171
at:anIndex put:anItem
3613
440f0aa671ce return value fixed (consistent)
Claus Gittinger <cg@exept.de>
parents: 3562
diff changeset
   172
    "replace a child by a new item. return anItem (sigh)"
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   173
2340
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   174
    |children oldItem visIndex model expFlag|
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   175
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   176
    anItem isNil ifTrue:[
3613
440f0aa671ce return value fixed (consistent)
Claus Gittinger <cg@exept.de>
parents: 3562
diff changeset
   177
        self removeFromIndex:anIndex toIndex:anIndex.
440f0aa671ce return value fixed (consistent)
Claus Gittinger <cg@exept.de>
parents: 3562
diff changeset
   178
        ^ nil
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   179
    ].
2340
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   180
    anItem parent:self.
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   181
2340
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   182
    (model := self model) isNil ifTrue:[
3613
440f0aa671ce return value fixed (consistent)
Claus Gittinger <cg@exept.de>
parents: 3562
diff changeset
   183
        self children at:anIndex put:anItem.
440f0aa671ce return value fixed (consistent)
Claus Gittinger <cg@exept.de>
parents: 3562
diff changeset
   184
        ^ anItem
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   185
    ].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   186
2340
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   187
    model criticalDo:[
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   188
        children := self children.
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   189
        oldItem  := children at:anIndex.
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   190
2340
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   191
        oldItem isExpanded ifTrue:[
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   192
            oldItem collapse
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   193
        ].
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   194
        visIndex := model identityIndexOf:oldItem.
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   195
        expFlag  := anItem isExpanded.
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   196
        anItem setExpanded:false.
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   197
2340
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   198
        children at:anIndex put:anItem.
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   199
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   200
        visIndex ~~ 0 ifTrue:[
2343
bf4bdedf0fa7 bugfix in: #at:put:
ca
parents: 2340
diff changeset
   201
            model at:visIndex put:anItem.
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   202
        ].
2340
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   203
        self changed:#redraw.
2226773397c4 bugfix in: #at:put:
ca
parents: 2315
diff changeset
   204
        expFlag ifTrue:[ anItem expand ].
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   205
    ].
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   206
    ^ anItem
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   207
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   208
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   209
children:aListOfChildren
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   210
    "set a new list of children"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   211
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   212
    self criticalDo:[
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   213
        self removeAll.
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   214
        self addAll:aListOfChildren beforeIndex:1
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   215
    ].
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   216
    ^ aListOfChildren
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   217
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   218
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   219
first
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   220
    "returns the first child
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   221
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   222
    ^ self at:1
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   223
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   224
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   225
last
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   226
    "returns the last child
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   227
    "
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   228
    ^ self at:(self size)
1900
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   229
!
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   230
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   231
second
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   232
    "returns the second child
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   233
    "
27372ea0db5f implement #at:ifAbsent:
ca
parents: 1899
diff changeset
   234
    ^ self at:2
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   235
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   236
1818
fe99c5c721e9 category changes
Claus Gittinger <cg@exept.de>
parents: 1804
diff changeset
   237
!HierarchicalItem methodsFor:'accessing-hierarchy'!
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   238
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   239
collapse
2549
fb6d594099b2 checkin from browser
Stefan Vogel <sv@exept.de>
parents: 2547
diff changeset
   240
    "hide all my subitems"
fb6d594099b2 checkin from browser
Stefan Vogel <sv@exept.de>
parents: 2547
diff changeset
   241
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   242
    |visChd index|
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   243
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   244
    self canCollapse ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   245
        isExpanded := false.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   246
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   247
        self criticalDo:[
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   248
            (index := self listIndex) notNil ifTrue:[
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   249
                "/ do not call :#size: children will be autoloaded !!!!
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   250
                (visChd := children size) ~~ 0 ifTrue:[
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
   251
                    self nonCriticalFrom:1 to:nil do:[:el|
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   252
                        visChd := visChd + el numberOfVisibleChildren
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   253
                    ].
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   254
                    self model itemRemoveFromIndex:(index + 1) toIndex:(index + visChd).
2201
aa74fa6137a5 make indicator dependent on hasIndicator and not hasChildren
ca
parents: 2193
diff changeset
   255
                ].
2549
fb6d594099b2 checkin from browser
Stefan Vogel <sv@exept.de>
parents: 2547
diff changeset
   256
                index ~~ 0 ifTrue:[self hierarchyChanged].
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   257
            ]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   258
        ]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   259
    ]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   260
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   261
2476
298ad746e52f added enforcedExpand;
Claus Gittinger <cg@exept.de>
parents: 2465
diff changeset
   262
enforcedExpand
2724
519a2190bf15 *** empty log message ***
martin
parents: 2716
diff changeset
   263
    "expand children - even if there are no children,
2476
298ad746e52f added enforcedExpand;
Claus Gittinger <cg@exept.de>
parents: 2465
diff changeset
   264
     the item is initially expanded (but this might be undone later,
298ad746e52f added enforcedExpand;
Claus Gittinger <cg@exept.de>
parents: 2465
diff changeset
   265
     when we know that no children are there"
298ad746e52f added enforcedExpand;
Claus Gittinger <cg@exept.de>
parents: 2465
diff changeset
   266
298ad746e52f added enforcedExpand;
Claus Gittinger <cg@exept.de>
parents: 2465
diff changeset
   267
    self expand:true
298ad746e52f added enforcedExpand;
Claus Gittinger <cg@exept.de>
parents: 2465
diff changeset
   268
!
298ad746e52f added enforcedExpand;
Claus Gittinger <cg@exept.de>
parents: 2465
diff changeset
   269
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   270
expand
2476
298ad746e52f added enforcedExpand;
Claus Gittinger <cg@exept.de>
parents: 2465
diff changeset
   271
    "expand children - but only if there are children 
298ad746e52f added enforcedExpand;
Claus Gittinger <cg@exept.de>
parents: 2465
diff changeset
   272
     (i.e. this cannot be used before the childInfo is valid;
298ad746e52f added enforcedExpand;
Claus Gittinger <cg@exept.de>
parents: 2465
diff changeset
   273
      aka not before the updateTask came along this item)"
298ad746e52f added enforcedExpand;
Claus Gittinger <cg@exept.de>
parents: 2465
diff changeset
   274
298ad746e52f added enforcedExpand;
Claus Gittinger <cg@exept.de>
parents: 2465
diff changeset
   275
    self expand:false
298ad746e52f added enforcedExpand;
Claus Gittinger <cg@exept.de>
parents: 2465
diff changeset
   276
!
298ad746e52f added enforcedExpand;
Claus Gittinger <cg@exept.de>
parents: 2465
diff changeset
   277
298ad746e52f added enforcedExpand;
Claus Gittinger <cg@exept.de>
parents: 2465
diff changeset
   278
expand:enforced
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
   279
    "expand children"
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
   280
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   281
    |index list|
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   282
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   283
    "/ test whether the item already is expanded; #canExpand could be redefined
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   284
    "/ without checking whether the node is expanded (happens already) !!
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   285
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
   286
    isExpanded ifTrue:[ ^ self ].
2724
519a2190bf15 *** empty log message ***
martin
parents: 2716
diff changeset
   287
    (enforced not and:[self canExpand not]) ifTrue:[ ^ self ].
1942
cf35cdb2395e bug-fixes if lazy children creation
martin
parents: 1900
diff changeset
   288
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   289
    self criticalDo:[
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   290
        (index := self listIndex) notNil ifTrue:[
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   291
            "/ must set expand-flag to false, otherwise change notifications
2476
298ad746e52f added enforcedExpand;
Claus Gittinger <cg@exept.de>
parents: 2465
diff changeset
   292
            "/ are raised during lazy auto creation (to the list).
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   293
            isExpanded := false.
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   294
            list := self children.
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   295
            isExpanded := true.
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   296
2832
e1f6a7c48552 code cleanup
Claus Gittinger <cg@exept.de>
parents: 2781
diff changeset
   297
            list notEmptyOrNil ifTrue:[
e1f6a7c48552 code cleanup
Claus Gittinger <cg@exept.de>
parents: 2781
diff changeset
   298
                list := OrderedCollection new:64.
e1f6a7c48552 code cleanup
Claus Gittinger <cg@exept.de>
parents: 2781
diff changeset
   299
                self addVisibleChildrenTo:list.
e1f6a7c48552 code cleanup
Claus Gittinger <cg@exept.de>
parents: 2781
diff changeset
   300
                self model itemAddAll:list beforeIndex:(index + 1).
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   301
            ].
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   302
            index ~~ 0 ifTrue:[self hierarchyChanged].
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   303
        ] ifFalse:[
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   304
            isExpanded := true
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   305
        ]
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   306
    ].
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   307
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   308
1409
e46f8d30a9c9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   309
makeVisible
e46f8d30a9c9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   310
    "expand all my parents
e46f8d30a9c9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   311
    "
e46f8d30a9c9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   312
    (parent notNil and:[parent isHierarchicalItem]) ifTrue:[
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   313
        self criticalDo:[
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   314
            parent expand.
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   315
            parent makeVisible
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   316
        ]
1409
e46f8d30a9c9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   317
    ].
e46f8d30a9c9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   318
!
e46f8d30a9c9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   319
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   320
recursiveCollapse
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   321
    "collapse all item and sub items
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   322
     **** must be expanded
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   323
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   324
    |visChd index|
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   325
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   326
    self canCollapse ifTrue:[
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   327
        self criticalDo:[
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   328
            (index := self listIndex) notNil ifTrue:[
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   329
                "/ do not call :#size: children will be autoloaded !!!!
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   330
                (visChd := children size) ~~ 0 ifTrue:[
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
   331
                    self nonCriticalFrom:1 to:nil do:[:el|
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   332
                        visChd := visChd + el numberOfVisibleChildren
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   333
                    ].
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   334
                ].
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   335
                self recursiveSetCollapsed.
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   336
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   337
                visChd ~~ 0 ifTrue:[
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   338
                    self model itemRemoveFromIndex:(index + 1)
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   339
                                           toIndex:(index + visChd)
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   340
                ].
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   341
                index ~~ 0 ifTrue:[
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   342
                    self hierarchyChanged
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   343
                ]
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   344
            ] ifFalse:[
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   345
                self recursiveSetCollapsed
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   346
            ]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   347
        ]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   348
    ]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   349
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   350
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   351
recursiveExpand
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   352
    "expand children and sub-children
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   353
     **** must be collapsed
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   354
    "
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   355
    "/ test whether the item already is expanded; #canExpand could be redefined
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   356
    "/ without checking whether the node is expanded (happens already) !!
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   357
2846
17a1d1db69dd remove recursiveForceExpand -> make no sense
ab
parents: 2845
diff changeset
   358
    |index list|
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
   359
    isExpanded ifTrue:[ ^ self ].
2845
fb807c9aa195 Add recursive force expand, to force expand of children independed
ab
parents: 2832
diff changeset
   360
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
   361
    self canExpand ifFalse:[ ^ self ].
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   362
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   363
    isExpanded := true.
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   364
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   365
    self criticalDo:[
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   366
        self size ~~ 0 ifTrue:[
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   367
            index := self listIndex.    "/ get the visible list index
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   368
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   369
            index isNil ifTrue:[        "/ not visible
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   370
                self nonCriticalFrom:1 to:nil do:[:el|
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   371
                    el setExpanded:true
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   372
                ].
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   373
            ] ifFalse:[
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   374
                list := OrderedCollection new:512.
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   375
                self recursiveSetExpandedAndAddToList:list.
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   376
                self model itemAddAll:list beforeIndex:(index + 1).
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   377
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   378
                index ~~ 0 ifTrue:[self hierarchyChanged]
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   379
            ]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   380
        ]
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   381
    ].
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   382
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   383
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   384
recursiveToggleExpand
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   385
    "if the item is collapsed, the item and all its sub-items
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
   386
     are expanded otherwise collapsed"
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
   387
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
   388
    isExpanded ifTrue:[
1598
33202082065d care for uninitialized isExpanded
Claus Gittinger <cg@exept.de>
parents: 1571
diff changeset
   389
        self recursiveCollapse
33202082065d care for uninitialized isExpanded
Claus Gittinger <cg@exept.de>
parents: 1571
diff changeset
   390
    ] ifFalse:[
33202082065d care for uninitialized isExpanded
Claus Gittinger <cg@exept.de>
parents: 1571
diff changeset
   391
        self recursiveExpand
33202082065d care for uninitialized isExpanded
Claus Gittinger <cg@exept.de>
parents: 1571
diff changeset
   392
    ]
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   393
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   394
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   395
toggleExpand
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   396
    "if the item is collapsed, the item is expanded otherwise
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
   397
     collapsed"
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
   398
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
   399
    isExpanded ifTrue:[
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   400
        self collapse
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   401
    ] ifFalse:[
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   402
        self expand
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   403
    ].
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   404
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   405
1818
fe99c5c721e9 category changes
Claus Gittinger <cg@exept.de>
parents: 1804
diff changeset
   406
!HierarchicalItem methodsFor:'accessing-mvc'!
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   407
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   408
application
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   409
    "returns the responsible application or nil"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   410
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   411
    |model|
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   412
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   413
    (model := self model) notNil ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   414
        ^ model application
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   415
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   416
    ^ nil
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   417
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   418
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   419
applicationsDo:aOneArgBlock
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   420
    "evaluate the block for each dependent application"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   421
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   422
    |model|
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   423
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   424
    (model := self model) notNil ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   425
        model applicationsDo:aOneArgBlock
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   426
    ]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   427
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   428
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   429
model
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   430
    "returns the hierachicalList model or nil
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   431
    "
2386
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   432
    |item next|
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   433
2716
c446689e8021 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2708
diff changeset
   434
    item := self. 
c446689e8021 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2708
diff changeset
   435
    [ (next := item parentOrModel) notNil ] whileTrue:[
c446689e8021 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2708
diff changeset
   436
        item := next.
c446689e8021 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2708
diff changeset
   437
    ].
2386
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   438
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   439
    item isHierarchicalItem ifFalse:[^ item].
64b2a77c1b57 *** empty log message ***
ca
parents: 2357
diff changeset
   440
    ^ nil
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   441
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   442
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   443
!HierarchicalItem methodsFor:'adding & removing'!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   444
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   445
add:aChildItem
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   446
    "add a child at end"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   447
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   448
    ^ self add:aChildItem beforeIndex:(self children size + 1).
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   449
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   450
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   451
add:aChildItem after:aChild
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   452
    "add an item after an existing item"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   453
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   454
    |index|
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   455
2315
d709a664a87c bug fix
ca
parents: 2314
diff changeset
   456
    index := self identityIndexOf:aChild.
2484
92f9e42980ab correct use of ascentOn: for display
Claus Gittinger <cg@exept.de>
parents: 2476
diff changeset
   457
    index == 0 ifTrue:[ self subscriptBoundsError:index ].
2315
d709a664a87c bug fix
ca
parents: 2314
diff changeset
   458
d709a664a87c bug fix
ca
parents: 2314
diff changeset
   459
    self add:aChildItem beforeIndex:(index + 1).
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   460
    ^ aChildItem
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   461
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   462
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   463
add:aChildItem afterIndex:anIndex
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   464
    "add an item after an index"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   465
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   466
    ^ self add:aChildItem beforeIndex:(anIndex + 1).
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   467
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   468
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   469
add:aChildItem before:aChild
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   470
    "add an item before an existing item"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   471
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   472
    |index|
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   473
2315
d709a664a87c bug fix
ca
parents: 2314
diff changeset
   474
    index := self identityIndexOf:aChild.
2484
92f9e42980ab correct use of ascentOn: for display
Claus Gittinger <cg@exept.de>
parents: 2476
diff changeset
   475
    index == 0 ifTrue:[ self subscriptBoundsError:index ].
2315
d709a664a87c bug fix
ca
parents: 2314
diff changeset
   476
d709a664a87c bug fix
ca
parents: 2314
diff changeset
   477
    self add:aChildItem beforeIndex:index.
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   478
    ^ aChild
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   479
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   480
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   481
add:aChildItem beforeIndex:anIndex
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   482
    "add an item before an index"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   483
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   484
    aChildItem notNil ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   485
        self addAll:(Array with:aChildItem) beforeIndex:anIndex
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   486
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   487
    ^ aChildItem
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   488
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   489
1488
370cb752ff54 checkin from browser
tm
parents: 1486
diff changeset
   490
add:aChild sortBlock:aBlock
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   491
    "add a child sorted"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   492
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   493
    self criticalDo:[
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   494
        self basicAdd:aChild sortBlock:aBlock
1488
370cb752ff54 checkin from browser
tm
parents: 1486
diff changeset
   495
    ].
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   496
    ^ aChild
1488
370cb752ff54 checkin from browser
tm
parents: 1486
diff changeset
   497
!
370cb752ff54 checkin from browser
tm
parents: 1486
diff changeset
   498
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   499
addAll:aList
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   500
    "add children at the end"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   501
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   502
    ^ self addAll:aList beforeIndex:(self children size + 1)
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   503
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   504
1650
9ac3cdd8572d checkin from browser
ps
parents: 1607
diff changeset
   505
addAll:aList before:aChild
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   506
    "add an item before an existing item"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   507
1650
9ac3cdd8572d checkin from browser
ps
parents: 1607
diff changeset
   508
    |index|
9ac3cdd8572d checkin from browser
ps
parents: 1607
diff changeset
   509
2315
d709a664a87c bug fix
ca
parents: 2314
diff changeset
   510
    index := self identityIndexOf:aChild.
2484
92f9e42980ab correct use of ascentOn: for display
Claus Gittinger <cg@exept.de>
parents: 2476
diff changeset
   511
    index == 0 ifTrue:[ self subscriptBoundsError:index ].
2315
d709a664a87c bug fix
ca
parents: 2314
diff changeset
   512
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   513
    ^ self addAll:aList beforeIndex:index
1650
9ac3cdd8572d checkin from browser
ps
parents: 1607
diff changeset
   514
!
9ac3cdd8572d checkin from browser
ps
parents: 1607
diff changeset
   515
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   516
addAll:aList beforeIndex:anIndex
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   517
    "add children before an index"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   518
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   519
    aList size ~~ 0 ifTrue:[
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   520
        self criticalDo:[
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   521
            self basicAddAll:aList beforeIndex:anIndex
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   522
        ]
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   523
    ].
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   524
    ^ aList
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   525
!
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   526
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   527
addAll:aList sortBlock:aBlock
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   528
    "add children sorted"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   529
2357
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   530
    aList size == 0 ifTrue:[ ^ aList ].
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   531
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   532
    aBlock isNil ifTrue:[
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   533
        self addAll:aList.
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   534
    ] ifFalse:[
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   535
        self criticalDo:[
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   536
            aList do:[:el| self basicAdd:el sortBlock:aBlock ]
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   537
        ]
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   538
    ].
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   539
    ^ aList
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   540
!
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   541
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   542
addAllFirst:aCollectionOfItems
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   543
    "add children at the beginning"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   544
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   545
    ^ self addAll:aCollectionOfItems beforeIndex:1
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   546
!
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   547
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   548
addAllLast:aCollectionOfItems
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   549
    "add children at the end"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   550
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   551
    ^ self addAll:aCollectionOfItems
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   552
!
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   553
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   554
addFirst:aChildItem
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   555
    "add a child at the beginning"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   556
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   557
    ^ self add:aChildItem beforeIndex:1.
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   558
!
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   559
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   560
addLast:anItem
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   561
    "add a child at the end"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   562
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   563
    ^ self add:anItem
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   564
!
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   565
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   566
remove
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   567
    "remove the item
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   568
    "
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   569
    parent notNil ifTrue:[                                      "check whether parent exists"
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   570
        parent isHierarchicalItem ifTrue:[parent remove:self]   "parent is HierarchicalItem"
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   571
                                 ifFalse:[parent root:nil]      "parent is HierarchicalList"
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   572
    ].
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   573
    ^ self
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   574
!
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   575
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   576
remove:aChild
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   577
    "remove a child
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   578
    "
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   579
    self removeIndex:(self identityIndexOf:aChild)
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   580
        
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   581
!
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   582
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   583
removeAll
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   584
    "remove all children
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   585
    "
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   586
    |size|
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   587
1942
cf35cdb2395e bug-fixes if lazy children creation
martin
parents: 1900
diff changeset
   588
    (size := children size) ~~ 0 ifTrue:[
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   589
        self removeFromIndex:1 toIndex:size
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   590
    ]
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   591
!
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   592
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   593
removeAll:aList
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   594
    "remove all children in the collection
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   595
    "
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   596
    |index|
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   597
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   598
    aList size ~~ 0 ifTrue:[
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   599
        self criticalDo:[
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   600
            aList do:[:el|
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   601
                (index := self identityIndexOf:el) ~~ 0 ifTrue:[
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   602
                    self removeIndex:index
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   603
                ]
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   604
            ]
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   605
        ]
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   606
    ].
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   607
    ^ aList
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   608
!
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   609
1899
d7c9a9dfdbf0 bugfix in: #removeFromIndex:toIndex:
ca
parents: 1883
diff changeset
   610
removeFromIndex:startIndex
d7c9a9dfdbf0 bugfix in: #removeFromIndex:toIndex:
ca
parents: 1883
diff changeset
   611
    "remove the children from startIndex up to end of children
d7c9a9dfdbf0 bugfix in: #removeFromIndex:toIndex:
ca
parents: 1883
diff changeset
   612
    "
d7c9a9dfdbf0 bugfix in: #removeFromIndex:toIndex:
ca
parents: 1883
diff changeset
   613
    ^ self removeFromIndex:startIndex toIndex:(children size)
d7c9a9dfdbf0 bugfix in: #removeFromIndex:toIndex:
ca
parents: 1883
diff changeset
   614
!
d7c9a9dfdbf0 bugfix in: #removeFromIndex:toIndex:
ca
parents: 1883
diff changeset
   615
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   616
removeFromIndex:startIndex toIndex:stopIndex
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   617
    "remove the children from startIndex up to and including
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   618
     the child under stopIndex.
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   619
    "
2853
e852742cbd10 when the last child is removed,
Claus Gittinger <cg@exept.de>
parents: 2851
diff changeset
   620
    |nrOfChildren stop|
1899
d7c9a9dfdbf0 bugfix in: #removeFromIndex:toIndex:
ca
parents: 1883
diff changeset
   621
2853
e852742cbd10 when the last child is removed,
Claus Gittinger <cg@exept.de>
parents: 2851
diff changeset
   622
    nrOfChildren := children size.
1899
d7c9a9dfdbf0 bugfix in: #removeFromIndex:toIndex:
ca
parents: 1883
diff changeset
   623
2853
e852742cbd10 when the last child is removed,
Claus Gittinger <cg@exept.de>
parents: 2851
diff changeset
   624
    (startIndex <= stopIndex and:[startIndex <= nrOfChildren]) ifTrue:[
e852742cbd10 when the last child is removed,
Claus Gittinger <cg@exept.de>
parents: 2851
diff changeset
   625
        stop := stopIndex min:nrOfChildren.
1899
d7c9a9dfdbf0 bugfix in: #removeFromIndex:toIndex:
ca
parents: 1883
diff changeset
   626
        
d7c9a9dfdbf0 bugfix in: #removeFromIndex:toIndex:
ca
parents: 1883
diff changeset
   627
        self criticalDo:[
d7c9a9dfdbf0 bugfix in: #removeFromIndex:toIndex:
ca
parents: 1883
diff changeset
   628
            self basicRemoveFromIndex:startIndex toIndex:stop
d7c9a9dfdbf0 bugfix in: #removeFromIndex:toIndex:
ca
parents: 1883
diff changeset
   629
        ]
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   630
    ].
2853
e852742cbd10 when the last child is removed,
Claus Gittinger <cg@exept.de>
parents: 2851
diff changeset
   631
e852742cbd10 when the last child is removed,
Claus Gittinger <cg@exept.de>
parents: 2851
diff changeset
   632
    children size == 0 ifTrue:[
2854
20b890ba0f6c allow subclasses to define the collapse-behavior
Claus Gittinger <cg@exept.de>
parents: 2853
diff changeset
   633
        self clearExpandedWhenLastChildWasRemoved ifTrue:[
20b890ba0f6c allow subclasses to define the collapse-behavior
Claus Gittinger <cg@exept.de>
parents: 2853
diff changeset
   634
            isExpanded := false.
20b890ba0f6c allow subclasses to define the collapse-behavior
Claus Gittinger <cg@exept.de>
parents: 2853
diff changeset
   635
        ]
2853
e852742cbd10 when the last child is removed,
Claus Gittinger <cg@exept.de>
parents: 2851
diff changeset
   636
    ].
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   637
!
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   638
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   639
removeIndex:anIndex
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   640
    "remove the child at an index
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   641
    "
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   642
    anIndex > 0 ifTrue:[
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   643
        self removeFromIndex:anIndex toIndex:anIndex
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   644
    ]
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   645
! !
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   646
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   647
!HierarchicalItem methodsFor:'basic adding & removing'!
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   648
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   649
basicAdd:aChild sortBlock:aBlock
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   650
    "add a child sorted"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   651
2357
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   652
    |size list|
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   653
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   654
    size := children size.
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   655
    list := Array with:aChild.
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   656
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   657
    (aBlock notNil and:[size ~~ 0]) ifTrue:[
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   658
        children keysAndValuesDo:[:i :el|
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   659
            (aBlock value:aChild value:el) ifTrue:[
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   660
                self basicAddAll:list beforeIndex:i.
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   661
                ^ aChild
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   662
            ]
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   663
        ]
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   664
    ].
2357
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   665
    self basicAddAll:list beforeIndex:(size + 1).
3fa40ed08bc6 supress change notifications for: adding sorted
ca
parents: 2343
diff changeset
   666
    ^ aChild.
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   667
!
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   668
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   669
basicAddAll:aList beforeIndex:anIndex
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   670
    "add children before an index"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   671
1602
00fe8b9b81d6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1601
diff changeset
   672
    |coll model notify index size|
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   673
1942
cf35cdb2395e bug-fixes if lazy children creation
martin
parents: 1900
diff changeset
   674
    size := children size.
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   675
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   676
    anIndex == 1 ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   677
        notify := self
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   678
    ] ifFalse:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   679
        anIndex > size ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   680
            anIndex > (1 + size) ifTrue:[
2484
92f9e42980ab correct use of ascentOn: for display
Claus Gittinger <cg@exept.de>
parents: 2476
diff changeset
   681
                ^ self subscriptBoundsError:index
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   682
            ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   683
            notify := self at:size
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   684
        ] ifFalse:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   685
            notify := nil
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   686
        ]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   687
    ].
1669
443680316aac checkin from browser
ca
parents: 1650
diff changeset
   688
    children isArray ifTrue:[
443680316aac checkin from browser
ca
parents: 1650
diff changeset
   689
        children := children asOrderedCollection
443680316aac checkin from browser
ca
parents: 1650
diff changeset
   690
    ].
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   691
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   692
    size == 0 ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   693
        children := OrderedCollection new
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   694
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   695
    aList do:[:anItem| anItem parent:self ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   696
    children addAll:aList beforeIndex:anIndex.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   697
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   698
    (model := self model) isNil ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   699
        ^ aList
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   700
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   701
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
   702
    isExpanded ifFalse:[
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   703
        notify notNil ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   704
            notify changed
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   705
        ].
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
   706
        ^ aList
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   707
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   708
    (index := self listIndex) isNil ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   709
        ^ aList
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   710
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   711
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   712
    children from:1 to:(anIndex - 1) do:[:anItem|
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   713
        index := 1 + index + anItem numberOfVisibleChildren
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   714
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   715
    coll := OrderedCollection new.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   716
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   717
    aList do:[:anItem|
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   718
        coll add:anItem.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   719
        anItem addVisibleChildrenTo:coll.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   720
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   721
    model itemAddAll:coll beforeIndex:(index + 1).
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   722
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   723
    notify notNil ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   724
        notify changed
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   725
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   726
  ^ aList
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   727
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   728
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
   729
basicRemoveFromIndex:startIndex toIndex:stopIndex
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   730
    "remove the children from startIndex up to and including
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   731
     the child under stopIndex."
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   732
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   733
    |model notify
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   734
     index "{ Class:SmallInteger }"
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   735
     start "{ Class:SmallInteger }"
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   736
     stop  "{ Class:SmallInteger }"
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   737
     size  "{ Class:SmallInteger }"
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   738
    |
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   739
    size  := self children size.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   740
    stop  := stopIndex.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   741
    start := startIndex.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   742
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   743
    (stop <= size and:[start between:1 and:stop]) ifFalse:[
2484
92f9e42980ab correct use of ascentOn: for display
Claus Gittinger <cg@exept.de>
parents: 2476
diff changeset
   744
        ^ self subscriptBoundsError:index
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   745
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   746
    start == 1 ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   747
        notify := self
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   748
    ] ifFalse:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   749
        stop == size ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   750
            notify := self at:(start - 1)
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   751
        ] ifFalse:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   752
            notify := nil
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   753
        ]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   754
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   755
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   756
    (model := self model) notNil ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   757
        index := model identityIndexOf:(children at:start).
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   758
        size  := stop - start + 1.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   759
    ] ifFalse:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   760
        index := 0
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   761
    ].
1669
443680316aac checkin from browser
ca
parents: 1650
diff changeset
   762
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   763
    children from:start to:stop do:[:aChild|
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   764
        index ~~ 0 ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   765
            size := size + aChild numberOfVisibleChildren
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   766
        ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   767
        aChild parent:nil
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   768
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   769
    children removeFromIndex:start toIndex:stop.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   770
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   771
    index ~~ 0 ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   772
        model itemRemoveFromIndex:index toIndex:(index + size - 1)
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   773
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   774
    notify notNil ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   775
        notify changed
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   776
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   777
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   778
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   779
!HierarchicalItem methodsFor:'change & update'!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   780
1606
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
   781
changed:what with:anArgument
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   782
    "the item changed; raise change notification
2854
20b890ba0f6c allow subclasses to define the collapse-behavior
Claus Gittinger <cg@exept.de>
parents: 2853
diff changeset
   783
        #icon           icon is modified; height and width are unchanged
20b890ba0f6c allow subclasses to define the collapse-behavior
Claus Gittinger <cg@exept.de>
parents: 2853
diff changeset
   784
        #hierarchy      collapsed/expanded; height and width are unchanged
20b890ba0f6c allow subclasses to define the collapse-behavior
Claus Gittinger <cg@exept.de>
parents: 2853
diff changeset
   785
        #redraw         redraw but height and width are unchanged
20b890ba0f6c allow subclasses to define the collapse-behavior
Claus Gittinger <cg@exept.de>
parents: 2853
diff changeset
   786
        .......         all others: the height and width are reset
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   787
    "
1974
14a0093f86eb checkin from browser
ca
parents: 1966
diff changeset
   788
    |model why|
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   789
1974
14a0093f86eb checkin from browser
ca
parents: 1966
diff changeset
   790
    what ~~ #redraw ifTrue:[
14a0093f86eb checkin from browser
ca
parents: 1966
diff changeset
   791
        (what ~~ #hierarchy and:[what ~~ #icon]) ifTrue:[
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   792
            self class doResetExtentOnChange ifTrue:[
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   793
                width := height := nil
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   794
            ].
1974
14a0093f86eb checkin from browser
ca
parents: 1966
diff changeset
   795
        ].
14a0093f86eb checkin from browser
ca
parents: 1966
diff changeset
   796
        why := what
2230
8e2b53ecd71b *** empty log message ***
ca
parents: 2206
diff changeset
   797
    ] ifFalse:[
8e2b53ecd71b *** empty log message ***
ca
parents: 2206
diff changeset
   798
        why := #redraw
1606
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
   799
    ].
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
   800
    (model := self model) notNil ifTrue:[
1974
14a0093f86eb checkin from browser
ca
parents: 1966
diff changeset
   801
        model itemChanged:why with:anArgument from:self
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   802
    ].
1974
14a0093f86eb checkin from browser
ca
parents: 1966
diff changeset
   803
    super changed:why with:anArgument
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   804
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   805
2193
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   806
childrenOrderChanged
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   807
    "called if the order of the children changed by a user
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   808
     operation. Update the model and raise a change notification for
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   809
     each item which has changed its position
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   810
     triggered by the user operation !!"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   811
2193
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   812
    |model visStart list|
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   813
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   814
    self isExpanded   ifFalse:[ ^ self ].       "/ not expanded
2206
e62f6df90972 *** empty log message ***
ca
parents: 2201
diff changeset
   815
    children size > 1 ifFalse:[ ^ self ].
2193
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   816
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   817
    model := self model.
3166
0cc67b66ec06 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3090
diff changeset
   818
    model isNil ifTrue:[^ self].                       "/ no model
2193
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   819
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   820
    visStart := model identityIndexOf:self.
2260
fdf2e412a42c #sort: bug fix for root and root set to unvisible
james
parents: 2252
diff changeset
   821
    visStart == 0 ifTrue:[
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   822
        model root ~~ self ifTrue:[ ^ self ].
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
   823
     "/ I'am the root but switched of by setting #showRoot to false
2260
fdf2e412a42c #sort: bug fix for root and root set to unvisible
james
parents: 2252
diff changeset
   824
    ].
2193
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   825
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   826
    self criticalDo:[
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   827
        list := OrderedCollection new.
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   828
        self addVisibleChildrenTo:list.
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   829
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   830
        list do:[:el|
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   831
            visStart := visStart + 1.
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   832
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   833
            (model at:visStart ifAbsent:el) ~~ el ifTrue:[
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   834
                model at:visStart put:el
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   835
            ].
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   836
        ]
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   837
    ].
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   838
!
41d5d33c9f78 add method to synchronize the model with the changed children order
ca
parents: 2117
diff changeset
   839
1843
61595a6b2e37 handle font changed notification
martin
parents: 1831
diff changeset
   840
fontChanged
61595a6b2e37 handle font changed notification
martin
parents: 1831
diff changeset
   841
    "called if the font has changed
61595a6b2e37 handle font changed notification
martin
parents: 1831
diff changeset
   842
    "
61595a6b2e37 handle font changed notification
martin
parents: 1831
diff changeset
   843
    width := height := nil.
61595a6b2e37 handle font changed notification
martin
parents: 1831
diff changeset
   844
61595a6b2e37 handle font changed notification
martin
parents: 1831
diff changeset
   845
    children size ~~ 0 ifTrue:[
61595a6b2e37 handle font changed notification
martin
parents: 1831
diff changeset
   846
        children do:[:el| el fontChanged ].
61595a6b2e37 handle font changed notification
martin
parents: 1831
diff changeset
   847
    ].
61595a6b2e37 handle font changed notification
martin
parents: 1831
diff changeset
   848
!
61595a6b2e37 handle font changed notification
martin
parents: 1831
diff changeset
   849
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   850
hierarchyChanged
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   851
    "hierarchy changed; optimize redrawing
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   852
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   853
    self changed:#hierarchy with:nil
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   854
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   855
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   856
iconChanged
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   857
    "icon changed; optimize redrawing
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   858
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   859
    self changed:#icon with:nil
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   860
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   861
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   862
!HierarchicalItem methodsFor:'enumerating'!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   863
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   864
collect:aBlock
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   865
    "for each child in the receiver, evaluate the argument, aBlock
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   866
     and return a new collection with the results"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   867
2008
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
   868
    |coll|
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   869
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   870
    coll := OrderedCollection new.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   871
    self do:[:el| coll add:(aBlock value:el) ].
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
   872
    ^ coll
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   873
!
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   874
2465
a282c734a816 +contains:
Claus Gittinger <cg@exept.de>
parents: 2386
diff changeset
   875
contains:aBlock
a282c734a816 +contains:
Claus Gittinger <cg@exept.de>
parents: 2386
diff changeset
   876
    "return true if aBlock returns true for any of the receivers items"
a282c734a816 +contains:
Claus Gittinger <cg@exept.de>
parents: 2386
diff changeset
   877
a282c734a816 +contains:
Claus Gittinger <cg@exept.de>
parents: 2386
diff changeset
   878
    self do:[:el | (aBlock value:el) ifTrue:[^ true] ].
a282c734a816 +contains:
Claus Gittinger <cg@exept.de>
parents: 2386
diff changeset
   879
    ^ false
a282c734a816 +contains:
Claus Gittinger <cg@exept.de>
parents: 2386
diff changeset
   880
!
a282c734a816 +contains:
Claus Gittinger <cg@exept.de>
parents: 2386
diff changeset
   881
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   882
do:aOneArgBlock
2879
ef33508d449a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2854
diff changeset
   883
    "evaluate a block for each child"
ef33508d449a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2854
diff changeset
   884
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   885
    ^ self from:1 do:aOneArgBlock
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   886
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   887
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   888
from:startIndex do:aOneArgBlock
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   889
    "evaluate a block on each child starting with the
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   890
     child at startIndex to the end.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   891
    "
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
   892
    ^ self from:startIndex to:nil do:aOneArgBlock
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   893
!
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   894
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   895
from:startIndex reverseDo:aOneArgBlock
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   896
    "evaluate a block on each child starting at end to the startIndex
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   897
    "
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
   898
    ^ self from:startIndex to:nil reverseDo:aOneArgBlock
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   899
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   900
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   901
from:startIndex to:endIndex do:aOneArgBlock
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   902
    "evaluate a block on each child starting with the
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   903
     child at startIndex to the endIndex.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   904
    "
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   905
    |res|
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   906
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   907
    self size < startIndex ifTrue:[^ nil].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   908
    res := nil.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   909
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   910
    self criticalDo:[
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
   911
        res := self nonCriticalFrom:startIndex to:endIndex do:aOneArgBlock
2008
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
   912
    ].
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   913
    ^ res
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   914
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   915
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   916
from:startIndex to:endIndex reverseDo:aOneArgBlock
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   917
    "evaluate a block on each child starting with the
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   918
     child at endIndex to the startIndex.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   919
    "
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   920
    |res|
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   921
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   922
    self size < startIndex ifTrue:[^ nil].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   923
    res := nil.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   924
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   925
    self criticalDo:[
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
   926
        res := self nonCriticalFrom:startIndex to:endIndex reverseDo:aOneArgBlock
2008
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
   927
    ].
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   928
    ^ res
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   929
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   930
1966
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
   931
keysAndValuesDo:aTwoArgBlock
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
   932
    "evaluate the argument, aBlock for every child,
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   933
     passing both index and element as arguments.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   934
    "
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   935
    |key res|
1966
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
   936
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   937
    key := 1.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   938
    res := nil.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   939
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   940
    self do:[:el|
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   941
        res := el value:key value:el.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   942
        key := key + 1.
1966
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
   943
    ].
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   944
    ^ res
1966
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
   945
!
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
   946
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
   947
keysAndValuesReverseDo:aTwoArgBlock
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
   948
    "evaluate the argument, aBlock in reverse order for every
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   949
     child, passing both index and element as arguments.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   950
    "
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   951
    |res|
1966
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
   952
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   953
    self size == 0 ifTrue:[^ nil].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   954
    res := nil.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   955
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   956
    self criticalDo:[
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
   957
        res := self nonCriticalKeysAndValuesReverseDo:aTwoArgBlock
1966
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
   958
    ].
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
   959
    ^ res
1966
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
   960
!
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
   961
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   962
recursiveCollect:aBlock
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   963
    "for each child in the receiver, evaluate the argument, aBlock
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   964
     and return a new collection with the results
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   965
    "
2008
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
   966
    |coll|
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   967
2008
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
   968
    coll := OrderedCollection new.
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
   969
    self recursiveDo:[:el| coll add:(aBlock value:el) ].
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
   970
  ^ coll
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   971
!
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   972
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   973
recursiveDo:aOneArgBlock
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   974
    "evaluate a block on each item and all the sub-items
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   975
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   976
    self do:[:aChild|
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   977
        aOneArgBlock value:aChild.
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
   978
        aChild nonCriticalRecursiveDo:aOneArgBlock
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   979
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   980
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   981
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   982
recursiveReverseDo:aOneArgBlock
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   983
    "evaluate a block on each item and all the sub-items;
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   984
     proccesing children in reverse direction
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   985
    "
2008
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
   986
    self reverseDo:[:aChild|
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
   987
        aChild nonCriticalRecursiveReverseDo:aOneArgBlock.
2008
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
   988
        aOneArgBlock value:aChild.
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   989
    ].
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   990
!
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   991
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   992
recursiveSelect:aBlock
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   993
    "return a new collection with all children and subChildren from the receiver, for which
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   994
     the argument aBlock evaluates to true.
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   995
    "
2008
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
   996
    |coll|
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
   997
2008
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
   998
    coll := OrderedCollection new.
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
   999
    self recursiveDo:[:el| (aBlock value:el) ifTrue:[coll add:el] ].
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
  1000
  ^ coll
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1001
!
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1002
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1003
reverseDo:aOneArgBlock
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1004
    "evaluate a block on each child in reverse direction
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1005
    "
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1006
    ^ self from:1 reverseDo:aOneArgBlock
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1007
!
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1008
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1009
select:aBlock
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1010
    "return a new collection with all items from the receiver, for which
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1011
     the argument aBlock evaluates to true.
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1012
    "
2008
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
  1013
    |coll|
1831
8efa00e1247a sort stuff; height fix when label changes
Claus Gittinger <cg@exept.de>
parents: 1818
diff changeset
  1014
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1015
    coll := OrderedCollection new.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1016
    self do:[:el| (aBlock value:el) ifTrue:[coll add:el] ].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1017
  ^ coll
1876
d9ec853e7843 add more messages
ca
parents: 1843
diff changeset
  1018
!
d9ec853e7843 add more messages
ca
parents: 1843
diff changeset
  1019
d9ec853e7843 add more messages
ca
parents: 1843
diff changeset
  1020
withAllDo:aOneArgBlock
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1021
    "evaluate the block on each item and subitem including self
1876
d9ec853e7843 add more messages
ca
parents: 1843
diff changeset
  1022
    "
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1023
    aOneArgBlock value:self.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1024
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1025
    self do:[:el|
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1026
        aOneArgBlock value:el.
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1027
        el nonCriticalRecursiveDo:aOneArgBlock.
1883
7da039ab6677 added: access-methode for rootItem
tm
parents: 1876
diff changeset
  1028
    ].
7da039ab6677 added: access-methode for rootItem
tm
parents: 1876
diff changeset
  1029
! !
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1030
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1031
!HierarchicalItem methodsFor:'enumerating parents'!
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1032
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1033
parentsDetect:aBlock
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1034
    "find the first parent, for which evaluation of the block returns
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1035
     true; if none does so, report an error
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1036
    "
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1037
    ^ self parentsDetect:aBlock ifNone:[self errorNotFound]
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1038
!
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1039
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1040
parentsDetect:aBlock ifNone:anExceptionBlock
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1041
    "find the first parent, for which evaluation of the block returns
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1042
     true; if none does so, return the evaluation of anExceptionBlock
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1043
    "
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1044
    |prnt|
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1045
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1046
    prnt := self.
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1047
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1048
    self criticalDo:[
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1049
        [(prnt := prnt parent) notNil and:[prnt isHierarchicalItem]] whileTrue:[
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1050
            (aBlock value:prnt) ifTrue:[^ prnt]
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1051
        ]
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1052
    ].
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1053
    ^ anExceptionBlock value
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1054
!
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1055
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1056
parentsDo:aBlock
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1057
    "evaluate a block on each parent
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1058
    "
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1059
    |prnt|
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1060
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1061
    prnt := self.
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1062
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1063
    self criticalDo:[
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1064
        [(prnt := prnt parent) notNil and:[prnt isHierarchicalItem]] whileTrue:[
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1065
            aBlock value:prnt
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1066
        ]
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1067
    ].
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1068
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1069
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1070
!HierarchicalItem methodsFor:'initialization'!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1071
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1072
initialize
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1073
    isExpanded := false
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1074
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1075
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1076
!HierarchicalItem methodsFor:'private'!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1077
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1078
addVisibleChildrenTo:aList
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1079
    "add all visible children and sub-children to the list"
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1080
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1081
    isExpanded ifFalse:[^ self].
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1082
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1083
    self nonCriticalFrom:1 to:nil do:[:el|
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1084
        aList add:el.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1085
        el addVisibleChildrenTo:aList.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1086
    ].
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1087
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1088
2854
20b890ba0f6c allow subclasses to define the collapse-behavior
Claus Gittinger <cg@exept.de>
parents: 2853
diff changeset
  1089
clearExpandedWhenLastChildWasRemoved
20b890ba0f6c allow subclasses to define the collapse-behavior
Claus Gittinger <cg@exept.de>
parents: 2853
diff changeset
  1090
    ^ true
20b890ba0f6c allow subclasses to define the collapse-behavior
Claus Gittinger <cg@exept.de>
parents: 2853
diff changeset
  1091
!
20b890ba0f6c allow subclasses to define the collapse-behavior
Claus Gittinger <cg@exept.de>
parents: 2853
diff changeset
  1092
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
  1093
criticalDo:aBlock
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
  1094
    |model|
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
  1095
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
  1096
    (model := self model) notNil ifTrue:[
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
  1097
        model recursionLock critical:aBlock
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
  1098
    ] ifFalse:[
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
  1099
        aBlock value
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
  1100
    ]
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
  1101
!
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
  1102
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1103
listIndex
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1104
    "returns the visible index or nil; for a none visible root
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1105
     0 is returned
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1106
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1107
    |index model|
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1108
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1109
    (model := self model) notNil ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1110
        index := model identityIndexOf:self.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1111
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1112
        (index ~~ 0 or:[parent == model]) ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1113
            ^ index
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1114
        ]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1115
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1116
    ^ nil
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1117
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1118
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1119
numberOfVisibleChildren
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1120
    "returns number of all visible children including subchildren"
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1121
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1122
    |size|
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1123
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1124
    isExpanded ifFalse:[^ 0].
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1125
    size := 0.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1126
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1127
    self nonCriticalFrom:1 to:nil do:[:el|
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1128
        size := 1 + size + el numberOfVisibleChildren
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1129
    ].
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1130
    ^ size
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1131
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1132
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1133
parentOrModel
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1134
    "returns the parent without checking for item or model
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1135
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1136
    ^ parent
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1137
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1138
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1139
setExpanded:aBoolean
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1140
    "set expanded flag without any computation or notification"
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1141
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1142
    isExpanded := aBoolean
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1143
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1144
2493
8b70a26f1694 method category rename
Claus Gittinger <cg@exept.de>
parents: 2486
diff changeset
  1145
!HierarchicalItem methodsFor:'private-displaying'!
1540
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1146
1606
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1147
displayLabel:aLabel h:lH on:aGC x:x y:y h:h 
1540
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1148
    "display the label at x@y
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1149
    "
2484
92f9e42980ab correct use of ascentOn: for display
Claus Gittinger <cg@exept.de>
parents: 2476
diff changeset
  1150
    |y0|
1540
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1151
1606
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1152
    lH ~~ 0 ifTrue:[
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1153
        y0 := y - (lH + 1 - h // 2).
1540
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1154
2484
92f9e42980ab correct use of ascentOn: for display
Claus Gittinger <cg@exept.de>
parents: 2476
diff changeset
  1155
        y0 := y0 + (aLabel ascentOn:aGC).
92f9e42980ab correct use of ascentOn: for display
Claus Gittinger <cg@exept.de>
parents: 2476
diff changeset
  1156
        (aLabel isString not
92f9e42980ab correct use of ascentOn: for display
Claus Gittinger <cg@exept.de>
parents: 2476
diff changeset
  1157
        or:[(aLabel includes:(Character cr)) not]) ifTrue:[
1606
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1158
            ^ aLabel displayOn:aGC x:x y:y0
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1159
        ].
1540
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1160
1606
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1161
        aLabel asCollectionOfLines do:[:el|
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1162
            el displayOn:aGC x:x y:y0.
2484
92f9e42980ab correct use of ascentOn: for display
Claus Gittinger <cg@exept.de>
parents: 2476
diff changeset
  1163
            y0 := y0 + (el heightOn:aGC)
1606
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1164
        ]
1540
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1165
    ].
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1166
!
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1167
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1168
heightOf:aLabel on:aGC
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1169
    "returns the height of the label or 0
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1170
    "
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1171
    |h|
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1172
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1173
    aLabel isSequenceable ifFalse:[
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1174
        ^ aLabel notNil ifTrue:[aLabel heightOn:aGC] ifFalse:[0]
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1175
    ].
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1176
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1177
    aLabel isString ifFalse:[
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1178
        h := 0.
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1179
        aLabel do:[:el|h := h max:(self heightOf:el on:aGC)].
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1180
      ^ h
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1181
    ].
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1182
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1183
    h := 1 + (aLabel occurrencesOf:(Character cr)).
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1184
    ^ h * (aGC font height)
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1185
!
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1186
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1187
widthOf:aLabel on:aGC
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1188
    "returns the height of the label or 0
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1189
    "
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1190
    |w|
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1191
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1192
    aLabel isSequenceable ifFalse:[
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1193
        ^ aLabel notNil ifTrue:[aLabel widthOn:aGC] ifFalse:[0]
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1194
    ].
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1195
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1196
    aLabel isString ifFalse:[
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1197
        w := -5.
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1198
        aLabel do:[:el|w := w + 5 + (self widthOf:el on:aGC)].
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1199
      ^ w
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1200
    ].
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1201
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1202
    (aLabel indexOf:(Character cr)) == 0 ifTrue:[
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1203
        ^ aLabel widthOn:aGC
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1204
    ].
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1205
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1206
    w := 0.
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1207
    aLabel asCollectionOfLines do:[:el|w := w max:(el widthOn:aGC)].
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1208
  ^ w
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1209
! !
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1210
2493
8b70a26f1694 method category rename
Claus Gittinger <cg@exept.de>
parents: 2486
diff changeset
  1211
!HierarchicalItem methodsFor:'private-enumerating'!
2008
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
  1212
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1213
nonCriticalDo:aOneArgBlock
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1214
    "evaluate a block noncritical on each child.
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1215
    "
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1216
    ^ self nonCriticalFrom:1 to:nil do:aOneArgBlock
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1217
!
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1218
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1219
nonCriticalFrom:startIndex to:endIndex do:aOneArgBlock
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1220
    "evaluate a block noncritical on each child starting with the
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1221
     child at startIndex to the endIndex (if nil to end of list).
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1222
    "
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1223
    |list size resp|
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1224
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1225
    list := self children.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1226
    size := list size.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1227
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1228
    startIndex > size ifTrue:[^ nil].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1229
    resp := nil.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1230
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1231
    endIndex notNil ifTrue:[
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1232
        size := size min:endIndex
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1233
    ].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1234
    startIndex to:size do:[:i| |item|
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1235
        item := list at:i ifAbsent:nil.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1236
        item isNil ifTrue:[^ resp].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1237
        resp := aOneArgBlock value:item.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1238
    ].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1239
    ^ resp
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1240
!
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1241
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1242
nonCriticalFrom:startIndex to:endIndex reverseDo:aOneArgBlock
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1243
    "evaluate a block non critical on each child starting with the
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1244
     child at endIndex (if nil to end of list) to startIndex.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1245
    "
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1246
    |list size resp|
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1247
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1248
    list := self children.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1249
    size := list size.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1250
    resp := nil.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1251
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1252
    endIndex notNil ifTrue:[
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1253
        size := size min:endIndex
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1254
    ].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1255
    size to:startIndex by:-1 do:[:i| |item|
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1256
        item := list at:i ifAbsent:nil.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1257
        item isNil ifTrue:[^ resp].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1258
        resp := aOneArgBlock value:item.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1259
    ].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1260
    ^ resp
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1261
!
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1262
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1263
nonCriticalKeysAndValuesReverseDo:aOneArgBlock
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1264
    "evaluate the argument, aBlock in reverse order for every
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1265
     child, passing both index and element as arguments.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1266
    "
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1267
    |list size resp|
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1268
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1269
    list := self children.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1270
    size := list size.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1271
    resp := nil.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1272
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1273
    size to:1 by:-1 do:[:i| |item|
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1274
        item := list at:i ifAbsent:nil.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1275
        item isNil ifTrue:[^ resp].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1276
        resp := aOneArgBlock value:i value:item.
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1277
    ].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1278
    ^ resp
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1279
!
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1280
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1281
nonCriticalRecursiveDo:anOneArgBlock
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1282
    "evaluate the block non critical on each item and all the sub-items
2008
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
  1283
    "
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1284
    self nonCriticalFrom:1 to:nil do:[:aChild|
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1285
        anOneArgBlock value:aChild.
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1286
        aChild nonCriticalRecursiveDo:anOneArgBlock
2008
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
  1287
    ].
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
  1288
!
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
  1289
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1290
nonCriticalRecursiveReverseDo:anOneArgBlock
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1291
    "evaluate the block non critical on each item and all the sub-items;
2008
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
  1292
     proccesing children in reverse direction
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
  1293
    "
2117
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1294
    self nonCriticalFrom:1 to:nil reverseDo:[:aChild|
61d68e3e5bdc methods rename (cg)
tm
parents: 2081
diff changeset
  1295
        aChild nonCriticalRecursiveReverseDo:anOneArgBlock.
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1296
        anOneArgBlock value:aChild.
2008
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
  1297
    ].
2294
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1298
!
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1299
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1300
nonCriticalRecursiveSort:aSortBlock
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1301
    "evaluate a block noncritical on each child.
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1302
    "
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1303
    |unsorted sorted|
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1304
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1305
    unsorted := children.
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1306
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1307
    unsorted size ~~ 0 ifTrue:[
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1308
        sorted := unsorted sort:aSortBlock.
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1309
        sorted do:[:el| el nonCriticalRecursiveSort:aSortBlock ].
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1310
        children := sorted.
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1311
    ].
2008
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
  1312
! !
916175defb9e add none critical blocks for recursive operations (optimize)
ca
parents: 1974
diff changeset
  1313
2493
8b70a26f1694 method category rename
Claus Gittinger <cg@exept.de>
parents: 2486
diff changeset
  1314
!HierarchicalItem methodsFor:'private-hierarchy'!
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1315
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1316
recursiveSetCollapsed
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1317
    "collapse all children and sub-children without notifications"
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1318
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1319
    isExpanded := false.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1320
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1321
    "/ do not call #size: children will be autoloaded !!!!
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1322
    children size ~~ 0 ifTrue:[
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1323
        self nonCriticalFrom:1 to:nil do:[:el| el canRecursiveCollapse ifTrue:[el recursiveSetCollapsed]].
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1324
    ]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1325
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1326
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1327
recursiveSetExpandedAndAddToList:aList
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1328
    "expand all children and sub-children without notifications;
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1329
     add children to list"
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1330
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1331
    isExpanded := true.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1332
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1333
    self do:[:eachChild|
2601
27b91c77ce7b bug fix during recursive expand of children
ca
parents: 2549
diff changeset
  1334
        aList add:eachChild.
27b91c77ce7b bug fix during recursive expand of children
ca
parents: 2549
diff changeset
  1335
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1336
        eachChild canRecursiveExpand ifTrue:[
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1337
            eachChild recursiveSetExpandedAndAddToList:aList.
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1338
        ].
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1339
    ].
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1340
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1341
2851
fa192ee81bb5 code cleanup
Claus Gittinger <cg@exept.de>
parents: 2847
diff changeset
  1342
!HierarchicalItem methodsFor:'protocol-accessing'!
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1343
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1344
children
2851
fa192ee81bb5 code cleanup
Claus Gittinger <cg@exept.de>
parents: 2847
diff changeset
  1345
    "returns a list of children
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
  1346
     *** to optimize: redefine by subClass"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
  1347
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1348
    |model|
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1349
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1350
    children isNil ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1351
        (model := self model) notNil ifTrue:[
1486
5b520551b2ef checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1431
diff changeset
  1352
            children := model childrenFor:self
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1353
        ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1354
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1355
    ^ children
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1356
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1357
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1358
icon
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1359
    "returns the icon or nil;
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1360
     *** to optimize:redefine by subClass
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1361
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1362
    |model|
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1363
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1364
    (model := self model) notNil ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1365
        ^ model iconFor:self
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1366
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1367
    ^ nil
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1368
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1369
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1370
label
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1371
    "returns the label displayed on aGC;
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1372
     *** to optimize:redefine by subClass
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1373
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1374
    |model|
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1375
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1376
    (model := self model) notNil ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1377
        ^ model labelFor:self
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1378
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1379
    ^ nil
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1380
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1381
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1382
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1383
middleButtonMenu
2602
8aec4c5fbf5b comment
Claus Gittinger <cg@exept.de>
parents: 2601
diff changeset
  1384
    "returns the items middleButtonMenu or nil if no menu is defined.
8aec4c5fbf5b comment
Claus Gittinger <cg@exept.de>
parents: 2601
diff changeset
  1385
     If nil is returned, the view is asked for a menu.
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1386
    "
3337
2c407545d5ec *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3333
diff changeset
  1387
    <resource: #programMenu>
2c407545d5ec *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3333
diff changeset
  1388
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1389
    |model|
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1391
    (model := self model) notNil ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1392
        ^ model middleButtonMenuFor:self
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1393
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1394
    ^ nil
1831
8efa00e1247a sort stuff; height fix when label changes
Claus Gittinger <cg@exept.de>
parents: 1818
diff changeset
  1395
!
8efa00e1247a sort stuff; height fix when label changes
Claus Gittinger <cg@exept.de>
parents: 1818
diff changeset
  1396
8efa00e1247a sort stuff; height fix when label changes
Claus Gittinger <cg@exept.de>
parents: 1818
diff changeset
  1397
recursiveSortChildren:aSortBlock
8efa00e1247a sort stuff; height fix when label changes
Claus Gittinger <cg@exept.de>
parents: 1818
diff changeset
  1398
    |children|
8efa00e1247a sort stuff; height fix when label changes
Claus Gittinger <cg@exept.de>
parents: 1818
diff changeset
  1399
2832
e1f6a7c48552 code cleanup
Claus Gittinger <cg@exept.de>
parents: 2781
diff changeset
  1400
    (children := self children) notEmptyOrNil ifTrue:[
1831
8efa00e1247a sort stuff; height fix when label changes
Claus Gittinger <cg@exept.de>
parents: 1818
diff changeset
  1401
        self criticalDo:[
8efa00e1247a sort stuff; height fix when label changes
Claus Gittinger <cg@exept.de>
parents: 1818
diff changeset
  1402
            children sort:aSortBlock.
8efa00e1247a sort stuff; height fix when label changes
Claus Gittinger <cg@exept.de>
parents: 1818
diff changeset
  1403
            children do:[:aChild| aChild recursiveSortChildren:aSortBlock ]
8efa00e1247a sort stuff; height fix when label changes
Claus Gittinger <cg@exept.de>
parents: 1818
diff changeset
  1404
        ]
8efa00e1247a sort stuff; height fix when label changes
Claus Gittinger <cg@exept.de>
parents: 1818
diff changeset
  1405
    ].
8efa00e1247a sort stuff; height fix when label changes
Claus Gittinger <cg@exept.de>
parents: 1818
diff changeset
  1406
!
8efa00e1247a sort stuff; height fix when label changes
Claus Gittinger <cg@exept.de>
parents: 1818
diff changeset
  1407
8efa00e1247a sort stuff; height fix when label changes
Claus Gittinger <cg@exept.de>
parents: 1818
diff changeset
  1408
sortChildren:aSortBlock
2708
f3efc17bcbce Mark obsolete methods
Stefan Vogel <sv@exept.de>
parents: 2602
diff changeset
  1409
    "sort the children inplace using the 2-arg block sortBlock for comparison"
f3efc17bcbce Mark obsolete methods
Stefan Vogel <sv@exept.de>
parents: 2602
diff changeset
  1410
f3efc17bcbce Mark obsolete methods
Stefan Vogel <sv@exept.de>
parents: 2602
diff changeset
  1411
    <resource: #obsolete>
f3efc17bcbce Mark obsolete methods
Stefan Vogel <sv@exept.de>
parents: 2602
diff changeset
  1412
    self obsoleteMethodWarning:'use #sort:'.
2252
ebcefc9af592 add #sort:
ca
parents: 2230
diff changeset
  1413
    self sort:aSortBlock.
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1414
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1415
2851
fa192ee81bb5 code cleanup
Claus Gittinger <cg@exept.de>
parents: 2847
diff changeset
  1416
!HierarchicalItem methodsFor:'protocol-displaying'!
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1417
1532
56e0fafc4349 change display protocol for item
Claus Gittinger <cg@exept.de>
parents: 1489
diff changeset
  1418
displayOn:aGC x:x y:y h:h
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1419
    "draw the receiver in the graphicsContext, aGC.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1420
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1421
    |label
1398
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1422
     x0 "{ Class:SmallInteger }"
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1423
    |
1540
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1424
    (label := self label) isNil ifTrue:[^ self].
1398
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1425
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1426
    (label isSequenceable and:[label isString not]) ifFalse:[
1606
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1427
        ^ self displayLabel:label h:(self heightOn:aGC) on:aGC x:x y:y h:h
1398
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1428
    ].
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1429
1540
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1430
    x0 := x.
1398
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1431
    label do:[:el|
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1432
        el notNil ifTrue:[
1606
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1433
            self displayLabel:el h:(self heightOf:el on:aGC) on:aGC x:x0 y:y h:h.
1398
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1434
            x0 := x0 + 5 + (el widthOn:aGC).
1540
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1435
        ].
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1436
    ]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1437
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1438
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1439
heightOn:aGC
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1440
    "return the width of the receiver, if it is to be displayed on aGC
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1441
    "
1606
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1442
    height isNil ifTrue:[
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1443
        height := self heightOf:(self label) on:aGC
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1444
    ].
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1445
    ^ height
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1446
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1447
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1448
widthOn:aGC
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1449
    "return the width of the receiver, if it is to be displayed on aGC
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1450
    "
1606
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1451
    width isNil ifTrue:[
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1452
        width := self widthOf:(self label) on:aGC
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1453
    ].
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1454
    ^ width
b46b9ec4b5d8 cache height and width
ca
parents: 1602
diff changeset
  1455
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1456
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1457
2851
fa192ee81bb5 code cleanup
Claus Gittinger <cg@exept.de>
parents: 2847
diff changeset
  1458
!HierarchicalItem methodsFor:'protocol-event processing'!
2313
6e91bdaac5bc delegate buttonPress event to the item
ca
parents: 2305
diff changeset
  1459
6e91bdaac5bc delegate buttonPress event to the item
ca
parents: 2305
diff changeset
  1460
processButtonPress:button x:x y:y
6e91bdaac5bc delegate buttonPress event to the item
ca
parents: 2305
diff changeset
  1461
    "a mouse button was pressed in my label.
2519
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1462
     Return true, if the event is eaten (ignored by the gc).
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1463
     On default false is returned (should be handled by the gc).
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1464
    "
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1465
    ^ false
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1466
!
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1467
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1468
processButtonPress:button x:x y:y on:aGC
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1469
    "a mouse button was pressed in my label.
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1470
     Return true, if the event is eaten (ignored by the gc).
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1471
     On default false is returned (should be handled by the gc).
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1472
    "
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1473
    ^ self processButtonPress:button x:x y:y
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1474
!
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1475
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1476
processButtonPressOnIcon:button on:aGC
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1477
    "a mouse button was pressed in my icon.
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1478
     Return true, if the event is eaten (ignored by the gc).
f043b9204ce7 process button events from hierarchical tree widget
james
parents: 2493
diff changeset
  1479
     On default false is returned (should be handled by the gc).
2313
6e91bdaac5bc delegate buttonPress event to the item
ca
parents: 2305
diff changeset
  1480
    "
6e91bdaac5bc delegate buttonPress event to the item
ca
parents: 2305
diff changeset
  1481
    ^ false
6e91bdaac5bc delegate buttonPress event to the item
ca
parents: 2305
diff changeset
  1482
! !
6e91bdaac5bc delegate buttonPress event to the item
ca
parents: 2305
diff changeset
  1483
2851
fa192ee81bb5 code cleanup
Claus Gittinger <cg@exept.de>
parents: 2847
diff changeset
  1484
!HierarchicalItem methodsFor:'protocol-monitoring'!
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1485
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1486
monitoringCycle
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1487
    "called all 'n' seconds by the model, if the monitoring
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1488
     cycle is enabled. The item can perform some checks, ..
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1489
     **** can be redefined by subclass to perform some actions
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1490
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1491
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1492
2851
fa192ee81bb5 code cleanup
Claus Gittinger <cg@exept.de>
parents: 2847
diff changeset
  1493
!HierarchicalItem methodsFor:'protocol-queries'!
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1494
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1495
canCollapse
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1496
    "called before collapsing the item; can be redefined
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1497
     by subclass to omit the collapse operation"
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1498
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1499
    ^ isExpanded
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1500
!
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1501
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1502
canExpand
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1503
    "called before expanding the item; can be redefined
2549
fb6d594099b2 checkin from browser
Stefan Vogel <sv@exept.de>
parents: 2547
diff changeset
  1504
     by subclass to omit the expand operation"
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1505
2549
fb6d594099b2 checkin from browser
Stefan Vogel <sv@exept.de>
parents: 2547
diff changeset
  1506
    ^ self hasChildren
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1507
!
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1508
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1509
canRecursiveCollapse
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1510
    "called before collapsing the item; can be redefined
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1511
     by subclass to omit the collapse operation "
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1512
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1513
    ^ self canCollapse
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1514
!
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1515
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1516
canRecursiveExpand
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1517
    "called before expanding the item; can be redefined
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1518
     by subclass to omit the collapse operation"
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1519
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1520
    ^ self canExpand
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1521
!
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1522
1571
a230fb988d3e support configuration of length of vertical line
ca
parents: 1540
diff changeset
  1523
drawHorizontalLineUpToText
a230fb988d3e support configuration of length of vertical line
ca
parents: 1540
diff changeset
  1524
    "draw the horizizontal line for the selected item up to the text
a230fb988d3e support configuration of length of vertical line
ca
parents: 1540
diff changeset
  1525
     or on default to the start of the the vertical line; only used by
a230fb988d3e support configuration of length of vertical line
ca
parents: 1540
diff changeset
  1526
     the hierarchical view
a230fb988d3e support configuration of length of vertical line
ca
parents: 1540
diff changeset
  1527
    "
a230fb988d3e support configuration of length of vertical line
ca
parents: 1540
diff changeset
  1528
    ^ false
a230fb988d3e support configuration of length of vertical line
ca
parents: 1540
diff changeset
  1529
!
a230fb988d3e support configuration of length of vertical line
ca
parents: 1540
diff changeset
  1530
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1531
hasChildren
2851
fa192ee81bb5 code cleanup
Claus Gittinger <cg@exept.de>
parents: 2847
diff changeset
  1532
    "checks whether the item has children; 
fa192ee81bb5 code cleanup
Claus Gittinger <cg@exept.de>
parents: 2847
diff changeset
  1533
     the list needs not to be loaded yet( example. FileDirectory ).
fa192ee81bb5 code cleanup
Claus Gittinger <cg@exept.de>
parents: 2847
diff changeset
  1534
     *** to optimize: redefine in subClass
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1535
    "
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1536
    ^ self children size ~~ 0
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1537
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1538
2201
aa74fa6137a5 make indicator dependent on hasIndicator and not hasChildren
ca
parents: 2193
diff changeset
  1539
hasIndicator
aa74fa6137a5 make indicator dependent on hasIndicator and not hasChildren
ca
parents: 2193
diff changeset
  1540
    "on default the indicator is drawn if the item
aa74fa6137a5 make indicator dependent on hasIndicator and not hasChildren
ca
parents: 2193
diff changeset
  1541
     has children
aa74fa6137a5 make indicator dependent on hasIndicator and not hasChildren
ca
parents: 2193
diff changeset
  1542
    "
aa74fa6137a5 make indicator dependent on hasIndicator and not hasChildren
ca
parents: 2193
diff changeset
  1543
    ^ self hasChildren
aa74fa6137a5 make indicator dependent on hasIndicator and not hasChildren
ca
parents: 2193
diff changeset
  1544
!
aa74fa6137a5 make indicator dependent on hasIndicator and not hasChildren
ca
parents: 2193
diff changeset
  1545
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1546
isSelectable
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1547
    "returns true if the item is selectable otherwise false
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1548
    "
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1549
    ^ true
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1550
!
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1551
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1552
string
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1553
    "access the printable string used for steping through a list
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1554
     searching for an entry starting with a character.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1555
     *** to optimize:redefine by subClass
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1556
    "
1398
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1557
    |label|
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1558
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1559
    (label := self label) notNil ifTrue:[
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1560
        label isString      ifTrue:[ ^ label string ].
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1561
        label isImageOrForm ifTrue:[ ^ nil ].
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1562
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1563
        label isSequenceable ifFalse:[
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1564
            ^ label perform:#string ifNotUnderstood:nil
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1565
        ].
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1566
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1567
        label do:[:el||s|
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1568
            (el notNil and:[el isImageOrForm not]) ifTrue:[
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1569
                s := el perform:#string ifNotUnderstood:nil.
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1570
                s notNil ifTrue:[^ s].
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1571
            ]
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1572
        ]
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1573
    ].
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1574
    ^ nil
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1575
        
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1576
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1577
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1578
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1579
!HierarchicalItem methodsFor:'queries'!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1580
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1581
isChildOf:anItem
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1582
    "returns true if the item is a child of anItem
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1583
    "
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1584
    |item|
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1585
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1586
    item := self.
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1587
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1588
    [anItem ~~ item] whileTrue:[
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1589
        ((item := item parent) notNil and:[item isHierarchicalItem]) ifFalse:[
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1590
            ^ false
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1591
        ]
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1592
    ].
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1593
    ^ true
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1594
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1595
!
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1596
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1597
isCollapsed
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1598
    "returns true if the item is collapsed"
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1599
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1600
    ^ isExpanded not
2305
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1601
!
a31516be9bd1 *** empty log message ***
ca
parents: 2294
diff changeset
  1602
3173
c7171ad3e1d7 *** empty log message ***
fm
parents: 3166
diff changeset
  1603
isDirectoryItem
c7171ad3e1d7 *** empty log message ***
fm
parents: 3166
diff changeset
  1604
    ^ false
c7171ad3e1d7 *** empty log message ***
fm
parents: 3166
diff changeset
  1605
c7171ad3e1d7 *** empty log message ***
fm
parents: 3166
diff changeset
  1606
    "Created: / 23-06-2006 / 12:47:05 / fm"
c7171ad3e1d7 *** empty log message ***
fm
parents: 3166
diff changeset
  1607
    "Modified: / 23-02-2007 / 12:04:23 / User"
c7171ad3e1d7 *** empty log message ***
fm
parents: 3166
diff changeset
  1608
!
c7171ad3e1d7 *** empty log message ***
fm
parents: 3166
diff changeset
  1609
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1610
isExpanded
2547
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1611
    "returns true if the item is expanded"
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1612
1b75a2c2be7c Hooks for recursive expand
Stefan Vogel <sv@exept.de>
parents: 2519
diff changeset
  1613
    ^ isExpanded 
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1614
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1615
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1616
isHierarchicalItem
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1617
    "used to decide if the parent is a hierarchical item
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1618
     or the model
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1619
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1620
    ^ true
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1621
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1622
2033
abe5de512c81 checkin from browser
martin
parents: 2029
diff changeset
  1623
isRealChildOf:anItem
abe5de512c81 checkin from browser
martin
parents: 2029
diff changeset
  1624
    "returns true if the item is a child of anItem
abe5de512c81 checkin from browser
martin
parents: 2029
diff changeset
  1625
    "
abe5de512c81 checkin from browser
martin
parents: 2029
diff changeset
  1626
    |item|
abe5de512c81 checkin from browser
martin
parents: 2029
diff changeset
  1627
    item := self parent.
abe5de512c81 checkin from browser
martin
parents: 2029
diff changeset
  1628
abe5de512c81 checkin from browser
martin
parents: 2029
diff changeset
  1629
    [item notNil] whileTrue:[
abe5de512c81 checkin from browser
martin
parents: 2029
diff changeset
  1630
        item == anItem ifTrue:[^ true].
abe5de512c81 checkin from browser
martin
parents: 2029
diff changeset
  1631
        item := item parent.
abe5de512c81 checkin from browser
martin
parents: 2029
diff changeset
  1632
    ].
abe5de512c81 checkin from browser
martin
parents: 2029
diff changeset
  1633
    ^ false
abe5de512c81 checkin from browser
martin
parents: 2029
diff changeset
  1634
!
abe5de512c81 checkin from browser
martin
parents: 2029
diff changeset
  1635
1876
d9ec853e7843 add more messages
ca
parents: 1843
diff changeset
  1636
isRootItem
d9ec853e7843 add more messages
ca
parents: 1843
diff changeset
  1637
    "returns true if the item is the root item
d9ec853e7843 add more messages
ca
parents: 1843
diff changeset
  1638
    "
1883
7da039ab6677 added: access-methode for rootItem
tm
parents: 1876
diff changeset
  1639
    ^ parent isHierarchicalItem not
7da039ab6677 added: access-methode for rootItem
tm
parents: 1876
diff changeset
  1640
!
1876
d9ec853e7843 add more messages
ca
parents: 1843
diff changeset
  1641
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1642
size
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1643
    "return the number of children
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1644
    "
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1645
    ^ self children size
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1646
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1647
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1648
!HierarchicalItem methodsFor:'searching'!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1649
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1650
detect:aOneArgBlock
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1651
    "find the first child, for which evaluation of the block returns
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
  1652
     true; if none does so, report an error"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
  1653
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1654
    ^ self detect:aOneArgBlock ifNone:[self errorNotFound]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1655
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1656
3071
55a9742766ed *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2962
diff changeset
  1657
detect:aOneArgBlock ifNone:exceptionBlock
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1658
    "find the first child, for which evaluation of the block returns
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
  1659
     true; if none does so, return the evaluation of anExceptionBlock"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
  1660
3071
55a9742766ed *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2962
diff changeset
  1661
    self do:[:el| 
55a9742766ed *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2962
diff changeset
  1662
        (aOneArgBlock value:el) ifTrue:[^ el] 
55a9742766ed *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2962
diff changeset
  1663
    ].
55a9742766ed *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2962
diff changeset
  1664
    ^ exceptionBlock value
55a9742766ed *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2962
diff changeset
  1665
55a9742766ed *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2962
diff changeset
  1666
    "Modified: / 13-09-2006 / 11:17:53 / cg"
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1667
!
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1668
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1669
detectLast:aOneArgBlock
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1670
    "find the last child, for which evaluation of the block returns
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
  1671
     true; if none does so, an exception is raised"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
  1672
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1673
    ^ self detectLast:aOneArgBlock ifNone:[self errorNotFound]
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1674
!
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1675
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1676
detectLast:anOneArgBlock ifNone:anExceptionBlock
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1677
    "find the last child, for which evaluation of the block returns
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
  1678
     true; if none does so, return the evaluation of anExceptionBlock"
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
  1679
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1680
    self reverseDo:[:el| (anOneArgBlock value:el) ifTrue:[^ el] ].
2927
25f51dcea354 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2879
diff changeset
  1681
    ^ anExceptionBlock value
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1682
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1683
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1684
findFirst:anOneArgBlock
1966
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
  1685
    "find the first child, for which evaluation of the argument, aOneArgBlock
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
  1686
     returns true; return its index or 0 if none detected.
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
  1687
    "
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1688
    self keysAndValuesDo:[:i :el| (anOneArgBlock value:el) ifTrue:[^ i] ].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1689
  ^ 0
1966
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
  1690
!
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
  1691
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1692
findLast:anOneArgBlock
1966
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
  1693
    "find the last child, for which evaluation of the argument, aOneArgBlock
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
  1694
     returns true; return its index or 0 if none detected.
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
  1695
    "
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1696
    self keysAndValuesReverseDo:[:i :el| (anOneArgBlock value:el) ifTrue:[^ i] ].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1697
  ^ 0
1966
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
  1698
!
ed61dfa648b5 add new enumerating/seraching functionality
ca
parents: 1965
diff changeset
  1699
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1700
identityIndexOf:aChild
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1701
    "return the index of aChild or 0 if not found. Compare using ==
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1702
    "
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
  1703
    ^ self identityIndexOf:aChild startingAt:1
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1704
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1705
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1706
identityIndexOf:aChild startingAt:startIndex
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1707
    "return the index of aChild, starting search at startIndex.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1708
     Compare using ==; return 0 if not found
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1709
    "
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
  1710
    |index|
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
  1711
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1712
    index := startIndex.
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
  1713
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1714
    self from:startIndex do:[:el|
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1715
        el == aChild ifTrue:[^ index ].
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1716
        index := index + 1.
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1717
    ].
2081
409ed8b04ae2 *** empty log message ***
ca
parents: 2033
diff changeset
  1718
    ^ 0
1489
d4c9639f7786 checkin from browser
tm
parents: 1488
diff changeset
  1719
!
d4c9639f7786 checkin from browser
tm
parents: 1488
diff changeset
  1720
d4c9639f7786 checkin from browser
tm
parents: 1488
diff changeset
  1721
recursiveDetect:aOneArgBlock
d4c9639f7786 checkin from browser
tm
parents: 1488
diff changeset
  1722
    "recursive find the first child, for which evaluation 
d4c9639f7786 checkin from browser
tm
parents: 1488
diff changeset
  1723
     of the block returns true; if none nil is returned
d4c9639f7786 checkin from browser
tm
parents: 1488
diff changeset
  1724
    "
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1725
    self recursiveDo:[:aChild|
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1726
        (aOneArgBlock value:aChild) ifTrue:[^ aChild]
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1727
    ].
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1728
    ^ nil
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1729
!
1489
d4c9639f7786 checkin from browser
tm
parents: 1488
diff changeset
  1730
1804
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1731
recursiveDetectLast:aBlock
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1732
    "find the last child, for which evaluation of the block returns
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1733
     true; if none does so, nil id returned
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1734
    "
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1735
    self recursiveReverseDo:[:aChild|
91896c0dfd4a add new features
ca
parents: 1794
diff changeset
  1736
        (aBlock value:aChild) ifTrue:[^ aChild].
1489
d4c9639f7786 checkin from browser
tm
parents: 1488
diff changeset
  1737
    ].
d4c9639f7786 checkin from browser
tm
parents: 1488
diff changeset
  1738
    ^ nil
1876
d9ec853e7843 add more messages
ca
parents: 1843
diff changeset
  1739
!
d9ec853e7843 add more messages
ca
parents: 1843
diff changeset
  1740
d9ec853e7843 add more messages
ca
parents: 1843
diff changeset
  1741
withAllDetect:aOneArgBlock
d9ec853e7843 add more messages
ca
parents: 1843
diff changeset
  1742
    "recursive find the first item including self, for which evaluation
d9ec853e7843 add more messages
ca
parents: 1843
diff changeset
  1743
     of the block returns true; if none nil is returned
d9ec853e7843 add more messages
ca
parents: 1843
diff changeset
  1744
    "
d9ec853e7843 add more messages
ca
parents: 1843
diff changeset
  1745
    (aOneArgBlock value:self) ifTrue:[^ self].
d9ec853e7843 add more messages
ca
parents: 1843
diff changeset
  1746
1883
7da039ab6677 added: access-methode for rootItem
tm
parents: 1876
diff changeset
  1747
    ^ self recursiveDetect:aOneArgBlock
7da039ab6677 added: access-methode for rootItem
tm
parents: 1876
diff changeset
  1748
! !
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1749
2486
d0c3806e68a6 category change
Claus Gittinger <cg@exept.de>
parents: 2484
diff changeset
  1750
!HierarchicalItem methodsFor:'sorting & reordering'!
2252
ebcefc9af592 add #sort:
ca
parents: 2230
diff changeset
  1751
2294
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1752
recursiveSort:aSortBlock
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1753
    "recursive sort the children inplace using the 2-arg block sortBlock for comparison
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1754
    "
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1755
    self criticalDo:[
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1756
        children size ~~ 0 ifTrue:[
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1757
            self nonCriticalRecursiveSort:aSortBlock.
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1758
            self childrenOrderChanged.
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1759
        ]
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1760
    ].
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1761
!
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1762
2252
ebcefc9af592 add #sort:
ca
parents: 2230
diff changeset
  1763
sort:aSortBlock
ebcefc9af592 add #sort:
ca
parents: 2230
diff changeset
  1764
    "sort the children inplace using the 2-arg block sortBlock for comparison
ebcefc9af592 add #sort:
ca
parents: 2230
diff changeset
  1765
    "
ebcefc9af592 add #sort:
ca
parents: 2230
diff changeset
  1766
    |unsorted|
ebcefc9af592 add #sort:
ca
parents: 2230
diff changeset
  1767
ebcefc9af592 add #sort:
ca
parents: 2230
diff changeset
  1768
    self criticalDo:[
2294
7f45237a518c recursive sort children
ca
parents: 2260
diff changeset
  1769
        unsorted := children.
2252
ebcefc9af592 add #sort:
ca
parents: 2230
diff changeset
  1770
ebcefc9af592 add #sort:
ca
parents: 2230
diff changeset
  1771
        unsorted size ~~ 0 ifTrue:[
ebcefc9af592 add #sort:
ca
parents: 2230
diff changeset
  1772
            children := unsorted sort:aSortBlock.
ebcefc9af592 add #sort:
ca
parents: 2230
diff changeset
  1773
            self childrenOrderChanged.
ebcefc9af592 add #sort:
ca
parents: 2230
diff changeset
  1774
        ]
ebcefc9af592 add #sort:
ca
parents: 2230
diff changeset
  1775
    ].
ebcefc9af592 add #sort:
ca
parents: 2230
diff changeset
  1776
! !
ebcefc9af592 add #sort:
ca
parents: 2230
diff changeset
  1777
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1778
!HierarchicalItem::Example class methodsFor:'instance creation'!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1779
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1780
labeled:aLabel
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1781
    ^ self new setLabel:aLabel
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1782
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1783
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1784
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1785
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1786
labeled:aLabel icon:anIcon
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1787
    ^ self new setLabel:aLabel icon:anIcon
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1788
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1789
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1790
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1791
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1792
!HierarchicalItem::Example class methodsFor:'resources'!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1793
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1794
iconForLevel:aLevel
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1795
    "returns an icon
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1796
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1797
    aLevel == 2 ifTrue:[ ^ ResourceSelectionBrowser iconPrivateClass ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1798
    aLevel == 3 ifTrue:[ ^ ResourceSelectionBrowser iconClass ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1799
    aLevel == 4 ifTrue:[ ^ ResourceSelectionBrowser iconCategory ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1800
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1801
  ^ nil
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1802
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1803
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1804
penguinIcon
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1805
    PenguinIcon isNil ifTrue:[
1794
029df2e76784 *** empty log message ***
ca
parents: 1733
diff changeset
  1806
        PenguinIcon := Smalltalk imageFromFileNamed:'xpmBitmaps/misc_logos/linux_penguin.xpm'
029df2e76784 *** empty log message ***
ca
parents: 1733
diff changeset
  1807
                                 inPackage:'stx:goodies'
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1808
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1809
    ^ PenguinIcon
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1810
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1811
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1812
!HierarchicalItem::Example methodsFor:'accessing'!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1813
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1814
children
2781
062d03cf175e *** empty log message ***
ca
parents: 2724
diff changeset
  1815
    |lvl lbl txt image img icon|
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1816
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1817
    children notNil ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1818
        ^ children
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1819
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1820
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1821
    (lvl := self level) == 5 ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1822
        children := #().
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1823
      ^ children
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1824
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1825
    icon     := self class iconForLevel:(lvl + 1).
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1826
    children := OrderedCollection new.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1827
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1828
    lvl < 4 ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1829
        txt := (lvl + 1) printString, ' ['.
2781
062d03cf175e *** empty log message ***
ca
parents: 2724
diff changeset
  1830
        img := Icon saveIcon.
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1831
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1832
        1 to:5 do:[:i|
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1833
            (i == 2 or:[i == 3]) ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1834
                lbl := img
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1835
            ] ifFalse:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1836
                i == 4 ifTrue:[
1540
3fab5658652a support carrige return in labels
Claus Gittinger <cg@exept.de>
parents: 1539
diff changeset
  1837
                    lbl := Array with:(self class penguinIcon)
1733
67c144581e63 add critical semaphore (RecursionLock)
ca
parents: 1669
diff changeset
  1838
                                 with:('penguin#and#text' replaceAll:$# with:(Character cr)).
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1839
                ] ifFalse:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1840
                    lbl := txt, (i printString), ']'
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1841
                ]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1842
            ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1843
            children add:(self class labeled:lbl icon:icon)
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1844
        ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1845
    ] ifFalse:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1846
        image := ResourceSelectionBrowser iconPrivateClass.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1847
        txt   := LabelAndIcon icon:image string:'Text'.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1848
        img   := Icon copyIcon.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1849
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1850
        1 to:5 do:[:i|
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1851
            lbl := i odd ifTrue:[txt] ifFalse:[img].
1398
590a0d3a5ff4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1390
diff changeset
  1852
            lbl := Array with:lbl with:'test' with:img.
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1853
            children add:(self class labeled:lbl icon:icon).
3333
ee578ab4ee94 Example - add editable text
Stefan Vogel <sv@exept.de>
parents: 3173
diff changeset
  1854
        ].
ee578ab4ee94 Example - add editable text
Stefan Vogel <sv@exept.de>
parents: 3173
diff changeset
  1855
        children add:(self class labeled:'Edit Text').
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1856
    ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1857
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1858
    children do:[:aChild| aChild parent:self ].
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1859
  ^ children
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1860
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1861
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1862
icon
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1863
    "returns the icon
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1864
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1865
    ^ icon
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1866
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1867
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1868
icon:anIcon
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1869
    "set the icon; if icon changed, a notification
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1870
     is raised.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1871
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1872
    icon ~= anIcon ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1873
        icon := anIcon.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1874
        self iconChanged
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1875
    ]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1876
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1877
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1878
label
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1879
    "returns the label
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1880
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1881
    ^ label
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1882
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1883
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1884
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1885
label:aLabel
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1886
    "set the label; if label changed, a notification
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1887
     is raised.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1888
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1889
    label ~= aLabel ifTrue:[
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1890
        label := aLabel.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1891
        self changed.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1892
    ]
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1893
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1894
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1895
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1896
setIcon:anIcon
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1897
    "set the icon without any change notification
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1898
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1899
    icon := anIcon
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1900
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1901
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1902
setLabel:aLabel
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1903
    "set the label without any change notification
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1904
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1905
    label := aLabel
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1906
!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1907
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1908
setLabel:aLabel icon:anIcon
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1909
    "set the label and icon without any change notification
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1910
    "
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1911
    label := aLabel.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1912
    icon  := anIcon.
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1913
! !
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1914
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1915
!HierarchicalItem class methodsFor:'documentation'!
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1916
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1917
version
3613
440f0aa671ce return value fixed (consistent)
Claus Gittinger <cg@exept.de>
parents: 3562
diff changeset
  1918
    ^ '$Header: /cvs/stx/stx/libwidg2/HierarchicalItem.st,v 1.85 2008-12-18 10:33:20 cg Exp $'
1390
62dc950b9140 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1919
! !