author | Jan Vrany <jan.vrany@fit.cvut.cz> |
Wed, 28 Aug 2013 10:50:17 +0100 | |
branch | jv |
changeset 13391 | 43eaa1c36082 |
parent 13390 | ab1969edf59b |
parent 13382 | 0ade5325ad8c |
child 13491 | b3afe831ff0a |
permissions | -rw-r--r-- |
5591 | 1 |
" |
2 |
COPYRIGHT (c) 2000 by eXept Software AG |
|
3 |
All Rights Reserved |
|
4 |
||
5 |
This software is furnished under a license and may be used |
|
6 |
only in accordance with the terms of that license and with the |
|
7 |
inclusion of the above copyright notice. This software may not |
|
8 |
be provided or otherwise made available to, or used by, any |
|
9 |
other person. No title to or ownership of the software is |
|
10 |
hereby transferred. |
|
11 |
" |
|
5592 | 12 |
"{ Package: 'stx:libtool' }" |
5591 | 13 |
|
14 |
"{ NameSpace: Tools }" |
|
15 |
||
16 |
BrowserList subclass:#VariableList |
|
10255 | 17 |
instanceVariableNames:'variableList classHolder showClassVars sortVariablesByName |
18 |
selectedVariableEntries showWarningAboutMissingEntryInXmlSpec' |
|
5591 | 19 |
classVariableNames:'' |
20 |
poolDictionaries:'' |
|
21 |
category:'Interface-Browsers-New' |
|
22 |
! |
|
23 |
||
10255 | 24 |
Object subclass:#VariableEntry |
13382 | 25 |
instanceVariableNames:'label application class name type icon sortingByNameHolder' |
10255 | 26 |
classVariableNames:'' |
27 |
poolDictionaries:'' |
|
28 |
privateIn:VariableList |
|
29 |
! |
|
30 |
||
5591 | 31 |
!VariableList class methodsFor:'documentation'! |
32 |
||
33 |
copyright |
|
34 |
" |
|
35 |
COPYRIGHT (c) 2000 by eXept Software AG |
|
36 |
All Rights Reserved |
|
37 |
||
38 |
This software is furnished under a license and may be used |
|
39 |
only in accordance with the terms of that license and with the |
|
40 |
inclusion of the above copyright notice. This software may not |
|
41 |
be provided or otherwise made available to, or used by, any |
|
42 |
other person. No title to or ownership of the software is |
|
43 |
hereby transferred. |
|
44 |
" |
|
11878 | 45 |
! |
46 |
||
47 |
documentation |
|
48 |
" |
|
49 |
I implement the variable list (below class list) in the new system browser |
|
50 |
" |
|
5591 | 51 |
! ! |
52 |
||
53 |
!VariableList class methodsFor:'interface specs'! |
|
54 |
||
55 |
windowSpec |
|
56 |
"This resource specification was automatically generated |
|
57 |
by the UIPainter of ST/X." |
|
58 |
||
59 |
"Do not manually edit this!! If it is corrupted, |
|
60 |
the UIPainter may not be able to read the specification." |
|
61 |
||
62 |
" |
|
10287 | 63 |
UIPainter new openOnClass:Tools::VariableList andSelector:#windowSpec |
64 |
Tools::VariableList new openInterface:#windowSpec |
|
65 |
Tools::VariableList open |
|
5591 | 66 |
" |
67 |
||
68 |
<resource: #canvas> |
|
69 |
||
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
70 |
^ |
10287 | 71 |
#(FullSpec |
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
72 |
name: windowSpec |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
73 |
window: |
10287 | 74 |
(WindowSpec |
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
75 |
label: 'VariableList' |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
76 |
name: 'VariableList' |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
77 |
min: (Point 0 0) |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
78 |
bounds: (Rectangle 0 0 300 300) |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
79 |
) |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
80 |
component: |
10287 | 81 |
(SpecCollection |
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
82 |
collection: ( |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
83 |
(SequenceViewSpec |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
84 |
name: 'List' |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
85 |
layout: (LayoutFrame 0 0.0 0 0.0 0 1.0 0 1.0) |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
86 |
tabable: true |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
87 |
model: selectedVariableEntries |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
88 |
menu: menuHolder |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
89 |
hasHorizontalScrollBar: true |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
90 |
hasVerticalScrollBar: true |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
91 |
miniScrollerHorizontal: true |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
92 |
isMultiSelect: true |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
93 |
valueChangeSelector: selectionChangedByClick |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
94 |
useIndex: false |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
95 |
sequenceList: variableList |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
96 |
doubleClickChannel: doubleClickChannel |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
97 |
) |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
98 |
) |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
99 |
|
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
100 |
) |
5591 | 101 |
) |
102 |
! ! |
|
103 |
||
104 |
!VariableList class methodsFor:'plugIn spec'! |
|
105 |
||
106 |
aspectSelectors |
|
107 |
"This resource specification was automatically generated |
|
108 |
by the UIPainter of ST/X." |
|
109 |
||
110 |
"Do not manually edit this. If it is corrupted, |
|
111 |
the UIPainter may not be able to read the specification." |
|
112 |
||
113 |
"Return a description of exported aspects; |
|
114 |
these can be connected to aspects of an embedding application |
|
115 |
(if this app is embedded in a subCanvas)." |
|
116 |
||
117 |
^ #( |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
118 |
#(#doubleClickChannel #action ) |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
119 |
#classHolder |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
120 |
#forceGeneratorTrigger |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
121 |
#immediateUpdate |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
122 |
#inGeneratorHolder |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
123 |
#menuHolder |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
124 |
#outGeneratorHolder |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
125 |
#packageFilter |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
126 |
#selectedVariables |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
127 |
#selectionChangeCondition |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
128 |
#updateTrigger |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
129 |
#showClassVarsInVariableList |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
130 |
#slaveMode |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
131 |
#sortVariablesByName |
5591 | 132 |
). |
133 |
! ! |
|
134 |
||
135 |
!VariableList methodsFor:'aspects'! |
|
136 |
||
137 |
classHolder |
|
138 |
classHolder isNil ifTrue:[ |
|
139 |
classHolder := #() asValue. |
|
140 |
classHolder addDependent:self |
|
141 |
]. |
|
142 |
^ classHolder |
|
143 |
! |
|
144 |
||
145 |
classHolder:aValueHolder |
|
146 |
classHolder notNil ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
147 |
classHolder removeDependent:self |
5591 | 148 |
]. |
149 |
classHolder := aValueHolder. |
|
150 |
classHolder notNil ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
151 |
classHolder isBehavior ifTrue:[self error:'should not happen']. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
152 |
classHolder addDependent:self |
5591 | 153 |
]. |
10308 | 154 |
|
155 |
"Modified: / 11-07-2011 / 17:04:19 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
5591 | 156 |
! |
157 |
||
158 |
defaultSlaveModeValue |
|
159 |
^ false. |
|
160 |
! |
|
161 |
||
10255 | 162 |
selectedVariableEntries |
163 |
<resource: #uiAspect> |
|
164 |
||
165 |
"automatically generated by UIPainter ..." |
|
166 |
||
167 |
"*** the code below creates a default model when invoked." |
|
168 |
"*** (which may not be the one you wanted)" |
|
169 |
"*** Please change as required and accept it in the browser." |
|
170 |
"*** (and replace this comment by something more useful ;-)" |
|
171 |
||
172 |
selectedVariableEntries isNil ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
173 |
selectedVariableEntries := #() asValue. |
10255 | 174 |
"/ if your app needs to be notified of changes, uncomment one of the lines below: |
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
175 |
selectedVariableEntries addDependent:self. |
10255 | 176 |
"/ selectedVariableEntries onChangeSend:#selectedVariableEntriesChanged to:self. |
177 |
]. |
|
178 |
^ selectedVariableEntries. |
|
179 |
||
180 |
"Modified: / 12-04-2011 / 15:49:31 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
181 |
! |
|
182 |
||
5591 | 183 |
selectedVariables |
184 |
^ self selectionHolder |
|
185 |
||
186 |
! |
|
187 |
||
188 |
selectedVariables:aValueHolder |
|
189 |
^ self selectionHolder:aValueHolder |
|
190 |
||
191 |
! |
|
192 |
||
193 |
showClassVarsInVariableList |
|
194 |
showClassVars isNil ifTrue:[ |
|
195 |
showClassVars := false asValue. |
|
196 |
showClassVars addDependent:self |
|
197 |
]. |
|
198 |
^ showClassVars |
|
199 |
! |
|
200 |
||
201 |
showClassVarsInVariableList:aValueHolder |
|
202 |
showClassVars notNil ifTrue:[ |
|
203 |
showClassVars removeDependent:self |
|
204 |
]. |
|
205 |
showClassVars := aValueHolder. |
|
206 |
showClassVars notNil ifTrue:[ |
|
207 |
showClassVars addDependent:self |
|
208 |
]. |
|
209 |
! |
|
210 |
||
211 |
showingInheritedClassVars |
|
212 |
^ false |
|
213 |
"/ ^ true |
|
214 |
! |
|
215 |
||
216 |
sortVariablesByName |
|
217 |
sortVariablesByName isNil ifTrue:[ |
|
218 |
sortVariablesByName := false asValue. |
|
219 |
sortVariablesByName addDependent:self |
|
220 |
]. |
|
221 |
^ sortVariablesByName |
|
222 |
! |
|
223 |
||
224 |
sortVariablesByName:aValueHolder |
|
6721
c49f5a3cbca2
variableList (sort) fixed in hierarchy views
Claus Gittinger <cg@exept.de>
parents:
5909
diff
changeset
|
225 |
"/ self assert:(aValueHolder value isBoolean). |
c49f5a3cbca2
variableList (sort) fixed in hierarchy views
Claus Gittinger <cg@exept.de>
parents:
5909
diff
changeset
|
226 |
|
5591 | 227 |
sortVariablesByName notNil ifTrue:[ |
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
228 |
sortVariablesByName removeDependent:self |
5591 | 229 |
]. |
230 |
sortVariablesByName := aValueHolder. |
|
231 |
sortVariablesByName notNil ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
232 |
sortVariablesByName addDependent:self |
5591 | 233 |
]. |
234 |
! |
|
235 |
||
236 |
variableList |
|
237 |
variableList isNil ifTrue:[ |
|
238 |
variableList := ValueHolder new |
|
239 |
]. |
|
240 |
^ variableList |
|
241 |
||
242 |
||
243 |
! ! |
|
244 |
||
245 |
!VariableList methodsFor:'change & update'! |
|
246 |
||
247 |
delayedUpdate:something with:aParameter from:changedObject |
|
248 |
|selectedClasses changedClass anyChange| |
|
249 |
||
250 |
self inSlaveModeOrInvisible ifTrue:[self invalidateList. ^ self]. |
|
251 |
||
252 |
changedObject == slaveMode ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
253 |
listValid ~~ true ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
254 |
self enqueueDelayedUpdateList |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
255 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
256 |
"/ self invalidateList. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
257 |
^ self |
5591 | 258 |
]. |
259 |
||
260 |
changedObject == classHolder ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
261 |
self invalidateList. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
262 |
^ self |
5591 | 263 |
]. |
264 |
changedObject == showClassVars ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
265 |
self invalidateList. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
266 |
^ self. |
5591 | 267 |
]. |
268 |
changedObject == sortVariablesByName ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
269 |
self invalidateList. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
270 |
^ self. |
5591 | 271 |
]. |
272 |
changedObject == Smalltalk ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
273 |
(something == #projectOrganization) ifTrue:[^ self]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
274 |
(something == #currentChangeSet) ifTrue:[^ self]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
275 |
(something == #aboutToAutoloadClass) ifTrue:[^ self]. |
11296
2fec94a88af2
added: #enqueueDelayedUpdateList
Claus Gittinger <cg@exept.de>
parents:
10974
diff
changeset
|
276 |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
277 |
(something == #classDefinition |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
278 |
or:[ (something == #newClass) |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
279 |
or:[ something == #classVariables and:[showClassVars value == true]]]) |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
280 |
ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
281 |
changedClass := aParameter. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
282 |
selectedClasses := classHolder value. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
283 |
selectedClasses notNil ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
284 |
selectedClasses isSequenceable ifFalse:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
285 |
selectedClasses := selectedClasses asOrderedCollection |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
286 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
287 |
selectedClasses keysAndValuesDo:[:idx :cls | |nm| |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
288 |
cls notNil ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
289 |
cls isObsolete ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
290 |
cls isMeta ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
291 |
nm := cls theNonMetaclass name. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
292 |
selectedClasses at:idx put:(Smalltalk at:nm) class. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
293 |
] ifFalse:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
294 |
nm := cls name. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
295 |
selectedClasses at:idx put:(Smalltalk at:nm). |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
296 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
297 |
anyChange := true. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
298 |
] ifFalse:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
299 |
(cls == aParameter |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
300 |
or:[something == #classVariables |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
301 |
and:[showClassVars value == true |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
302 |
and:[cls theNonMetaclass == aParameter theNonMetaclass]]]) ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
303 |
anyChange := true. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
304 |
] |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
305 |
] |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
306 |
] |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
307 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
308 |
(selectedClasses includes:nil) ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
309 |
"/ can happen, if a selected class is removed... |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
310 |
"/ self halt:'should this happen ?'. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
311 |
"/ fix it ... |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
312 |
selectedClasses := selectedClasses select:[:each | each notNil]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
313 |
classHolder value:selectedClasses. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
314 |
anyChange := true. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
315 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
316 |
anyChange == true ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
317 |
self invalidateList. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
318 |
^ self |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
319 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
320 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
321 |
^ self |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
322 |
]. |
5591 | 323 |
] ifFalse:[ |
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
324 |
changedObject isBehavior ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
325 |
anyChange := false. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
326 |
selectedClasses := classHolder value. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
327 |
selectedClasses notNil ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
328 |
selectedClasses keysAndValuesDo:[:idx :cls | |nm| |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
329 |
cls isObsolete ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
330 |
nm := cls name. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
331 |
selectedClasses at:idx put:(Smalltalk at:nm). |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
332 |
anyChange := true. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
333 |
] |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
334 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
335 |
anyChange == true ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
336 |
self invalidateList. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
337 |
^ self |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
338 |
]. |
5591 | 339 |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
340 |
(selectedClasses includesIdentical:something) ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
341 |
self invalidateList. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
342 |
^ self |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
343 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
344 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
345 |
^ self |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
346 |
]. |
5591 | 347 |
]. |
348 |
super delayedUpdate:something with:aParameter from:changedObject |
|
11296
2fec94a88af2
added: #enqueueDelayedUpdateList
Claus Gittinger <cg@exept.de>
parents:
10974
diff
changeset
|
349 |
|
2fec94a88af2
added: #enqueueDelayedUpdateList
Claus Gittinger <cg@exept.de>
parents:
10974
diff
changeset
|
350 |
"Modified: / 01-03-2012 / 09:18:11 / cg" |
2fec94a88af2
added: #enqueueDelayedUpdateList
Claus Gittinger <cg@exept.de>
parents:
10974
diff
changeset
|
351 |
! |
2fec94a88af2
added: #enqueueDelayedUpdateList
Claus Gittinger <cg@exept.de>
parents:
10974
diff
changeset
|
352 |
|
2fec94a88af2
added: #enqueueDelayedUpdateList
Claus Gittinger <cg@exept.de>
parents:
10974
diff
changeset
|
353 |
enqueueDelayedUpdateList |
2fec94a88af2
added: #enqueueDelayedUpdateList
Claus Gittinger <cg@exept.de>
parents:
10974
diff
changeset
|
354 |
super enqueueDelayedUpdateList |
2fec94a88af2
added: #enqueueDelayedUpdateList
Claus Gittinger <cg@exept.de>
parents:
10974
diff
changeset
|
355 |
|
2fec94a88af2
added: #enqueueDelayedUpdateList
Claus Gittinger <cg@exept.de>
parents:
10974
diff
changeset
|
356 |
"Created: / 01-03-2012 / 09:06:42 / cg" |
5591 | 357 |
! |
358 |
||
359 |
makeDependent |
|
360 |
Smalltalk addDependent:self |
|
361 |
||
362 |
! |
|
363 |
||
364 |
makeIndependent |
|
365 |
Smalltalk removeDependent:self |
|
366 |
||
367 |
! |
|
368 |
||
369 |
selectionChangedByClick |
|
370 |
"we are not interested in that - get another notification |
|
371 |
via the changed valueHolder" |
|
372 |
||
373 |
||
374 |
! |
|
375 |
||
376 |
update:something with:aParameter from:changedObject |
|
377 |
"/ ^ self delayedUpdate:something with:aParameter from:changedObject. |
|
378 |
||
379 |
changedObject == Smalltalk ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
380 |
something == #methodDictionary ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
381 |
^ self |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
382 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
383 |
something == #methodTrap ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
384 |
^ self |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
385 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
386 |
something == #methodCoverageInfo ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
387 |
^ self |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
388 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
389 |
something == #methodInClass ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
390 |
^ self |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
391 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
392 |
something == #methodInClassRemoved ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
393 |
^ self |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
394 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
395 |
something == #classComment ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
396 |
^ self. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
397 |
]. |
5591 | 398 |
]. |
399 |
"/ self window sensor isNil ifTrue:[ |
|
400 |
"/ "/ I am not visible ... |
|
401 |
"/ self invalidateList. |
|
402 |
"/ ^ self |
|
403 |
"/ ]. |
|
10255 | 404 |
changedObject == selectedVariableEntries ifTrue:[ |
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
405 |
self selectedVariables value: |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
406 |
((selectedVariableEntries value ? #()) |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
407 |
collect:[:e|e name]). |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
408 |
^self. |
10255 | 409 |
]. |
410 |
||
411 |
||
5591 | 412 |
super update:something with:aParameter from:changedObject |
413 |
||
10255 | 414 |
"Modified: / 12-04-2011 / 15:54:23 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
10366 | 415 |
"Modified: / 20-07-2011 / 18:52:44 / cg" |
5591 | 416 |
! ! |
417 |
||
418 |
!VariableList methodsFor:'generators'! |
|
419 |
||
420 |
makeGenerator |
|
421 |
||
422 |
||
423 |
||
424 |
! ! |
|
425 |
||
426 |
!VariableList methodsFor:'private'! |
|
427 |
||
5909 | 428 |
commonPostBuild |
5591 | 429 |
|list| |
430 |
||
5909 | 431 |
super commonPostBuild. |
5591 | 432 |
|
5909 | 433 |
list := builder componentAt:#List. |
5591 | 434 |
list notNil ifTrue:[ |
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
435 |
list selectConditionBlock:[:item | self selectionChangeAllowed:item]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
436 |
list ignoreReselect:false. |
5591 | 437 |
]. |
438 |
! |
|
439 |
||
440 |
commonSubClassIn:classes |
|
441 |
"return true if there is a common subclass" |
|
442 |
||
443 |
|theCommonSubClass "classesByInheritance"| |
|
444 |
||
445 |
theCommonSubClass := nil. |
|
446 |
classes do:[:eachClass | |
|
447 |
theCommonSubClass isNil ifTrue:[ |
|
448 |
theCommonSubClass := eachClass |
|
449 |
] ifFalse:[ |
|
450 |
(eachClass isSubclassOf:theCommonSubClass) ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
451 |
theCommonSubClass := eachClass |
5591 | 452 |
] ifFalse:[ |
453 |
(theCommonSubClass isSubclassOf:eachClass) ifFalse:[ |
|
454 |
^ nil |
|
455 |
] |
|
456 |
] |
|
457 |
] |
|
458 |
]. |
|
459 |
^ theCommonSubClass. |
|
460 |
||
461 |
"/ classesByInheritance := classes topologicalSort:[:a :b | a isSubclassOf:b]. |
|
462 |
"/ classesByInheritance keysAndValuesDo:[:index :eachClass | |
|
463 |
"/ "/ all classes after that one must be superclasses ... |
|
464 |
"/ classesByInheritance from:index+1 to:classesByInheritance size do:[:otherClass | |
|
465 |
"/ (eachClass isSubclassOf:otherClass) ifFalse:[ |
|
466 |
"/ ^ nil. |
|
467 |
"/ ] |
|
468 |
"/ ]. |
|
469 |
"/ ]. |
|
470 |
"/ ^ classesByInheritance first |
|
471 |
! |
|
472 |
||
10324
d68f7aa2e449
I dont like extensions too much.
Claus Gittinger <cg@exept.de>
parents:
10308
diff
changeset
|
473 |
iconInBrowserForVariable:varName in:aClass |
d68f7aa2e449
I dont like extensions too much.
Claus Gittinger <cg@exept.de>
parents:
10308
diff
changeset
|
474 |
"variables for which an entry is found in the xml-spec (if any) are marked |
d68f7aa2e449
I dont like extensions too much.
Claus Gittinger <cg@exept.de>
parents:
10308
diff
changeset
|
475 |
with an <xml>-icon." |
10255 | 476 |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
477 |
(Expecco::ExpeccoXMLDecoder notNil |
11586 | 478 |
and:[aClass canUnderstand: #xmlSpecForObject:]) ifTrue:[ |
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
479 |
Error handle:[:ex | |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
480 |
] do:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
481 |
(Expecco::ExpeccoXMLDecoder xmlSpecForObject:aClass basicNew) |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
482 |
do:[:spec | spec getter = varName ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
483 |
^ SystemBrowser instVarOverlayXmlSpec |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
484 |
] |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
485 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
486 |
]. |
10324
d68f7aa2e449
I dont like extensions too much.
Claus Gittinger <cg@exept.de>
parents:
10308
diff
changeset
|
487 |
]. |
d68f7aa2e449
I dont like extensions too much.
Claus Gittinger <cg@exept.de>
parents:
10308
diff
changeset
|
488 |
^ nil |
10255 | 489 |
|
490 |
"Created: / 12-04-2011 / 19:58:08 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
10324
d68f7aa2e449
I dont like extensions too much.
Claus Gittinger <cg@exept.de>
parents:
10308
diff
changeset
|
491 |
"Modified: / 15-07-2011 / 18:32:47 / cg" |
11586 | 492 |
"Modified: / 22-06-2012 / 13:17:28 / sr" |
10255 | 493 |
! |
494 |
||
495 |
listEntryForClass: cls name:name |
|
496 |
||
497 |
" (showWarningAboutMissingEntryInXmlSpec not |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
498 |
and:[Expecco::ExpeccoXMLDecoder notNil |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
499 |
and:[cls canUnderstand: #xmlSpecFor:]]) ifTrue: |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
500 |
[| hasSpecEntry | |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
501 |
hasSpecEntry := false. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
502 |
(Expecco::ExpeccoXMLDecoder xmlSpecForObject:cls basicNew) |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
503 |
do:[:spec|spec getter = name ifTrue: |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
504 |
[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
505 |
hasSpecEntry := true]]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
506 |
showWarningAboutMissingEntryInXmlSpec := hasSpecEntry not]. " |
10255 | 507 |
|
13382 | 508 |
|entry| |
509 |
||
510 |
entry := VariableEntry application: self class: cls name: name. |
|
511 |
entry sortingByNameHolder:sortVariablesByName. |
|
512 |
^ entry |
|
10255 | 513 |
|
514 |
"Created: / 12-04-2011 / 15:41:07 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
515 |
"Modified: / 12-04-2011 / 21:36:33 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
516 |
! |
|
517 |
||
10974 | 518 |
listEntryForClass: cls name:name info: classInfo |
519 |
||
520 |
| nm entry | |
|
521 |
||
522 |
nm := name. |
|
523 |
entry := Tools::VariableList::VariableEntry application: self class: cls name: nm. |
|
13382 | 524 |
entry sortingByNameHolder:sortVariablesByName. |
10974 | 525 |
classInfo notNil ifTrue:[ |
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
526 |
entry type: (classInfo infoForInstvarOrNil: name). |
10974 | 527 |
]. |
528 |
^entry |
|
529 |
||
530 |
"Created: / 27-11-2011 / 17:17:11 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
531 |
! |
|
532 |
||
5591 | 533 |
listOfVariables |
10974 | 534 |
|
13155 | 535 |
|nameList numClasses classes class commonSubclass commonSuperclass showingClassVars |
10974 | 536 |
sortByName classesAlreadyProcessed hasSmallSense smallSenseManager info | |
5591 | 537 |
|
538 |
classHolder isNil ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
539 |
"/ testing |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
540 |
^ #() |
5591 | 541 |
]. |
542 |
||
10974 | 543 |
hasSmallSense := ConfigurableFeatures includesFeature:'SmallSenseEnabled'. |
544 |
hasSmallSense ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
545 |
smallSenseManager := (Smalltalk at: #'SmallSense::Manager') instance. |
10974 | 546 |
]. |
547 |
||
6721
c49f5a3cbca2
variableList (sort) fixed in hierarchy views
Claus Gittinger <cg@exept.de>
parents:
5909
diff
changeset
|
548 |
showingClassVars := self showClassVarsInVariableList value == true. |
c49f5a3cbca2
variableList (sort) fixed in hierarchy views
Claus Gittinger <cg@exept.de>
parents:
5909
diff
changeset
|
549 |
sortByName := self sortVariablesByName value. |
c49f5a3cbca2
variableList (sort) fixed in hierarchy views
Claus Gittinger <cg@exept.de>
parents:
5909
diff
changeset
|
550 |
"/ self assert:(sortByName isBoolean). |
5591 | 551 |
|
552 |
classes := classHolder value. |
|
553 |
(numClasses := classes size) == 0 ifTrue:[^ #() ]. |
|
554 |
numClasses > 1 ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
555 |
"/ multiple classes - see if there is a common subclass ... |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
556 |
commonSubclass := self commonSubClassIn:classes. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
557 |
commonSubclass notNil ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
558 |
"/ yes - treat like a single class |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
559 |
classes := Array with:(commonSubclass). |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
560 |
numClasses := 1. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
561 |
]. |
13155 | 562 |
"/ commonSuperclass := Behavior commonSuperclassOf:classes. |
563 |
"/ commonSuperclass notNil ifTrue:[ |
|
564 |
"/ "/ yes - treat like a single class |
|
565 |
"/ classes := Array with:(commonSuperclass). |
|
566 |
"/ numClasses := 1. |
|
567 |
"/ ]. |
|
5591 | 568 |
]. |
569 |
||
570 |
numClasses > 1 ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
571 |
"/ multiple classes - sort alphabetically ... |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
572 |
"/ unless there is a common subclass ... |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
573 |
nameList := Set new. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
574 |
classesAlreadyProcessed := IdentitySet new. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
575 |
classes do:[:eachClass | |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
576 |
|class| |
13155 | 577 |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
578 |
class := eachClass. |
13155 | 579 |
"/ showingClassVars ifTrue:[ |
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
580 |
"/ class := class theNonMetaclass |
13155 | 581 |
"/ ]. |
582 |
||
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
583 |
hasSmallSense ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
584 |
info := smallSenseManager infoForClassOrNil: class. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
585 |
]. |
10974 | 586 |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
587 |
(classesAlreadyProcessed includes:class) ifFalse:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
588 |
showingClassVars ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
589 |
self showingInheritedClassVars ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
590 |
class theNonMetaclass withAllSuperclassesDo:[:cls| |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
591 |
hasSmallSense ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
592 |
info := smallSenseManager infoForClassOrNil: cls. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
593 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
594 |
(classesAlreadyProcessed includes:cls) ifFalse:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
595 |
nameList addAll: |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
596 |
(cls classVarNames collect:[:nm|self listEntryForClass: cls name: nm info: info]). |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
597 |
classesAlreadyProcessed add:cls. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
598 |
] |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
599 |
] |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
600 |
] ifFalse:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
601 |
nameList addAll: |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
602 |
(class classVarNames collect:[:nm|self listEntryForClass: class name: nm info: info ]) |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
603 |
] |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
604 |
] ifFalse:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
605 |
class withAllSuperclassesDo:[:cls| |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
606 |
(classesAlreadyProcessed includes:cls) ifFalse:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
607 |
nameList addAll: |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
608 |
(cls instVarNames collect:[:nm|self listEntryForClass: cls name: nm info: info ]). |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
609 |
classesAlreadyProcessed add:cls. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
610 |
] |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
611 |
] |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
612 |
] |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
613 |
] |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
614 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
615 |
nameList := nameList asOrderedCollection. |
5591 | 616 |
] ifFalse:[ |
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
617 |
"/ only a single class - sort by inheritance |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
618 |
class := classes first. |
5591 | 619 |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
620 |
nameList := OrderedCollection new. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
621 |
class notNil ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
622 |
showingClassVars ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
623 |
class := class theNonMetaclass |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
624 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
625 |
class withAllSuperclassesDo:[:cls| |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
626 |
|varNames| |
5591 | 627 |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
628 |
(hasSmallSense and:[showingClassVars not]) ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
629 |
info := smallSenseManager infoForClassOrNil: cls. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
630 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
631 |
varNames := showingClassVars ifTrue:[ cls classVarNames ] ifFalse:[ cls instVarNames ]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
632 |
varNames copy reverse do:[:varName| |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
633 |
nameList addFirst: (self listEntryForClass: cls name: varName info: info). |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
634 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
635 |
sortByName ifFalse:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
636 |
nameList addFirst:(("'----- ' , "cls nameInBrowser" , ' -----'") asText colorizeAllWith: Color gray). |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
637 |
] |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
638 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
639 |
]. |
5591 | 640 |
]. |
641 |
||
642 |
(numClasses > 1 or:[sortByName]) ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
643 |
nameList := nameList asSortedCollection:[:a :b|a name < b name]. |
5591 | 644 |
]. |
645 |
^ nameList |
|
646 |
||
10255 | 647 |
"Created: / 05-02-2000 / 13:42:11 / cg" |
10550 | 648 |
"Modified: / 08-08-2011 / 16:20:58 / cg" |
10974 | 649 |
"Modified: / 27-11-2011 / 17:29:47 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
650 |
"Modified (comment): / 16-12-2011 / 01:27:57 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
5591 | 651 |
! |
652 |
||
653 |
postBuildWith:aBuilder |
|
654 |
|listView| |
|
655 |
||
656 |
(listView := aBuilder componentAt:#List) notNil ifTrue:[ |
|
657 |
listView scrollWhenUpdating:#end |
|
658 |
]. |
|
659 |
super postBuildWith:aBuilder |
|
660 |
||
661 |
! |
|
662 |
||
663 |
release |
|
664 |
super release. |
|
665 |
||
666 |
classHolder removeDependent:self. |
|
667 |
showClassVars removeDependent:self. |
|
668 |
! |
|
669 |
||
670 |
selectionChangeAllowed:index |
|
10255 | 671 |
|
672 |
| entry | |
|
673 |
^((entry := variableList value at:index) isString" and:[entry startsWith:'---']") not. |
|
674 |
||
675 |
"Modified: / 28-04-2011 / 13:18:21 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
5591 | 676 |
! |
677 |
||
678 |
updateList |
|
679 |
| prevSelection newSelection newList oldList selectedVariablesHolder| |
|
680 |
||
681 |
oldList := self variableList value copy. |
|
10255 | 682 |
showWarningAboutMissingEntryInXmlSpec := false. |
5591 | 683 |
newList := self listOfVariables. |
684 |
||
685 |
newList ~= variableList value ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
686 |
selectedVariablesHolder := self selectedVariableEntries. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
687 |
prevSelection := (self selectedVariables value "selectedVariablesHolder value" copy) ? #(). |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
688 |
variableList value:newList. |
10255 | 689 |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
690 |
newSelection := newList select:[:item | prevSelection includes:item string]. |
11360 | 691 |
"/ newSelection := prevSelection select:[:item | newList includes:item]. |
5591 | 692 |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
693 |
newSelection size > 0 ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
694 |
"/ force change (for dependents) |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
695 |
"/ selectedVariablesHolder value:nil. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
696 |
selectedVariablesHolder |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
697 |
setValue:newSelection; |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
698 |
removeDependent:self; |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
699 |
changed; |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
700 |
addDependent:self. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
701 |
] ifFalse:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
702 |
prevSelection := selectedVariablesHolder value. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
703 |
selectedVariablesHolder value:nil. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
704 |
]. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
705 |
(prevSelection size > 0 or:[newSelection size > 0 |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
706 |
"and:[ prevSelection ~= newSelection]"]) ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
707 |
self updateOutputGenerator. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
708 |
]. |
10255 | 709 |
]. |
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
710 |
(showWarningAboutMissingEntryInXmlSpec and:[self topApplication respondsTo: #showMessage:]) |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
711 |
ifTrue: |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
712 |
[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
713 |
self topApplication showMessage: |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
714 |
'One or more instance variables are not listed in #xmlSpecFor:'. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
715 |
]. |
10255 | 716 |
showWarningAboutMissingEntryInXmlSpec := false. |
717 |
listValid := true. |
|
718 |
||
10495 | 719 |
"Modified: / 05-08-2011 / 12:34:47 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
11461 | 720 |
"Modified: / 23-03-2012 / 15:55:47 / cg" |
10255 | 721 |
! ! |
722 |
||
723 |
!VariableList::VariableEntry class methodsFor:'instance creation'! |
|
724 |
||
725 |
application: app class: aClass name: aString |
|
726 |
||
727 |
^self new application: app; class: aClass; name: aString |
|
728 |
||
729 |
"Created: / 12-04-2011 / 19:53:06 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
730 |
! |
|
731 |
||
732 |
class: aClass name: aString |
|
733 |
||
734 |
^self new class: aClass; name: aString |
|
735 |
||
736 |
"Created: / 12-04-2011 / 15:39:30 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
737 |
! ! |
|
738 |
||
739 |
!VariableList::VariableEntry methodsFor:'accessing'! |
|
740 |
||
741 |
application: anObject |
|
5591 | 742 |
|
10255 | 743 |
application := anObject |
744 |
||
745 |
"Created: / 12-04-2011 / 19:55:01 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
746 |
! |
|
747 |
||
10308 | 748 |
asString |
749 |
||
750 |
^self name |
|
751 |
||
752 |
"Created: / 11-07-2011 / 17:03:02 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
753 |
! |
|
754 |
||
10255 | 755 |
class:aClass |
756 |
class := aClass. |
|
757 |
! |
|
758 |
||
759 |
icon |
|
10871 | 760 |
icon isNil ifTrue:[ |
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
761 |
icon := application iconInBrowserForVariable: name in: class. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
762 |
icon isNil ifTrue:[icon := #NOICON]. |
10871 | 763 |
]. |
10255 | 764 |
^icon |
765 |
||
766 |
"Created: / 12-04-2011 / 15:54:50 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
767 |
"Modified: / 12-04-2011 / 19:58:34 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
10871 | 768 |
"Modified: / 18-11-2011 / 15:05:18 / cg" |
10255 | 769 |
! |
770 |
||
771 |
klass |
|
772 |
^ class |
|
773 |
||
774 |
"Created: / 12-04-2011 / 19:54:33 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
775 |
! |
|
776 |
||
10974 | 777 |
label |
778 |
||
779 |
label isNil ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
780 |
label := name. |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
781 |
type notNil ifTrue:[ |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
782 |
label := (label , ' ' , (type displayString colorizeAllWith: Color brown)) |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
783 |
]. |
10974 | 784 |
]. |
785 |
^label |
|
786 |
||
787 |
"Created: / 16-12-2011 / 00:54:58 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
788 |
! |
|
789 |
||
13382 | 790 |
labelWithClass |
791 |
|l| |
|
792 |
||
793 |
l := self label. |
|
794 |
class notNil ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
795 |
^ label,' (' ,(class nameWithoutPrefix colorizeAllWith: Color grey),')' |
13382 | 796 |
]. |
797 |
^label |
|
798 |
! |
|
799 |
||
10255 | 800 |
name |
801 |
^ name |
|
802 |
! |
|
803 |
||
804 |
name:aString |
|
805 |
name := aString. |
|
806 |
! |
|
807 |
||
13382 | 808 |
sortingByNameHolder:something |
809 |
sortingByNameHolder := something. |
|
810 |
! |
|
811 |
||
10255 | 812 |
string |
813 |
||
814 |
^name |
|
815 |
||
816 |
"Created: / 12-04-2011 / 15:45:20 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
10974 | 817 |
! |
818 |
||
819 |
type |
|
820 |
"Return a SmallSense inferred type" |
|
821 |
||
822 |
^ type |
|
823 |
||
824 |
"Modified (format): / 16-12-2011 / 00:41:38 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
825 |
! |
|
826 |
||
827 |
type:aSmallSenseType |
|
828 |
"Sets a SmallSense inferred type" |
|
829 |
||
830 |
type := aSmallSenseType. |
|
831 |
||
832 |
"Modified (format): / 16-12-2011 / 00:41:35 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
10255 | 833 |
! ! |
834 |
||
835 |
!VariableList::VariableEntry methodsFor:'displaying'! |
|
836 |
||
837 |
displayOn:aGC x:x y:y opaque: opaque |
|
13382 | 838 |
| icn shownLabel | |
10255 | 839 |
|
840 |
icn := self icon. |
|
841 |
icn ~~ #NOICON ifTrue:[ |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
842 |
icn displayOn:aGC x:x + 1 y:y - icn height. |
5591 | 843 |
]. |
13382 | 844 |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
845 |
shownLabel := sortingByNameHolder value |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
846 |
ifTrue:[ self labelWithClass ] |
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
847 |
ifFalse: [ self label ]. |
13382 | 848 |
|
849 |
shownLabel displayOn:aGC x:x + 20 y:y opaque: opaque |
|
10255 | 850 |
|
851 |
"Created: / 12-04-2011 / 15:47:09 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
5591 | 852 |
! ! |
853 |
||
10974 | 854 |
!VariableList::VariableEntry methodsFor:'queries'! |
855 |
||
856 |
widthOn:aGC |
|
857 |
||
858 |
^20"space for icon, see displayOn:..." |
|
13391
43eaa1c36082
Merged ab1969edf59b and 64efc4f4f688 (branch default - CVS HEAD)
Jan Vrany <jan.vrany@fit.cvut.cz>
diff
changeset
|
859 |
+ (self label widthOn:aGC) |
10974 | 860 |
|
861 |
"Created: / 16-12-2011 / 01:04:01 / Jan Vrany <jan.vrany@fit.cvut.cz>" |
|
862 |
! ! |
|
863 |
||
5591 | 864 |
!VariableList class methodsFor:'documentation'! |
865 |
||
9461 | 866 |
version_CVS |
13382 | 867 |
^ '$Header: /cvs/stx/stx/libtool/Tools__VariableList.st,v 1.22 2013-08-27 12:57:33 cg Exp $' |
12128
a7ff7d66ee85
Improvements in LintHighlighter, few fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
12125
diff
changeset
|
868 |
! |
a7ff7d66ee85
Improvements in LintHighlighter, few fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
12125
diff
changeset
|
869 |
|
12431
9f0c59c742d5
Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
12401
diff
changeset
|
870 |
version_HG |
9f0c59c742d5
Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
12401
diff
changeset
|
871 |
|
9f0c59c742d5
Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
12401
diff
changeset
|
872 |
^ '$Changeset: <not expanded> $' |
9f0c59c742d5
Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
12401
diff
changeset
|
873 |
! |
9f0c59c742d5
Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
12401
diff
changeset
|
874 |
|
12128
a7ff7d66ee85
Improvements in LintHighlighter, few fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
12125
diff
changeset
|
875 |
version_SVN |
12314 | 876 |
^ '$Id: Tools__VariableList.st 8083 2013-01-14 11:48:37Z vranyj1 $' |
5591 | 877 |
! ! |