BrowserView.st
author claus
Thu, 07 Sep 1995 14:53:52 +0200
changeset 132 9bf0c15113f2
parent 131 48cd793d8eb4
child 133 fa9a37e36a07
permissions -rw-r--r--
.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
     1
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
f2c56efa3599 Initial revision
claus
parents:
diff changeset
     3
	      All Rights Reserved
f2c56efa3599 Initial revision
claus
parents:
diff changeset
     4
f2c56efa3599 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
f2c56efa3599 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
f2c56efa3599 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
f2c56efa3599 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
f2c56efa3599 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    11
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    12
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    13
'From Smalltalk/X, Version:2.10.4 on 24-feb-1995 at 7:10:38 am'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    14
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    15
StandardSystemView subclass:#BrowserView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    16
	 instanceVariableNames:'classCategoryListView classListView methodCategoryListView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    17
		methodListView classMethodListView codeView classToggle
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    18
		instanceToggle currentClassCategory currentClassHierarchy
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    19
		currentClass currentMethodCategory currentMethod currentSelector
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    20
		showInstance actualClass fullClass lastMethodCategory aspect
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    21
		variableListView fullProtocol lockUpdates autoSearch myLabel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    22
		acceptClass'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    23
	 classVariableNames:'CheckForInstancesWhenRemovingClasses DefaultIcon'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    24
	 poolDictionaries:''
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    25
	 category:'Interface-Browsers'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    26
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    27
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    28
BrowserView comment:'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    29
COPYRIGHT (c) 1989 by Claus Gittinger
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    30
	     All Rights Reserved
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    31
132
claus
parents: 131
diff changeset
    32
$Header: /cvs/stx/stx/libtool/BrowserView.st,v 1.27 1995-09-07 12:52:56 claus Exp $
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    33
'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    34
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    35
!BrowserView class methodsFor:'documentation'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    36
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    37
copyright
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    38
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    39
 COPYRIGHT (c) 1989 by Claus Gittinger
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    40
	      All Rights Reserved
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    41
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    42
 This software is furnished under a license and may be used
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    43
 only in accordance with the terms of that license and with the
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    44
 inclusion of the above copyright notice.   This software may not
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    45
 be provided or otherwise made available to, or used by, any
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    46
 other person.  No title to or ownership of the software is
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    47
 hereby transferred.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    48
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    49
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    50
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    51
version
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    52
"
132
claus
parents: 131
diff changeset
    53
$Header: /cvs/stx/stx/libtool/BrowserView.st,v 1.27 1995-09-07 12:52:56 claus Exp $
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    54
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    55
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    56
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    57
documentation
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    58
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    59
    this class implements all kinds of class browsers.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    60
    Typically, it is started with 'SystemBrowser open', but there are many other 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    61
    startup messages, to launch special browsers.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    62
    See the categories 'startup' and 'special search startup' in the classes
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    63
    protocol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    64
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    65
    Alse, see the extra document 'doc/misc/sbrowser.doc' or the HTML online doc
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    66
    for how to use the browser.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    67
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    68
    written winter 89 by claus
106
claus
parents: 105
diff changeset
    69
claus
parents: 105
diff changeset
    70
    Notice: SystemBrowser is currently being rewritten to be an instance
claus
parents: 105
diff changeset
    71
    of ApplicationModel - this transition is not yet complete and you see
claus
parents: 105
diff changeset
    72
    here intermediate versions of BrowserView/SystemBrowser. 
claus
parents: 105
diff changeset
    73
    All action is (currently) still done here in BrowserView, although the
claus
parents: 105
diff changeset
    74
    SystemBrowsers class methods are used to startup a browser.
claus
parents: 105
diff changeset
    75
    This will certainly change ...
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    76
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    77
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    78
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    79
!BrowserView class methodsFor:'defaults'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    80
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    81
defaultIcon
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    82
    DefaultIcon isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    83
	DefaultIcon := Form fromFile:'SBrowser.xbm' resolution:100
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    84
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    85
    ^ DefaultIcon
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    86
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    87
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    88
!BrowserView class methodsFor:'initialization'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    89
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    90
initialize
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    91
    "Browser configuration;
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    92
     (values can be changed from your private startup file)"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    93
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    94
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    95
     setting this to false, the removeClass function will remove
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    96
     classes WITHOUT checking for instances. Otherwise,
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    97
     it will check and let you confirm in case there are instances.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    98
     Checking for instances may be a bit time consuming, though.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
    99
     The default is true - therefore, it will check
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   100
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   101
    CheckForInstancesWhenRemovingClasses := true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   102
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   103
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   104
     CheckForInstancesWhenRemovingClasses := true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   105
     CheckForInstancesWhenRemovingClasses := false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   106
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   107
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   108
126
claus
parents: 125
diff changeset
   109
!BrowserView methodsFor:'help'!
claus
parents: 125
diff changeset
   110
claus
parents: 125
diff changeset
   111
helpTextFor:aComponent
claus
parents: 125
diff changeset
   112
    |s|
claus
parents: 125
diff changeset
   113
claus
parents: 125
diff changeset
   114
    aComponent == classCategoryListView ifTrue:[
claus
parents: 125
diff changeset
   115
	s := 'HELP_CCAT_LIST'
claus
parents: 125
diff changeset
   116
    ].
claus
parents: 125
diff changeset
   117
    aComponent == classListView ifTrue:[
claus
parents: 125
diff changeset
   118
	fullProtocol ifTrue:[
claus
parents: 125
diff changeset
   119
	    s := 'HELP_PCLASS_LIST'
claus
parents: 125
diff changeset
   120
	] ifFalse:[
claus
parents: 125
diff changeset
   121
	    currentClassHierarchy notNil ifTrue:[
claus
parents: 125
diff changeset
   122
		s := 'HELP_HCLASS_LIST'
claus
parents: 125
diff changeset
   123
	    ] ifFalse:[
claus
parents: 125
diff changeset
   124
		s := 'HELP_CLASS_LIST'
claus
parents: 125
diff changeset
   125
	    ]
claus
parents: 125
diff changeset
   126
	]
claus
parents: 125
diff changeset
   127
    ].
claus
parents: 125
diff changeset
   128
    aComponent == methodCategoryListView ifTrue:[
claus
parents: 125
diff changeset
   129
	s := 'HELP_MCAT_LIST'
claus
parents: 125
diff changeset
   130
    ].
claus
parents: 125
diff changeset
   131
    aComponent == methodListView ifTrue:[
claus
parents: 125
diff changeset
   132
	s := 'HELP_METHOD_LIST'
claus
parents: 125
diff changeset
   133
    ].
claus
parents: 125
diff changeset
   134
    aComponent == variableListView ifTrue:[
claus
parents: 125
diff changeset
   135
	s := 'HELP_VAR_LIST'
claus
parents: 125
diff changeset
   136
    ].
claus
parents: 125
diff changeset
   137
    aComponent == codeView ifTrue:[
132
claus
parents: 131
diff changeset
   138
	fullClass ifTrue:[
claus
parents: 131
diff changeset
   139
	    s := 'HELP_FULLCODE_VIEW'
claus
parents: 131
diff changeset
   140
	] ifFalse:[
claus
parents: 131
diff changeset
   141
	    s := 'HELP_CODE_VIEW'
claus
parents: 131
diff changeset
   142
	]
126
claus
parents: 125
diff changeset
   143
    ].
claus
parents: 125
diff changeset
   144
    (aComponent == instanceToggle 
claus
parents: 125
diff changeset
   145
    or:[aComponent == classToggle]) ifTrue:[
claus
parents: 125
diff changeset
   146
	s := 'HELP_INST_CLASS_TOGGLE'
claus
parents: 125
diff changeset
   147
    ].
claus
parents: 125
diff changeset
   148
    aComponent == classMethodListView ifTrue:[
claus
parents: 125
diff changeset
   149
	s := 'HELP_CLSMTHOD_LIST'
claus
parents: 125
diff changeset
   150
    ].
claus
parents: 125
diff changeset
   151
    s notNil ifTrue:[
claus
parents: 125
diff changeset
   152
	^ resources string:s
claus
parents: 125
diff changeset
   153
    ].
claus
parents: 125
diff changeset
   154
    ^ nil
claus
parents: 125
diff changeset
   155
132
claus
parents: 131
diff changeset
   156
    "Modified: 31.8.1995 / 19:11:39 / claus"
126
claus
parents: 125
diff changeset
   157
! !
claus
parents: 125
diff changeset
   158
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   159
!BrowserView methodsFor:'misc'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   160
85
d9713a3ca092 *** empty log message ***
claus
parents: 81
diff changeset
   161
processName
d9713a3ca092 *** empty log message ***
claus
parents: 81
diff changeset
   162
    "the name of my process - for the processMonitor only"
d9713a3ca092 *** empty log message ***
claus
parents: 81
diff changeset
   163
d9713a3ca092 *** empty log message ***
claus
parents: 81
diff changeset
   164
    ^ 'System Browser'.
d9713a3ca092 *** empty log message ***
claus
parents: 81
diff changeset
   165
!
d9713a3ca092 *** empty log message ***
claus
parents: 81
diff changeset
   166
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   167
updateCodeView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   168
    |code|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   169
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   170
    fullClass ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   171
	currentClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   172
	    code := currentClass source.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   173
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   174
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   175
	currentMethod notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   176
	    (codeView acceptAction isNil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   177
	    and:[actualClass notNil 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   178
	    and:[currentMethodCategory notNil]]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   179
		self setAcceptAndExplainActionsForMethod.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   180
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   181
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   182
	    code := currentMethod source.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   183
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   184
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   185
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   186
    codeView contents:code.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   187
    codeView modified:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   188
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   189
    self normalLabel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   190
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   191
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   192
instanceProtocol:aBoolean
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   193
    "switch between instance and class protocol"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   194
93
claus
parents: 92
diff changeset
   195
    |onToggle offToggle|
claus
parents: 92
diff changeset
   196
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   197
    showInstance ~~ aBoolean ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   198
	self checkSelectionChangeAllowed ifTrue:[
120
claus
parents: 118
diff changeset
   199
	    instanceToggle notNil ifTrue:[
claus
parents: 118
diff changeset
   200
		aBoolean ifTrue:[
claus
parents: 118
diff changeset
   201
		    offToggle := classToggle.
claus
parents: 118
diff changeset
   202
		    onToggle := instanceToggle.
claus
parents: 118
diff changeset
   203
		] ifFalse:[
claus
parents: 118
diff changeset
   204
		    onToggle := classToggle.
claus
parents: 118
diff changeset
   205
		    offToggle := instanceToggle.
claus
parents: 118
diff changeset
   206
		].
claus
parents: 118
diff changeset
   207
		onToggle turnOn.
claus
parents: 118
diff changeset
   208
		offToggle turnOff.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   209
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   210
	    showInstance := aBoolean.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   211
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   212
	    (variableListView notNil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   213
	    and:[variableListView hasSelection]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   214
		self unhilightMethodCategories.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   215
		self unhilightMethods.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   216
		variableListView deselect
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   217
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   218
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   219
	    fullProtocol ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   220
		showInstance ifTrue:[
93
claus
parents: 92
diff changeset
   221
		    actualClass := currentClassHierarchy.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   222
		] ifFalse:[
93
claus
parents: 92
diff changeset
   223
		    actualClass := currentClassHierarchy class.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   224
		].
93
claus
parents: 92
diff changeset
   225
		acceptClass := actualClass.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   226
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   227
		self updateClassList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   228
		self updateMethodCategoryListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   229
		self updateMethodListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   230
		self updateVariableList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   231
		^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   232
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   233
	    currentClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   234
		self classSelectionChanged
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   235
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   236
	    codeView modified:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   237
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   238
	    aBoolean ifTrue:[
93
claus
parents: 92
diff changeset
   239
		onToggle := classToggle.
claus
parents: 92
diff changeset
   240
		offToggle := instanceToggle
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   241
	    ] ifFalse:[
93
claus
parents: 92
diff changeset
   242
		offToggle := classToggle.
claus
parents: 92
diff changeset
   243
		onToggle := instanceToggle.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   244
	    ].
93
claus
parents: 92
diff changeset
   245
	    onToggle turnOn.
claus
parents: 92
diff changeset
   246
	    offToggle turnOff.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   247
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   248
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   249
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   250
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   251
!BrowserView methodsFor:'method stuff'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   252
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   253
methodSelectionChanged
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   254
    "method selection has changed - update dependent views"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   255
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   256
    self withWaitCursorDo:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   257
	|index cls|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   258
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   259
	self updateCodeView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   260
	self setAcceptAndExplainActionsForMethod.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   261
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   262
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   263
	 if there is any autoSearch string, do the search
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   264
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   265
	autoSearch notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   266
	    codeView searchFwd:autoSearch startingAtLine:1 col:0 ifAbsent:[]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   267
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   268
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   269
	fullProtocol ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   270
	    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   271
	     remove any bold attribute from classList
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   272
	    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   273
	    1 to:classListView list size do:[:i |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   274
		classListView attributeAt:i remove:#bold.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   275
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   276
	    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   277
	     boldify the class where this method is implemented
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   278
	    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   279
	    currentMethod notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   280
		cls := currentMethod who at:1.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   281
		index := classListView list indexOf:(cls name).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   282
		(index == 0 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   283
		 and:[cls isMeta
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   284
		 and:[cls name endsWith:'class']]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   285
		    index := classListView list indexOf:(cls name copyWithoutLast:5).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   286
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   287
		index ~~ 0 ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   288
		    classListView attributeAt:index add:#bold.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   289
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   290
		currentClass := acceptClass := cls.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   291
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   292
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   293
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   294
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   295
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   296
updateMethodListWithScroll:scroll
107
claus
parents: 106
diff changeset
   297
    self updateMethodListWithScroll:scroll keepSelection:false
claus
parents: 106
diff changeset
   298
!
claus
parents: 106
diff changeset
   299
claus
parents: 106
diff changeset
   300
updateMethodListWithScroll:scroll keepSelection:keep
claus
parents: 106
diff changeset
   301
    |selectors scr first last selection|
claus
parents: 106
diff changeset
   302
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   303
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   304
    methodListView notNil ifTrue:[
107
claus
parents: 106
diff changeset
   305
	selection := methodListView selection.
claus
parents: 106
diff changeset
   306
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   307
	currentMethodCategory notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   308
	    fullProtocol ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   309
		selectors := self listOfAllSelectorsInCategory:currentMethodCategory 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   310
					    inFullProtocolHierarchyOfClass:actualClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   311
	    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   312
		selectors := self listOfAllSelectorsInCategory:currentMethodCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   313
						       ofClass:actualClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   314
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   315
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   316
	scr := scroll.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   317
	first := methodListView firstLineShown.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   318
	first ~~ 1 ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   319
	    last := methodListView lastLineShown.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   320
	    selectors size <= (last - first + 1) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   321
		scr := true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   322
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   323
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   324
	methodListView list = selectors ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   325
	    scr ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   326
		methodListView contents:selectors
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   327
	    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   328
		methodListView setContents:selectors
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   329
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   330
	].
107
claus
parents: 106
diff changeset
   331
	keep ifTrue:[
claus
parents: 106
diff changeset
   332
	    methodListView selection:selection.
claus
parents: 106
diff changeset
   333
	]
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   334
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   335
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   336
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   337
listOfAllSelectorsInCategory:aCategory ofClass:aClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   338
    "answer a list of all selectors in a given method category 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   339
     of the argument, aClass"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   340
124
claus
parents: 123
diff changeset
   341
    |newList searchCategory all p|
114
claus
parents: 111
diff changeset
   342
claus
parents: 111
diff changeset
   343
    all := (aCategory = '* all *').
claus
parents: 111
diff changeset
   344
    (aCategory = '* no category *') ifTrue:[
claus
parents: 111
diff changeset
   345
	searchCategory := nil
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   346
    ] ifFalse:[
114
claus
parents: 111
diff changeset
   347
	searchCategory := aCategory
claus
parents: 111
diff changeset
   348
    ].
claus
parents: 111
diff changeset
   349
    newList := OrderedCollection new.
claus
parents: 111
diff changeset
   350
    aClass methodArray with:aClass selectorArray do:[:aMethod :selector |
125
claus
parents: 124
diff changeset
   351
	|sel how|
114
claus
parents: 111
diff changeset
   352
claus
parents: 111
diff changeset
   353
	(all or:[aMethod category = searchCategory]) ifTrue:[
claus
parents: 111
diff changeset
   354
	    sel := selector.
124
claus
parents: 123
diff changeset
   355
	    (p := aMethod privacy) ~~ #public ifTrue:[
125
claus
parents: 124
diff changeset
   356
		how := '    (* ' , p , ' *)'.
114
claus
parents: 111
diff changeset
   357
	    ].
claus
parents: 111
diff changeset
   358
	    aMethod isWrapped ifTrue:[
125
claus
parents: 124
diff changeset
   359
		how := ' !!'
114
claus
parents: 111
diff changeset
   360
	    ].
claus
parents: 111
diff changeset
   361
	    aMethod isInvalid ifTrue:[
125
claus
parents: 124
diff changeset
   362
		how := '    (** not executable **)'
114
claus
parents: 111
diff changeset
   363
	    ].
125
claus
parents: 124
diff changeset
   364
	    aMethod isLazyMethod ifTrue:[
claus
parents: 124
diff changeset
   365
"/                how := '    (lazy)'
claus
parents: 124
diff changeset
   366
	    ] ifFalse:[
claus
parents: 124
diff changeset
   367
		(aMethod code isNil 
claus
parents: 124
diff changeset
   368
		and:[aMethod byteCode isNil]) ifTrue:[
claus
parents: 124
diff changeset
   369
		    how := '    (** unloaded **)'
claus
parents: 124
diff changeset
   370
		]
claus
parents: 124
diff changeset
   371
	    ].
claus
parents: 124
diff changeset
   372
	    how notNil ifTrue:[sel := sel , how].
114
claus
parents: 111
diff changeset
   373
	    newList add:sel
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   374
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   375
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   376
    (newList size == 0) ifTrue:[^ nil].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   377
    ^ newList sort
125
claus
parents: 124
diff changeset
   378
claus
parents: 124
diff changeset
   379
    "Modified: 28.8.1995 / 21:53:34 / claus"
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   380
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   381
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   382
methodSelection:lineNr
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   383
    "user clicked on a method line - show code"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   384
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   385
    |selectorString selectorSymbol|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   386
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   387
    (fullProtocol not and:[currentClass isNil]) ifTrue:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   388
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   389
    selectorString := methodListView selectionValue.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   390
    "
107
claus
parents: 106
diff changeset
   391
     kludge: extract real selector
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   392
    "
107
claus
parents: 106
diff changeset
   393
    selectorString := selectorString withoutSpaces upTo:(Character space).
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   394
    selectorSymbol := selectorString asSymbol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   395
    fullProtocol ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   396
	currentMethod := currentSelector := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   397
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   398
	 search which class implements the selector
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   399
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   400
	self classesInFullProtocolHierarchy:actualClass do:[:c |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   401
	    (currentMethod isNil 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   402
	     and:[c implements:selectorSymbol]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   403
		currentSelector := selectorSymbol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   404
		currentMethod := c compiledMethodAt:selectorSymbol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   405
		acceptClass := c
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   406
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   407
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   408
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   409
	currentSelector := selectorSymbol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   410
	currentMethod := actualClass compiledMethodAt:selectorSymbol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   411
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   412
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   413
    methodCategoryListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   414
	currentMethod notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   415
	    (currentMethodCategory = currentMethod category) ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   416
		currentMethodCategory := currentMethod category.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   417
		methodCategoryListView selectElement:currentMethodCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   418
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   419
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   420
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   421
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   422
    self methodSelectionChanged
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   423
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   424
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   425
updateMethodList
107
claus
parents: 106
diff changeset
   426
    self updateMethodListWithScroll:true keepSelection:false
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   427
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   428
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   429
checkMethodSelected
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   430
    currentMethod isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   431
	self warn:'select a method first'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   432
	^ false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   433
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   434
    ^ true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   435
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   436
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   437
template
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   438
    "return a method definition template"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   439
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   440
    ^ 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   441
'message selector and argument names
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   442
    "comment stating purpose of message"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   443
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   444
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   445
    |temporaries|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   446
    statements
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   447
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   448
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   449
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   450
 change above template into real code.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   451
 Then ''accept'' either via the menu 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   452
 or via the keyboard (usually CMD-A).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   453
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   454
 You do not need this template; you can also
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   455
 select any existing methods code, change it,
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   456
 and finally ''accept''.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   457
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   458
'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   459
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   460
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   461
switchToMethodNamed:matchString
129
claus
parents: 126
diff changeset
   462
    "switch (in the current class) to a method named matchString.
claus
parents: 126
diff changeset
   463
     If there are more than one matches, switch to the first."
claus
parents: 126
diff changeset
   464
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   465
    |aSelector method cat index classToSearch selectors|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   466
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   467
    currentClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   468
	showInstance ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   469
	    classToSearch := currentClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   470
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   471
	    classToSearch := currentClass class
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   472
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   473
	selectors := classToSearch selectorArray.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   474
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   475
	((matchString ~= '*') and:[matchString includesMatchCharacters]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   476
	    index := selectors findFirst:[:element | matchString match:element]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   477
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   478
	    index := selectors indexOf:matchString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   479
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   480
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   481
	(index ~~ 0) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   482
	    aSelector := selectors at:index.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   483
	    method := classToSearch methodArray at:index.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   484
	    cat := method category.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   485
	    cat isNil ifTrue:[cat := '* all *'].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   486
	    methodCategoryListView selectElement:cat.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   487
	    currentMethodCategory := cat.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   488
	    self methodCategorySelectionChanged.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   489
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   490
	    currentMethod := classToSearch compiledMethodAt:aSelector.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   491
	    currentMethod notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   492
		currentSelector := aSelector.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   493
		methodListView selectElement:aSelector.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   494
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   495
	    self methodSelectionChanged
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   496
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   497
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   498
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   499
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   500
listOfAllSelectorsInCategory:aCategory inFullProtocolHierarchyOfClass:aClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   501
    "answer a list of all selectors in a given method category 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   502
     of the argument, aClass and its superclasses.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   503
     Used with fullProtocol browsing."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   504
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   505
    |newList|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   506
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   507
    newList := Set new.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   508
    self classesInFullProtocolHierarchy:aClass do:[:c |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   509
	|searchCategory|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   510
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   511
	(aCategory = '* all *') ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   512
	    newList addAll:(c selectorArray)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   513
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   514
	    (aCategory = '* no category *') ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   515
		searchCategory := nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   516
	    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   517
		searchCategory := aCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   518
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   519
	    c methodArray with:c selectorArray do:[:aMethod :selector |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   520
		(aMethod category = searchCategory) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   521
		    newList add:selector
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   522
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   523
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   524
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   525
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   526
    (newList size == 0) ifTrue:[^ nil].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   527
    ^ newList asOrderedCollection sort
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   528
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   529
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   530
switchToAnyMethodNamed:aString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   531
    |aSelector classToStartSearch aClass nm|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   532
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   533
    aSelector := aString asSymbol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   534
    currentClass isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   535
	currentClassHierarchy notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   536
	    classToStartSearch := currentClassHierarchy
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   537
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   538
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   539
	classToStartSearch := currentClass 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   540
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   541
    classToStartSearch notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   542
	showInstance ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   543
	    classToStartSearch := classToStartSearch class
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   544
	].
93
claus
parents: 92
diff changeset
   545
	aClass := classToStartSearch whichClassIncludesSelector:aSelector.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   546
	aClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   547
	    nm := aClass name.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   548
	    showInstance ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   549
		((nm ~= 'Metaclass') and:[nm endsWith:'class']) ifTrue:[
106
claus
parents: 105
diff changeset
   550
		    nm := nm copyWithoutLast:5 "copyTo:(nm size - 5)"
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   551
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   552
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   553
	    self switchToClassNamed:nm.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   554
	    self switchToMethodNamed:aString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   555
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   556
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   557
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   558
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   559
!BrowserView methodsFor:'private'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   560
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   561
checkSelectionChangeAllowed
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   562
    "return true, if selection change is ok;
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   563
     its not ok, if code has been changed.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   564
     in this case, return the result of a user query"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   565
107
claus
parents: 106
diff changeset
   566
    |action|
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   567
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   568
    codeView modified ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   569
	^ true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   570
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   571
    action := OptionBox 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   572
		  request:(resources at:'text has not been accepted.\\Your modifications will be lost when continuing.') withCRs
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   573
		  label:(resources string:'Attention')
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   574
		  form:(WarningBox iconBitmap)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   575
		  buttonLabels:(resources array:#('abort' 'accept' 'continue'))
108
claus
parents: 107
diff changeset
   576
		  values:#(false #accept true)
claus
parents: 107
diff changeset
   577
		  default:true.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   578
    action ~~ #accept ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   579
	^ action
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   580
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   581
    codeView accept. ^ true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   582
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   583
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   584
normalLabel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   585
    "set the normal (inactive) window- and icon labels"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   586
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   587
    |l il|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   588
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   589
    myLabel notNil ifTrue:[
110
claus
parents: 109
diff changeset
   590
	"if I have been given an explicit label,
claus
parents: 109
diff changeset
   591
	 and its not the default, take that one"
claus
parents: 109
diff changeset
   592
claus
parents: 109
diff changeset
   593
	myLabel ~= 'System Browser' ifTrue:[
claus
parents: 109
diff changeset
   594
	    l := il := myLabel
claus
parents: 109
diff changeset
   595
	]
claus
parents: 109
diff changeset
   596
    ].
claus
parents: 109
diff changeset
   597
    l isNil ifTrue:[    
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   598
	l := resources string:'System Browser'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   599
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   600
	currentClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   601
	    l := l, ': ', currentClass name.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   602
	    classListView isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   603
		currentSelector notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   604
		    l := l , ' ' ,  currentSelector
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   605
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   606
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   607
	    il := currentClass name
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   608
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   609
	    il := l.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   610
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   611
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   612
    self label:l.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   613
    self iconLabel:il.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   614
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   615
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   616
setDoitActionForClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   617
    "tell the codeView what to do on doIt"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   618
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   619
    "set self for doits. This allows accessing the current class
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   620
     as self, and access to the class variables by name.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   621
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   622
    codeView doItAction:[:theCode |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   623
	|compiler|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   624
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   625
	currentClass isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   626
	    compiler := Compiler
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   627
	] ifFalse:[
108
claus
parents: 107
diff changeset
   628
	    compiler := currentClass evaluatorClass
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   629
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   630
	compiler 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   631
	    evaluate:theCode 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   632
	    in:nil 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   633
	    receiver:currentClass 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   634
	    notifying:codeView 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   635
	    logged:false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   636
	    ifFail:nil 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   637
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   638
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   639
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   640
setAcceptAndExplainActionsForMethod
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   641
    "tell the codeView what to do on accept and explain"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   642
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   643
    codeView acceptAction:[:theCode |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   644
	|cat cls|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   645
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   646
	codeView cursor:Cursor execute.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   647
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   648
	(cat := currentMethodCategory) = '* all *' ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   649
	    "must check from which category this code came from ...
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   650
	     ... thanks to Arno for pointing this out"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   651
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   652
	    cat := self askForMethodCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   653
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   654
	(cat notNil and:[cat notEmpty]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   655
	    fullProtocol ifTrue:[
93
claus
parents: 92
diff changeset
   656
		cls := acceptClass "/actualClass whichClassIncludesSelector:currentSelector.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   657
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   658
	    cls isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   659
		cls := actualClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   660
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   661
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   662
	    Object abortSignal catch:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   663
		lockUpdates := true.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   664
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   665
		actualClass compilerClass 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   666
		    compile:theCode asString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   667
		    forClass:cls
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   668
		    inCategory:cat 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   669
		    notifying:codeView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   670
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   671
		codeView modified:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   672
		self updateMethodListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   673
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   674
	    lockUpdates := false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   675
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   676
	codeView cursor:Cursor normal.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   677
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   678
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   679
    codeView explainAction:[:theCode :theSelection |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   680
	self showExplanation:(Explainer 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   681
				explain:theSelection 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   682
				in:theCode
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   683
				forClass:actualClass)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   684
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   685
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   686
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   687
enterBoxTitle:title okText:okText
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   688
    "convenient method: setup enterBox"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   689
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   690
    |box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   691
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   692
    box := EnterBox new.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   693
    box title:(resources string:title) okText:(resources string:okText).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   694
    ^ box
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   695
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   696
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   697
selectorToSearchFor
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   698
    "look in codeView and methodListView for a search-string when searching for selectors"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   699
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   700
    |sel t|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   701
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   702
    sel := codeView selection.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   703
    sel notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   704
	sel := sel asString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   705
	t := Parser selectorInExpression:sel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   706
	t notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   707
	    sel := t
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   708
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   709
	sel := sel withoutSpaces.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   710
	sel == #>> ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   711
	    "oops - thats probably not what we want here ..."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   712
	    self extractClassAndSelectorFromSelectionInto:[:c :s :m |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   713
		sel := s
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   714
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   715
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   716
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   717
	methodListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   718
	    sel := methodListView selectionValue
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   719
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   720
	    classMethodListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   721
		sel := classMethodListView selectionValue.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   722
		sel notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   723
		    sel := self selectorFromClassMethodString:sel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   724
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   725
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   726
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   727
	sel notNil ifTrue:[
107
claus
parents: 106
diff changeset
   728
	    sel := sel withoutSpaces upTo:(Character space)
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   729
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   730
	    sel := ''
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   731
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   732
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   733
    ^ sel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   734
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   735
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   736
setSearchPattern:aString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   737
    codeView setSearchPattern:aString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   738
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   739
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   740
listBoxTitle:title okText:okText list:aList
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   741
    "convenient method: setup a listBox & return it"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   742
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   743
    |box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   744
129
claus
parents: 126
diff changeset
   745
    box := ListSelectionBox 
claus
parents: 126
diff changeset
   746
		title:(resources string:title)
claus
parents: 126
diff changeset
   747
		okText:(resources string:okText)
claus
parents: 126
diff changeset
   748
		action:nil.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   749
    box list:aList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   750
    ^ box
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   751
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   752
129
claus
parents: 126
diff changeset
   753
listBoxForCodeSelectionTitle:title okText:okText
claus
parents: 126
diff changeset
   754
    "convenient method: setup listBox with text from codeview"
claus
parents: 126
diff changeset
   755
claus
parents: 126
diff changeset
   756
    |sel box|
claus
parents: 126
diff changeset
   757
claus
parents: 126
diff changeset
   758
    box := self listBoxTitle:title okText:okText list:nil. 
claus
parents: 126
diff changeset
   759
    sel := codeView selection.
claus
parents: 126
diff changeset
   760
    sel notNil ifTrue:[
claus
parents: 126
diff changeset
   761
	box initialText:(sel asString withoutSeparators)
claus
parents: 126
diff changeset
   762
    ].
claus
parents: 126
diff changeset
   763
    ^ box
claus
parents: 126
diff changeset
   764
!
claus
parents: 126
diff changeset
   765
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   766
showExplanation:someText
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   767
    "show explanation from Parser"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   768
108
claus
parents: 107
diff changeset
   769
    self information:someText
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   770
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   771
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   772
stringToSearchFor
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   773
    "look in codeView and methodListView for a search-string when searching for classes/names"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   774
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   775
    |sel|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   776
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   777
    sel := codeView selection.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   778
    sel notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   779
	sel := sel asString withoutSpaces
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   780
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   781
	sel isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   782
	    currentClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   783
		sel := currentClass name
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   784
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   785
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   786
	sel notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   787
	    sel := sel withoutSpaces
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   788
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   789
	    sel := ''
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   790
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   791
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   792
    ^ sel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   793
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   794
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   795
findClassOfVariable:aVariableName accessWith:aSelector
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   796
    "this method returns the class, in which a variable
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   797
     is defined; 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   798
     needs either #instVarNames or #classVarNames as aSelector."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   799
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   800
    |cls homeClass|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   801
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   802
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   803
     first, find the class, where the variable is declared
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   804
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   805
    cls := currentClass.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   806
    [cls notNil] whileTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   807
	((cls perform:aSelector) includes:aVariableName) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   808
	    homeClass := cls.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   809
	    cls := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   810
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   811
	    cls := cls superclass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   812
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   813
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   814
    homeClass isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   815
	"nope, must be one below ... (could optimize a bit, by searching down
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   816
	 for the declaring class ...
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   817
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   818
	homeClass := currentClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   819
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   820
"/        Transcript showCr:'starting search in ' , homeClass name.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   821
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   822
    ^ homeClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   823
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   824
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   825
enterBoxForSearchSelectorTitle:title
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   826
    "convenient method: setup enterBox with text from codeView or selected
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   827
     method for browsing based on a selector"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   828
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   829
    |box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   830
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   831
    box := self enterBoxTitle:title okText:'search'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   832
    box initialText:(self selectorToSearchFor).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   833
    ^ box
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   834
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   835
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   836
enterBoxForCodeSelectionTitle:title okText:okText
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   837
    "convenient method: setup enterBox with text from codeview"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   838
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   839
    |sel box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   840
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   841
    box := self enterBoxTitle:(resources string:title) okText:(resources string:okText).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   842
    sel := codeView selection.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   843
    sel notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   844
	box initialText:(sel asString withoutSeparators)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   845
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   846
    ^ box
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   847
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   848
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   849
classesInFullProtocolHierarchy:aClass do:aBlock
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   850
    "evaluate aBlock for all non-striked out classes in
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   851
     the hierarchy"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   852
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   853
    |index|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   854
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   855
    index := (classListView list size).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   856
    aClass withAllSuperclasses do:[:c |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   857
	(classListView isInSelection:index) ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   858
	    aBlock value:c
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   859
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   860
	index := index - 1
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   861
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   862
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   863
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   864
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   865
enterBoxForBrowseTitle:title action:aBlock
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   866
    "convenient method: setup enterBox with text from codeView or selected
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   867
     method for method browsing based on className/variable"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   868
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   869
    |box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   870
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   871
    box := self enterBoxTitle:title okText:'browse'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   872
    box initialText:(self stringToSearchFor).
93
claus
parents: 92
diff changeset
   873
    box action:[:aString | 
claus
parents: 92
diff changeset
   874
	aString notEmpty ifTrue:[
claus
parents: 92
diff changeset
   875
	    self withWaitCursorDo:[aBlock value:aString]
claus
parents: 92
diff changeset
   876
	].
claus
parents: 92
diff changeset
   877
    ].
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   878
    box showAtPointer
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   879
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   880
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   881
askAndBrowseMethodCategory:title action:aBlock
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   882
    "convenient method: setup enterBox with initial being current method category"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   883
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   884
    |sel box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   885
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   886
    box := self enterBoxTitle:title okText:'browse'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   887
    sel := codeView selection.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   888
    sel isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   889
	currentMethodCategory notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   890
	    sel := currentMethodCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   891
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   892
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   893
    sel notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   894
	box initialText:(sel asString withoutSpaces)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   895
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   896
    box action:[:aString | self withWaitCursorDo:[aBlock value:aString]].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   897
    box showAtPointer
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   898
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   899
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   900
classHierarchyDo:aBlock
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   901
    "eavluate the 2-arg block for every class,
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   902
     starting at Object; passing class and nesting level to the block."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   903
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   904
    |classes s classDict l|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   905
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   906
    classes := Smalltalk allClasses.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   907
    classDict := IdentityDictionary new:classes size.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   908
    classes do:[:aClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   909
	s := aClass superclass.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   910
	s notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   911
	    l := classDict at:s ifAbsent:[nil].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   912
	    l isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   913
		l := OrderedCollection new:5.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   914
		classDict at:s put:l
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   915
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   916
	    l add:aClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   917
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   918
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   919
    self classHierarchyOf:Object level:0 do:aBlock using:classDict
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   920
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   921
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   922
warnLabel:what
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   923
    "set the title for some warning"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   924
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   925
    self label:('System Browser WARNING: ' , what)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   926
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   927
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   928
classHierarchyOf:aClass level:level do:aBlock using:aDictionary
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   929
    "evaluate the 2-arg block for every subclass of aClass,
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   930
     passing class and nesting level to the block."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   931
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   932
    |names subclasses|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   933
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   934
    aBlock value:aClass value:level.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   935
    subclasses := aDictionary at:aClass ifAbsent:[nil].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   936
    (subclasses size == 0) ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   937
	names := subclasses collect:[:class | class name].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   938
	names sortWith:subclasses.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   939
	subclasses do:[:aSubClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   940
	    self classHierarchyOf:aSubClass level:(level + 1) do:aBlock using:aDictionary
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   941
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   942
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   943
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   944
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   945
compileCode:someCode
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   946
    (ReadStream on:someCode) fileIn
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   947
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   948
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   949
extractClassAndSelectorFromSelectionInto:aBlock
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   950
    "given a string which can be either 'class>>sel' or
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   951
     'class sel', extract className and selector, and call aBlock with
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   952
    the result."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   953
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   954
    |sel clsName isMeta sep s|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   955
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   956
    sel := codeView selection.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   957
    sel notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   958
	sel := sel asString withoutSeparators.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   959
	('*>>*' match:sel) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   960
	    sep := $>
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   961
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   962
	    ('* *' match:sel) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   963
		sep := Character space
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   964
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   965
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   966
	sep notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   967
	    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   968
	     extract class/sel from selection
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   969
	    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   970
	    s := ReadStream on:sel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   971
	    clsName := s upTo:sep.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   972
	    [s peek == sep] whileTrue:[s next].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   973
	    sel := s upToEnd.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   974
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   975
	    (clsName endsWith:'class') ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   976
		isMeta := true.
106
claus
parents: 105
diff changeset
   977
		clsName := clsName copyWithoutLast:5 "copyTo:(clsName size - 5)"
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   978
	    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   979
		isMeta := false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   980
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   981
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   982
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   983
    aBlock value:clsName value:sel value:isMeta
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   984
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   985
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   986
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   987
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   988
busyLabel:what with:someArgument
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   989
    "set the title for some warning"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   990
106
claus
parents: 105
diff changeset
   991
    self label:('System Browser - ' , (resources string:what with:someArgument))
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   992
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   993
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   994
classesInHierarchy:aClass do:aBlock
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   995
    |index|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   996
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   997
    index := (classListView list size).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   998
    aClass withAllSuperclasses do:[:c |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
   999
	(classListView isInSelection:index) ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1000
	    aBlock value:c
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1001
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1002
	index := index - 1
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1003
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1004
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1005
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1006
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1007
askForMethodCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1008
    |someCategories box txt|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1009
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1010
    someCategories := actualClass categories sort.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1011
    box := self listBoxTitle:'accept in which method category ?' okText:'accept' list:someCategories.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1012
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1013
    lastMethodCategory isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1014
	txt := 'new methods'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1015
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1016
	txt := lastMethodCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1017
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1018
    box initialText:txt.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1019
    box action:[:aString | ^ aString ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1020
    box showAtPointer.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1021
    ^ nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1022
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1023
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1024
askForSelectorTitle:title
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1025
    "convenient method: setup enterBox with text from codeView or selected
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1026
     method for browsing based on a selector. Set action and launch box"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1027
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1028
    |box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1029
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1030
    box := self enterBoxTitle:title okText:'browse'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1031
    box initialText:(self selectorToSearchFor).
93
claus
parents: 92
diff changeset
  1032
    box action:[:aString | aString isEmpty ifTrue:[^ nil]. ^ aString].
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1033
    box showAtPointer.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1034
    ^ nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1035
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1036
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1037
askForSelectorTitle:title openWith:selector
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1038
    "convenient method: setup enterBox with text from codeView or selected
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1039
     method for browsing based on a selector. Set action and launch box"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1040
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1041
    |string|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1042
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1043
    string := self askForSelectorTitle:title.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1044
    string notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1045
	self withCursor:(Cursor questionMark) do:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1046
	    SystemBrowser perform:selector with:string
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1047
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1048
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1049
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1050
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1051
askForSelectorTitle:title openWith:selector and:arg
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1052
    "convenient method: setup enterBox with text from codeView or selected
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1053
     method for browsing based on a selector. Set action and launch box"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1054
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1055
    |string|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1056
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1057
    string := self askForSelectorTitle:title.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1058
    string notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1059
	self withCursor:(Cursor questionMark) do:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1060
	    SystemBrowser perform:selector with:string with:arg
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1061
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1062
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1063
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1064
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1065
!BrowserView methodsFor:'method category stuff'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1066
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1067
updateMethodCategoryListWithScroll:scroll
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1068
    |categories|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1069
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1070
    methodCategoryListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1071
	fullProtocol ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1072
	    currentClassHierarchy notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1073
		categories := self listOfAllMethodCategoriesInFullProtocolHierarchy:actualClass 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1074
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1075
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1076
	    currentClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1077
		categories := self listOfAllMethodCategoriesInClass:actualClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1078
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1079
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1080
	methodCategoryListView list = categories ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1081
	    scroll ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1082
		methodCategoryListView contents:categories
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1083
	    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1084
		methodCategoryListView setContents:categories
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1085
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1086
	    currentMethodCategory notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1087
		methodCategoryListView selectElement:currentMethodCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1088
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1089
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1090
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1091
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1092
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1093
listOfAllMethodCategoriesInClass:aClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1094
    "answer a list of all method categories of the argument, aClass"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1095
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1096
    |newList|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1097
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  1098
    newList := Set new.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1099
    aClass methodArray do:[:aMethod |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1100
	|cat|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1101
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1102
	cat := aMethod category.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1103
	cat isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1104
	    cat := '* no category *'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1105
	].
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  1106
	newList add:cat
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1107
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1108
    (newList size == 0) ifTrue:[^ nil].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1109
    newList add:'* all *'.
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  1110
    ^ newList asOrderedCollection sort
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1111
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1112
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1113
methodCategorySelection:lineNr
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1114
    "user clicked on a method category line - show selectors"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1115
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1116
    |oldSelector|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1117
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1118
"/    oldSelector := currentSelector.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1119
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1120
    (fullProtocol not and:[currentClass isNil]) ifTrue:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1121
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1122
    currentMethodCategory := methodCategoryListView selectionValue.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1123
    self methodCategorySelectionChanged.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1124
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1125
    "if there is only one method, show it right away"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1126
    methodListView list size == 1 ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1127
	methodListView selection:1.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1128
	self methodSelection:1
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1129
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1130
	oldSelector notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1131
	    methodListView selectElement:oldSelector.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1132
	    methodListView hasSelection ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1133
		self methodSelection:methodListView selection.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1134
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1135
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1136
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1137
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1138
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1139
methodCategorySelectionChanged
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1140
    "method category selection has changed - update dependant views"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1141
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1142
    self withWaitCursorDo:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1143
	currentMethod := currentSelector := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1144
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1145
	self updateMethodList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1146
	self updateCodeView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1147
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1148
	currentMethodCategory notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1149
	    methodCategoryListView selectElement:currentMethodCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1150
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1151
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1152
	self setAcceptAndExplainActionsForMethod.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1153
	self hilightMethodsInMethodCategoryList:false inMethodList:true.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1154
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1155
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1156
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1157
updateMethodCategoryList
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1158
    self updateMethodCategoryListWithScroll:true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1159
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1160
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1161
listOfAllMethodCategoriesInFullProtocolHierarchy:aClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1162
    "answer a list of all method categories of the argument, aClass,
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1163
     and all of its superclasses.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1164
     Used with fullProtocol browsing."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1165
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1166
    |newList|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1167
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  1168
    newList := Set new.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1169
    self classesInFullProtocolHierarchy:aClass do:[:c |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1170
	|cat|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1171
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1172
	c methodArray do:[:aMethod |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1173
	    cat := aMethod category.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1174
	    cat isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1175
		cat := '* no category *'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1176
	    ].
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  1177
	    newList add:cat
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1178
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1179
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1180
    (newList size == 0) ifTrue:[^ nil].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1181
    newList add:'* all *'.
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  1182
    ^ newList asOrderedCollection sort
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1183
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1184
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1185
checkMethodCategorySelected
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1186
    currentMethodCategory isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1187
	self warn:'select a method category first'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1188
	^ false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1189
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1190
    ^ true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1191
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1192
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1193
whenMethodCategorySelected:aBlock
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1194
    self checkMethodCategorySelected ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1195
	self withWaitCursorDo:aBlock
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1196
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1197
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1198
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1199
copyMethodsFromClass:aClassName
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1200
    |class box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1201
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1202
    currentClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1203
	class := Smalltalk classNamed:aClassName.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1204
	class isBehavior ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1205
	    self warn:'no class named %1' with:aClassName.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1206
	    ^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1207
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1208
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1209
	showInstance ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1210
	    class := class class
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1211
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1212
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1213
	"show enterbox for category to copy from"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1214
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1215
	box := self enterBoxTitle:'name of category to copy from (matchpattern allowed, * for all):'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1216
			   okText:'copy'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1217
	box action:[:aString | self copyMethodsFromClass:class category:aString].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1218
	box showAtPointer.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1219
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1220
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1221
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1222
copyMethodsFromClass:class category:category
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1223
    currentClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1224
	Object abortSignal catch:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1225
	    class methodArray do:[:aMethod |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1226
		|source|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1227
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1228
		(category match:aMethod category) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1229
		    source := aMethod source.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1230
		    codeView contents:source.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1231
		    codeView modified:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1232
		    actualClass compilerClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1233
			 compile:source 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1234
			 forClass:actualClass 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1235
			 inCategory:aMethod category
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1236
			 notifying:codeView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1237
		    self updateMethodCategoryListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1238
		    self updateMethodListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1239
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1240
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1241
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1242
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1243
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1244
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1245
newMethodCategory:aString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1246
    |categories|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1247
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1248
    currentClass isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1249
	^ self warn:'select/create a class first'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1250
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1251
    categories := methodCategoryListView list.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1252
    categories isNil ifTrue:[categories := OrderedCollection new].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1253
    (categories includes:aString) ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1254
	categories add:aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1255
	categories sort.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1256
	methodCategoryListView contents:categories
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1257
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1258
    currentMethodCategory := aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1259
    self methodCategorySelectionChanged
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1260
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1261
132
claus
parents: 131
diff changeset
  1262
!BrowserView methodsFor:'change & update'!
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1263
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1264
update:something with:someArgument from:changedObject
93
claus
parents: 92
diff changeset
  1265
    |list|
claus
parents: 92
diff changeset
  1266
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1267
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1268
     avoid update/warn after my own changes
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1269
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1270
    lockUpdates == true ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1271
"/         'ignored my change' printNL.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1272
	^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1273
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1274
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1275
"/ changedObject print. ' ' print. someArgument print. ' ' print.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1276
"/ something printNL.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1277
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1278
    (changedObject == Smalltalk) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1279
	something == #newClass ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1280
	    (currentClass notNil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1281
	    and:[someArgument name = currentClass name]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1282
		"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1283
		 the current class was autoloaded
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1284
		"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1285
		self warnLabel:'the selected class has changed'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1286
		self updateClassListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1287
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1288
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1289
	    ((someArgument category = currentClassCategory)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1290
	    or:[currentClassCategory notNil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1291
		and:[currentClassCategory startsWith:'*']]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1292
		self updateClassListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1293
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1294
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1295
	    someArgument category ~= currentClassCategory ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1296
		"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1297
		 category new ?
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1298
		"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1299
		(classCategoryListView notNil 
93
claus
parents: 92
diff changeset
  1300
		and:[(list := classCategoryListView list) notNil
claus
parents: 92
diff changeset
  1301
		and:[(list includes:someArgument category) not]])
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1302
		ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1303
		    self updateClassCategoryListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1304
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1305
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1306
	    ^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1307
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1308
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1309
	something == #classRemove ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1310
	    someArgument = currentClass ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1311
		self warnLabel:'the selected class was removed'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1312
		^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1313
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1314
	    " fall into general update "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1315
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1316
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1317
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1318
	 any other (unknown) change 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1319
	 with the Smalltalk dictionary ...
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1320
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1321
	self updateClassCategoryListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1322
	self updateClassListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1323
	^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1324
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1325
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1326
    changedObject isBehavior ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1327
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1328
	 its a class, that has changed
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1329
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1330
	(currentClass notNil 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1331
	and:[changedObject name = currentClass name]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1332
	    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1333
	     its the current class that has changed
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1334
	    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1335
	    something == #methodDictionary ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1336
		(someArgument isSymbol) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1337
		    |changedMethod|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1338
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1339
		    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1340
		     the method with selector someArgument was changed or removed
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1341
		    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1342
		    self updateMethodCategoryListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1343
		    self updateMethodListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1344
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1345
		    someArgument == currentSelector ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1346
			"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1347
			 special care here: the currently shown method has been
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1348
			 changed somehow in another browser (or via fileIn)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1349
			"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1350
			changedMethod := currentClass compiledMethodAt:currentSelector.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1351
			changedMethod isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1352
			    self warnLabel:'the method shown was removed'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1353
			    ^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1354
			].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1355
			"compare the source codes"
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  1356
			currentMethod notNil ifTrue:[
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  1357
			    changedMethod source = codeView contents ifFalse:[
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  1358
				self warnLabel:'the code shown may not up to date'.
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  1359
			    ]
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  1360
			].
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1361
			^ self    
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1362
		    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1363
		    ^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1364
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1365
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1366
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1367
	    something == #comment ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1368
		"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1369
		 the class has changed its comment; we dont care, except if
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1370
		 currently showing the comment
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1371
		"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1372
		aspect == #comment ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1373
		    self warnLabel:'the comment shown may not up to date'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1374
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1375
		^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1376
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1377
	    something == #definition ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1378
		"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1379
		 the class has changed its definition.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1380
		 Warn, except if showing a method.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1381
		"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1382
		aspect notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1383
		    self warnLabel:'the classes definition has changed'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1384
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1385
"/                ^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1386
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1387
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1388
	    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1389
	     get the class again - in case of a changed class definition,
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1390
	     we are otherwise refering to the obsolete old class
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1391
	    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1392
	    currentClass := Smalltalk at:(currentClass name asSymbol).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1393
	    showInstance ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1394
		actualClass := currentClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1395
	    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1396
		actualClass := currentClass class
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1397
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1398
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1399
	    self updateMethodCategoryListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1400
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1401
	    "dont update codeView ...."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1402
	    "self update"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1403
	    ^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1404
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1405
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1406
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1407
	 any other class has changed (but not its organization, since
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1408
	 that is cought in the above case).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1409
	 We are not interrested in it - except, if showing fullProtocol
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1410
	 or hierarchy ...
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1411
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1412
	currentClassHierarchy notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1413
	    fullProtocol ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1414
		(currentClass isSubclassOf:changedObject) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1415
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1416
	    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1417
		((currentClass isSubclassOf:changedObject)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1418
		or:[changedObject isSubclassOf:currentClass]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1419
		]                
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1420
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1421
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1422
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1423
	^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1424
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1425
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1426
    (changedObject isMethod) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1427
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1428
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1429
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1430
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1431
!BrowserView methodsFor:'initialize / release'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1432
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1433
initialize
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1434
    super initialize.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1435
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1436
    showInstance := true.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1437
    fullClass := false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1438
    fullProtocol := false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1439
    aspect := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1440
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1441
    "inform me, when Smalltalk changes"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1442
    Smalltalk addDependent:self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1443
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1444
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1445
title:someString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1446
    myLabel := someString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1447
    self label:someString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1448
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1449
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1450
realize
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1451
    |v checkBlock|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1452
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1453
    super realize.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1454
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1455
    checkBlock := [:lineNr | self checkSelectionChangeAllowed].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1456
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1457
    v := classCategoryListView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1458
    v notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1459
	v action:[:lineNr | self classCategorySelection:lineNr].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1460
	v selectConditionBlock:checkBlock.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1461
	v ignoreReselect:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1462
	v contents:(self listOfAllClassCategories).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1463
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1464
	 tell classCategoryListView to ask for the menu
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1465
	"
98
claus
parents: 95
diff changeset
  1466
	v menuHolder:self; menuPerformer:self; menuMessage:#classCategoryMenu.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1467
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1468
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1469
    v := classListView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1470
    v notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1471
	v action:[:lineNr | self classSelection:lineNr].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1472
	v selectConditionBlock:checkBlock.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1473
	v ignoreReselect:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1474
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1475
	 tell classListView to ask for the menu
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1476
	"
98
claus
parents: 95
diff changeset
  1477
	v menuHolder:self; menuPerformer:self; menuMessage:#classMenu.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1478
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1479
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1480
    v := methodCategoryListView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1481
    v notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1482
	v action:[:lineNr | self methodCategorySelection:lineNr].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1483
	v selectConditionBlock:checkBlock.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1484
	v ignoreReselect:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1485
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1486
	 tell methodCategoryListView to ask for the menu
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1487
	"
98
claus
parents: 95
diff changeset
  1488
	v menuHolder:self; menuPerformer:self; menuMessage:#methodCategoryMenu.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1489
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1490
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1491
    v := methodListView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1492
    v notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1493
	v action:[:lineNr | self methodSelection:lineNr].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1494
	v selectConditionBlock:checkBlock.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1495
	v ignoreReselect:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1496
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1497
	 tell methodListView to ask for the menu
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1498
	"
98
claus
parents: 95
diff changeset
  1499
	v menuHolder:self; menuPerformer:self; menuMessage:#methodMenu.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1500
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1501
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1502
    v := classMethodListView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1503
    v notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1504
	v action:[:lineNr | self classMethodSelection:lineNr].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1505
	v selectConditionBlock:checkBlock.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1506
	v ignoreReselect:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1507
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1508
	 tell classMethodListView to ask for the menu
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1509
	"
98
claus
parents: 95
diff changeset
  1510
	v menuHolder:self; menuPerformer:self; menuMessage:#classMethodMenu.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1511
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1512
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1513
    v := variableListView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1514
    v notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1515
	v action:[:lineNr | self variableSelection:lineNr].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1516
	v ignoreReselect:false.
98
claus
parents: 95
diff changeset
  1517
	v toggleSelect:true.
claus
parents: 95
diff changeset
  1518
	v menuHolder:self; menuPerformer:self; menuMessage:#variableListMenu.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1519
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1520
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1521
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1522
     normal browsers show the top at first;
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1523
     hierarchy and fullProtocol browsers better show the end
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1524
     initially
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1525
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1526
    currentClassHierarchy notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1527
	classListView scrollToBottom.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1528
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1529
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1530
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1531
destroy
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1532
    "relese dependant - destroy popups"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1533
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1534
    Smalltalk removeDependent:self.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1535
    currentClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1536
	currentClass removeDependent:self.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1537
	currentClass := nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1538
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1539
    super destroy
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1540
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1541
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1542
terminate
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1543
    (self checkSelectionChangeAllowed) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1544
	super terminate
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1545
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1546
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1547
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1548
autoSearch:aString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1549
    "used with class-method list browsing. If true,
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1550
     selecting an entry from the list will automatically
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1551
     search for the searchstring in the codeView"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1552
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1553
    self setSearchPattern:aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1554
    autoSearch := aString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1555
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1556
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1557
!BrowserView methodsFor:'initialize subviews'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1558
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1559
createCodeViewIn:aView at:relY
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1560
    "setup the code view"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1561
    |v|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1562
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1563
    v := HVScrollableView for:CodeView miniScrollerH:true miniScrollerV:false in:aView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1564
    v origin:(0.0 @ relY) corner:(1.0 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1565
    codeView := v scrolledView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1566
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1567
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1568
createCodeViewIn:aView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1569
    "setup the code view"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1570
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1571
    ^ self createCodeViewIn:aView at:0.25
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1572
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1573
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1574
createTogglesIn:aFrame
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1575
    "create and setup the class/instance toggles"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1576
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1577
    |h halfSpace classAction instanceAction|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1578
93
claus
parents: 92
diff changeset
  1579
    classAction := [self instanceProtocol:false].
claus
parents: 92
diff changeset
  1580
    instanceAction := [self instanceProtocol:true].
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1581
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1582
    halfSpace := ViewSpacing // 2.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1583
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1584
    instanceToggle := Toggle label:(resources at:'instance') in:aFrame.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1585
    h := instanceToggle height.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1586
    instanceToggle origin:(0.0 @ 1.0) corner:(0.5 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1587
    instanceToggle topInset:h negated.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1588
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1589
    instanceToggle turnOn.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1590
    instanceToggle pressAction:instanceAction.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1591
    instanceToggle releaseAction:classAction.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1592
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1593
    classToggle := Toggle label:(resources at:'class') in:aFrame.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1594
    h := classToggle height.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1595
    classToggle origin:(0.5 @ 1.0) corner:(1.0 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1596
    classToggle topInset:h negated.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1597
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1598
    classToggle turnOff.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1599
    classToggle pressAction:classAction.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1600
    classToggle releaseAction:instanceAction.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1601
105
claus
parents: 98
diff changeset
  1602
    styleSheet is3D ifTrue:[
81
b3b4d34c5ada *** empty log message ***
claus
parents: 79
diff changeset
  1603
	instanceToggle bottomInset:halfSpace.
b3b4d34c5ada *** empty log message ***
claus
parents: 79
diff changeset
  1604
	classToggle bottomInset:halfSpace.
b3b4d34c5ada *** empty log message ***
claus
parents: 79
diff changeset
  1605
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1606
	instanceToggle leftInset:halfSpace.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1607
	classToggle leftInset:halfSpace.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1608
	instanceToggle rightInset:ViewSpacing - halfSpace.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1609
	classToggle rightInset:ViewSpacing - halfSpace.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1610
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1611
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1612
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1613
setupForList:aList
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1614
    "setup subviews to browse methods from a list"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1615
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1616
    |vpanel v|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1617
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1618
    vpanel := VariableVerticalPanel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1619
			origin:(0.0 @ 0.0)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1620
			corner:(1.0 @ 1.0)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1621
			    in:self.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1622
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1623
    v := ScrollableView for:SelectionInListView in:vpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1624
    v origin:(0.0 @ 0.0) corner:(1.0 @ 0.25).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1625
    classMethodListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1626
    classMethodListView contents:aList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1627
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1628
    self createCodeViewIn:vpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1629
    self updateCodeView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1630
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1631
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1632
createClassListViewIn:frame
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1633
    "setup the classlist subview, with its toggles"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1634
93
claus
parents: 92
diff changeset
  1635
    |v panel|
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1636
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1637
    self createTogglesIn:frame.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1638
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1639
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1640
     oldstyle had no variableList ...
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1641
    "
93
claus
parents: 92
diff changeset
  1642
"/    v := ScrollableView for:SelectionInListView in:frame.
claus
parents: 92
diff changeset
  1643
"/    v origin:(0.0 @ 0.0)
claus
parents: 92
diff changeset
  1644
"/      extent:[frame width
claus
parents: 92
diff changeset
  1645
"/            @
claus
parents: 92
diff changeset
  1646
"/           (frame height
claus
parents: 92
diff changeset
  1647
"/            - ViewSpacing
claus
parents: 92
diff changeset
  1648
"/            - instanceToggle height
claus
parents: 92
diff changeset
  1649
"/            - instanceToggle borderWidth
claus
parents: 92
diff changeset
  1650
"/            + v borderWidth)].
claus
parents: 92
diff changeset
  1651
"/
claus
parents: 92
diff changeset
  1652
"/    classListView := v scrolledView
claus
parents: 92
diff changeset
  1653
claus
parents: 92
diff changeset
  1654
    panel := VariableVerticalPanel
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1655
		    origin:(0.0 @ 0.0)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1656
		    corner:[frame width
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1657
			    @
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1658
			    (frame height
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1659
			      - ViewSpacing
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1660
			      - instanceToggle height
81
b3b4d34c5ada *** empty log message ***
claus
parents: 79
diff changeset
  1661
			      "-" + instanceToggle borderWidth
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1662
			      + v borderWidth)]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1663
			in:frame.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1664
93
claus
parents: 92
diff changeset
  1665
    v := ScrollableView for:SelectionInListView in:panel.
claus
parents: 92
diff changeset
  1666
    v origin:(0.0 @ 0.0) corner:(1.0 @ 0.7).
claus
parents: 92
diff changeset
  1667
    classListView := v scrolledView.
claus
parents: 92
diff changeset
  1668
claus
parents: 92
diff changeset
  1669
claus
parents: 92
diff changeset
  1670
    v := ScrollableView for:SelectionInListView in:panel.
claus
parents: 92
diff changeset
  1671
    v origin:(0.0 @ 0.7) corner:(1.0 @ 1.0).
claus
parents: 92
diff changeset
  1672
claus
parents: 92
diff changeset
  1673
    variableListView := v scrolledView.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1674
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1675
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1676
setupForAll
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1677
    "create subviews for a full browser"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1678
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1679
    |vpanel hpanel frame v|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1680
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1681
    vpanel := VariableVerticalPanel origin:(0.0 @ 0.0) corner:(1.0 @ 1.0) 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1682
		  in:self.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1683
    hpanel := View origin:(0.0 @ 0.0) corner:(1.0 @ 0.25) in:vpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1684
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1685
    v := HVScrollableView for:SelectionInListView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1686
			  miniScrollerH:true miniScrollerV:false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1687
			  in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1688
    v origin:(0.0 @ 0.0) corner:(0.25 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1689
    classCategoryListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1690
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1691
    frame := View origin:(0.25 @ 0.0) corner:(0.5 @ 1.0) in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1692
    self createClassListViewIn:frame.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1693
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1694
    v := HVScrollableView for:SelectionInListView miniScrollerH:true miniScrollerV:false in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1695
    v origin:(0.5 @ 0.0) corner:(0.75 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1696
    methodCategoryListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1697
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1698
    v := HVScrollableView for:SelectionInListView miniScrollerH:true miniScrollerV:false in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1699
    v origin:(0.75 @ 0.0) corner:(1.0 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1700
    methodListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1701
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1702
    self createCodeViewIn:vpanel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1703
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1704
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1705
focusSequence
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1706
    |s|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1707
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1708
    s := OrderedCollection new.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1709
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1710
    classCategoryListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1711
	s add:classCategoryListView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1712
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1713
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1714
    classListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1715
	s add:classListView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1716
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1717
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1718
"/    variableListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1719
"/        s add:variableListView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1720
"/    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1721
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1722
    instanceToggle notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1723
	s add:instanceToggle.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1724
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1725
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1726
    methodCategoryListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1727
	s add:methodCategoryListView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1728
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1729
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1730
    methodListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1731
	s add:methodListView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1732
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1733
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1734
    classMethodListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1735
	s add:classMethodListView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1736
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1737
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1738
    s add:codeView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1739
    ^ s
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1740
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1741
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1742
setupForClass:aClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1743
    "create subviews for browsing a single class"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1744
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1745
    |vpanel hpanel frame v|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1746
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1747
    vpanel := VariableVerticalPanel origin:(0.0 @ 0.0) 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1748
				    corner:(1.0 @ 1.0)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1749
					in:self.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1750
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1751
    hpanel := View origin:(0.0 @ 0.0) corner:(1.0 @ 0.25) in:vpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1752
    frame := View origin:(0.0 @ 0.0) corner:(0.5 @ 1.0)in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1753
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1754
    self createTogglesIn:frame.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1755
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1756
    v := ScrollableView for:SelectionInListView in:frame.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1757
    v origin:(0.0 @ 0.0)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1758
      extent:[frame width
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1759
	      @
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1760
	      (frame height 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1761
	       - ViewSpacing
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1762
	       - instanceToggle height
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1763
	       - instanceToggle borderWidth
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1764
	       + v borderWidth)].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1765
    methodCategoryListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1766
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1767
    v := ScrollableView for:SelectionInListView in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1768
    v origin:(0.5 @ 0.0) corner:(1.0 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1769
    methodListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1770
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1771
    self createCodeViewIn:vpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1772
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1773
    self switchToClass:aClass.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1774
    actualClass := acceptClass := aClass.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1775
    self updateMethodCategoryList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1776
    self updateMethodList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1777
    self updateCodeView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1778
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1779
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1780
setupForClassHierarchy:aClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1781
    "setup subviews to browse a class hierarchy"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1782
108
claus
parents: 107
diff changeset
  1783
    |vpanel hpanel frame v cls|
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1784
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1785
    vpanel := VariableVerticalPanel origin:(0.0 @ 0.0)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1786
				    corner:(1.0 @ 1.0)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1787
					in:self.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1788
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1789
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1790
     notice: we use a different ratio here
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1791
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1792
    hpanel := View origin:(0.0 @ 0.0) corner:(1.0 @ 0.4) in:vpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1793
    frame := View origin:(0.0 @ 0.0) corner:(0.33 @ 1.0) in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1794
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1795
    self createClassListViewIn:frame.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1796
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1797
    v := ScrollableView for:SelectionInListView in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1798
    v origin:(0.33 @ 0.0) corner:(0.66 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1799
    methodCategoryListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1800
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1801
    v := ScrollableView for:SelectionInListView in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1802
    v origin:(0.66 @ 0.0) corner:(1.0 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1803
    methodListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1804
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1805
    self createCodeViewIn:vpanel at:0.4.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1806
108
claus
parents: 107
diff changeset
  1807
    cls := aClass.
claus
parents: 107
diff changeset
  1808
    cls isMeta ifTrue:[
claus
parents: 107
diff changeset
  1809
	cls := cls soleInstance
claus
parents: 107
diff changeset
  1810
    ].
claus
parents: 107
diff changeset
  1811
    currentClassHierarchy := currentClass := actualClass := cls.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1812
    self updateClassList.
92
claus
parents: 85
diff changeset
  1813
    classListView selectElement:aClass name; makeSelectionVisible.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1814
    self updateMethodCategoryList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1815
    self updateMethodList.
108
claus
parents: 107
diff changeset
  1816
    self updateCodeView.
claus
parents: 107
diff changeset
  1817
claus
parents: 107
diff changeset
  1818
    aClass isMeta ifTrue:[
claus
parents: 107
diff changeset
  1819
	self instanceProtocol:false
claus
parents: 107
diff changeset
  1820
    ].
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1821
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1822
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1823
setupForFullClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1824
    "setup subviews to browse a class as full text"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1825
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1826
    |vpanel hpanel v|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1827
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1828
    vpanel := VariableVerticalPanel origin:(0.0 @ 0.0)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1829
				    corner:(1.0 @ 1.0)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1830
					in:self.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1831
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1832
    hpanel := View origin:(0.0 @ 0.0) corner:(1.0 @ 0.25) in:vpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1833
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1834
    v := ScrollableView for:SelectionInListView in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1835
    v origin:(0.0 @ 0.0) corner:(0.5 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1836
    classCategoryListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1837
    classCategoryListView contents:(self listOfAllClassCategories).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1838
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1839
    v := ScrollableView for:SelectionInListView in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1840
    v origin:(0.5 @ 0.0) corner:(1.0 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1841
    classListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1842
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1843
    self createCodeViewIn:vpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1844
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1845
    fullClass := true.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1846
    self updateCodeView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1847
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1848
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1849
setupForClassCategory:aClassCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1850
    "setup subviews to browse a class category"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1851
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1852
    |vpanel hpanel frame v|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1853
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1854
    vpanel := VariableVerticalPanel origin:(0.0 @ 0.0) 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1855
				    corner:(1.0 @ 1.0)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1856
					in:self.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1857
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1858
    hpanel := View origin:(0.0 @ 0.0) corner:(1.0 @ 0.25) in:vpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1859
    frame  := View origin:(0.0 @ 0.0) corner:(0.33 @ 1.0) in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1860
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1861
    self createClassListViewIn:frame.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1862
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1863
    v := ScrollableView for:SelectionInListView in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1864
    v origin:(0.33 @ 0.0) corner:(0.66 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1865
    methodCategoryListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1866
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1867
    v := ScrollableView for:SelectionInListView in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1868
    v origin:(0.66 @ 0.0) corner:(1.0 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1869
    methodListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1870
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1871
    self createCodeViewIn:vpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1872
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1873
    currentClassCategory := aClassCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1874
    self updateClassList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1875
    self updateMethodCategoryList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1876
    self updateMethodList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1877
    self updateCodeView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1878
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1879
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1880
setupForClass:aClass selector:selector
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1881
    "setup subviews to browse a single method"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1882
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1883
    |v|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1884
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1885
    v := ScrollableView for:CodeView in:self.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1886
    v origin:(0.0 @ 0.0) corner:(1.0 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1887
    codeView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1888
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1889
    currentClassCategory := aClass category.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1890
    self switchToClass:aClass.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1891
    actualClass := acceptClass := aClass.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1892
    currentSelector := selector.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1893
    currentMethod := currentClass compiledMethodAt:selector.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1894
    currentMethodCategory := currentMethod category.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1895
    self updateCodeView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1896
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1897
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1898
setupForClassList:aList
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1899
    "setup subviews to browse classes from a list"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1900
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1901
    |vpanel hpanel frame l v|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1902
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1903
    vpanel := VariableVerticalPanel 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1904
		 origin:(0.0 @ 0.0) corner:(1.0 @ 1.0) in:self.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1905
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1906
    hpanel := View origin:(0.0 @ 0.0) corner:(1.0 @ 0.25) in:vpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1907
    frame := View origin:(0.0 @ 0.0) corner:(0.33 @ 1.0) in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1908
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1909
    self createClassListViewIn:frame.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1910
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1911
    v := ScrollableView for:SelectionInListView in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1912
    v origin:(0.33 @ 0.0) corner:(0.66 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1913
    methodCategoryListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1914
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1915
    v := ScrollableView for:SelectionInListView in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1916
    v origin:(0.66 @ 0.0) corner:(1.0 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1917
    methodListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1918
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1919
    self createCodeViewIn:vpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1920
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1921
    l := aList collect:[:entry | entry name].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1922
    classListView list:(l sort).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1923
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1924
    self updateMethodCategoryList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1925
    self updateMethodList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1926
    self updateCodeView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1927
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1928
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1929
setupForClass:aClass methodCategory:aMethodCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1930
    "setup subviews to browse a method category"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1931
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1932
    |vpanel v|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1933
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1934
    vpanel := VariableVerticalPanel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1935
			origin:(0.0 @ 0.0) corner:(1.0 @ 1.0)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1936
			    in:self.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1937
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1938
    v := ScrollableView for:SelectionInListView in:vpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1939
    v origin:(0.0 @ 0.0) corner:(1.0 @ 0.25).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1940
    methodListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1941
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1942
    self createCodeViewIn:vpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1943
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1944
    currentClassCategory := aClass category.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1945
    self switchToClass:aClass.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1946
    actualClass := acceptClass := aClass.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1947
    currentMethodCategory := aMethodCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1948
    self updateMethodList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1949
    self updateCodeView
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1950
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1951
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1952
setupForFullClassProtocol:aClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1953
    "setup subviews to browse a classes full protocol"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1954
108
claus
parents: 107
diff changeset
  1955
    |vpanel hpanel frame v cls|
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1956
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1957
    vpanel := VariableVerticalPanel origin:(0.0 @ 0.0)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1958
				    corner:(1.0 @ 1.0)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1959
					in:self.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1960
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1961
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1962
     notice: we use a different ratio here
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1963
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1964
    hpanel := View origin:(0.0 @ 0.0) corner:(1.0 @ 0.4) in:vpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1965
    frame := View origin:(0.0 @ 0.0) corner:(0.33 @ 1.0) in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1966
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1967
    self createClassListViewIn:frame.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1968
    classListView multipleSelectOk:true.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1969
    classListView toggleSelect:true.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1970
    classListView strikeOut:true.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1971
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1972
    v := ScrollableView for:SelectionInListView in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1973
    v origin:(0.33 @ 0.0) corner:(0.66 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1974
    methodCategoryListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1975
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1976
    v := ScrollableView for:SelectionInListView in:hpanel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1977
    v origin:(0.66 @ 0.0) corner:(1.0 @ 1.0).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1978
    methodListView := v scrolledView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1979
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1980
    self createCodeViewIn:vpanel at:0.4.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1981
108
claus
parents: 107
diff changeset
  1982
    cls := aClass.
claus
parents: 107
diff changeset
  1983
    cls isMeta ifTrue:[
claus
parents: 107
diff changeset
  1984
	cls := cls soleInstance
claus
parents: 107
diff changeset
  1985
    ].
claus
parents: 107
diff changeset
  1986
    currentClassHierarchy := actualClass := acceptClass := currentClass := cls.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1987
    fullProtocol := true.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1988
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1989
    self updateClassList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1990
    self updateMethodCategoryList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1991
    self updateMethodList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1992
    self updateCodeView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1993
    self updateVariableList.
108
claus
parents: 107
diff changeset
  1994
    aClass isMeta ifTrue:[
claus
parents: 107
diff changeset
  1995
	self instanceProtocol:false
claus
parents: 107
diff changeset
  1996
    ].
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1997
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1998
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  1999
!BrowserView methodsFor:'class stuff'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2000
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2001
switchToClass:newClass
132
claus
parents: 131
diff changeset
  2002
    "switch to some other class;
claus
parents: 131
diff changeset
  2003
     keep instance protocol as it was ..."
claus
parents: 131
diff changeset
  2004
131
claus
parents: 130
diff changeset
  2005
    |cls meta|
108
claus
parents: 107
diff changeset
  2006
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2007
    fullProtocol ifTrue:[^ self].
108
claus
parents: 107
diff changeset
  2008
claus
parents: 107
diff changeset
  2009
    cls := newClass.
131
claus
parents: 130
diff changeset
  2010
    (meta := cls isMeta) ifTrue:[
108
claus
parents: 107
diff changeset
  2011
	cls := cls soleInstance
claus
parents: 107
diff changeset
  2012
    ].
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2013
    currentClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2014
	currentClass removeDependent:self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2015
    ].
129
claus
parents: 126
diff changeset
  2016
    currentClass := cls.
132
claus
parents: 131
diff changeset
  2017
    showInstance ifTrue:[
claus
parents: 131
diff changeset
  2018
       actualClass := acceptClass := cls.
claus
parents: 131
diff changeset
  2019
    ] ifFalse:[
claus
parents: 131
diff changeset
  2020
       actualClass := acceptClass := cls class.
claus
parents: 131
diff changeset
  2021
    ].
131
claus
parents: 130
diff changeset
  2022
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2023
    currentClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2024
	currentClass addDependent:self.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2025
    ].
108
claus
parents: 107
diff changeset
  2026
    self normalLabel.
132
claus
parents: 131
diff changeset
  2027
claus
parents: 131
diff changeset
  2028
    "Modified: 1.9.1995 / 01:04:05 / claus"
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2029
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2030
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2031
classSelectionChanged
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2032
    |oldMethodCategory oldMethod oldSelector|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2033
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2034
    self withWaitCursorDo:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2035
	oldMethodCategory := currentMethodCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2036
	oldMethod := currentMethod.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2037
	oldSelector := currentSelector.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2038
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2039
	showInstance ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2040
	    actualClass := acceptClass := currentClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2041
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2042
	    actualClass := acceptClass := currentClass class
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2043
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2044
	currentMethodCategory := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2045
	currentMethod := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2046
	currentSelector := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2047
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2048
	self updateVariableList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2049
	self updateMethodCategoryList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2050
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2051
	oldMethodCategory notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2052
	    methodCategoryListView selectElement:oldMethodCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2053
	    methodCategoryListView hasSelection ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2054
		currentMethodCategory := oldMethodCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2055
		self methodCategorySelectionChanged
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2056
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2057
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2058
	self updateMethodList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2059
	self updateCodeView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2060
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2061
	fullClass ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2062
	    codeView acceptAction:[:theCode |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2063
		codeView cursor:Cursor execute.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2064
		Object abortSignal catch:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2065
		    self compileCode:theCode asString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2066
		    codeView modified:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2067
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2068
		codeView cursor:Cursor normal.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2069
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2070
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2071
	    self classDefinition.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2072
	    codeView acceptAction:[:theCode |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2073
		codeView cursor:Cursor execute.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2074
		Object abortSignal catch:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2075
		    (Compiler evaluate:theCode asString notifying:codeView compile:false)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2076
		    isBehavior ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2077
			self classCategoryUpdate.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2078
			self updateClassListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2079
			codeView modified:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2080
		    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2081
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2082
		codeView cursor:Cursor normal.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2083
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2084
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2085
	codeView explainAction:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2086
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2087
	classCategoryListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2088
	    (currentClassCategory = currentClass category) ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2089
		currentClassCategory := currentClass category.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2090
		classCategoryListView selectElement:currentClassCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2091
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2092
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2093
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2094
	self setDoitActionForClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2095
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2096
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2097
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2098
updateClassListWithScroll:scroll
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2099
    |classes oldClassName|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2100
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2101
    classListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2102
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2103
	 refetch in case we are not up to date
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2104
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2105
	(currentClass notNil and:[fullProtocol not]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2106
	    oldClassName := currentClass name.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2107
	    currentClass := Smalltalk at:(oldClassName asSymbol).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2108
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2109
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2110
	currentClassCategory notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2111
	    classes := self listOfAllClassesInCategory:currentClassCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2112
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2113
	    currentClassHierarchy notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2114
		classes := self listOfClassHierarchyOf:currentClassHierarchy
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2115
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2116
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2117
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2118
	classListView list = classes ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2119
	    scroll ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2120
		classListView contents:classes
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2121
	    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2122
		classListView setContents:classes
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2123
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2124
	    oldClassName notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2125
		classListView setContents:classes.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2126
		classListView selectElement:oldClassName
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2127
	    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2128
		variableListView notNil ifTrue:[variableListView contents:nil]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2129
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2130
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2131
	scroll ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2132
	    fullProtocol ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2133
		classListView scrollToBottom
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2134
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2135
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2136
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2137
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2138
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2139
doClassMenu:aBlock
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2140
    "a helper - check if class is selected and evaluate aBlock
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2141
     while showing waitCursor"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2142
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2143
    self checkClassSelected ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2144
	self withWaitCursorDo:[aBlock value:currentClass]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2145
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2146
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2147
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2148
checkClassSelected
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2149
    "warn and return false, if no class is selected"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2150
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2151
    currentClass isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2152
	self warn:'select a class first'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2153
	^ false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2154
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2155
    ^ true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2156
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2157
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2158
listOfAllClassesInCategory:aCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2159
    "return a list of all classes in a given category"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2160
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2161
    |newList classes searchCategory nm|
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2162
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2163
    (aCategory = '* hierarchy *') ifTrue:[
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2164
	newList := OrderedCollection new.
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2165
	classes := Set new.
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2166
	self classHierarchyDo:[:aClass :lvl|
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2167
	    nm := aClass name.
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2168
	    (classes includes:nm) ifFalse:[
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2169
		classes add:nm.
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2170
		newList add:(String new:lvl) , nm
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2171
	    ]
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2172
	].
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2173
	^ newList
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2174
    ].
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2175
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2176
    newList := Set new.
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2177
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2178
    (aCategory = '* all *') ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2179
	Smalltalk allBehaviorsDo:[:aClass |
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2180
	    newList add:aClass name
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2181
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2182
    ] ifFalse:[
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2183
	(aCategory = '* no category *') ifTrue:[
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2184
	    searchCategory := nil
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2185
	] ifFalse:[
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2186
	    searchCategory := aCategory
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2187
	].
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2188
	Smalltalk allBehaviorsDo:[:aClass |
105
claus
parents: 98
diff changeset
  2189
	    |thisCategory|
claus
parents: 98
diff changeset
  2190
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2191
	    aClass isMeta ifFalse:[
105
claus
parents: 98
diff changeset
  2192
		thisCategory := aClass category.
claus
parents: 98
diff changeset
  2193
		((thisCategory = searchCategory) 
claus
parents: 98
diff changeset
  2194
		or:[thisCategory = aCategory]) ifTrue:[
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2195
		    newList add:aClass name
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2196
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2197
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2198
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2199
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2200
    (newList size == 0) ifTrue:[^ nil].
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  2201
    ^ newList asOrderedCollection sort
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2202
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2203
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2204
classSelection:lineNr
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2205
    "user clicked on a class line - show method categories"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2206
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2207
    |classSymbol cls oldSelector|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2208
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2209
    (currentClassHierarchy notNil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2210
     and:[fullProtocol]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2211
	oldSelector := currentSelector.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2212
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2213
	self updateMethodCategoryListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2214
	self updateMethodListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2215
	self updateVariableList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2216
	^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2217
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2218
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2219
    cls := Smalltalk classNamed:classListView selectionValue withoutSpaces.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2220
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2221
    classSymbol := classListView selectionValue withoutSpaces asSymbol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2222
    (Smalltalk includesKey:classSymbol) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2223
	cls := Smalltalk at:classSymbol
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2224
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2225
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2226
    cls notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2227
	self switchToClass:cls.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2228
	self classSelectionChanged
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2229
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2230
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2231
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2232
updateClassList
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2233
    self updateClassListWithScroll:true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2234
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2235
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2236
templateFor:className in:cat
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2237
    "return a class definition template - be smart in what is offered initially"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2238
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2239
    |aString name i|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2240
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2241
    name := 'NewClass'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2242
    i := 1.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2243
    [name knownAsSymbol and:[Smalltalk includesKey:name asSymbol]] whileTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2244
	i := i + 1.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2245
	name := 'NewClass' , i printString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2246
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2247
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2248
    aString := className , ' subclass:#' , name , '
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2249
	instanceVariableNames: '''' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2250
	classVariableNames: ''''    
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2251
	poolDictionaries: ''''
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2252
	category: '''.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2253
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2254
    cat notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2255
	aString := aString , cat
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2256
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2257
    aString := aString , '''
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2258
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2259
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2260
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2261
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2262
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2263
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2264
 Replace ''' , className , ''', ''', name , ''' and
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2265
 the empty string arguments by true values.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2266
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2267
 Install (or change) the class by ''accepting'',
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2268
 either via the menu or the keyboard (usually CMD-A).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2269
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2270
 To be nice to others (and yourself later), do not forget to
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2271
 add some documentation; either under the classes documentation
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2272
 protocol, or as a class comment.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2273
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2274
'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2275
    ^ aString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2276
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2277
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2278
listOfClassHierarchyOf:aClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2279
    "return a hierarchy class-list"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2280
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2281
    |startClass classes thisOne|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2282
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2283
    showInstance ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2284
	startClass := aClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2285
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2286
	startClass := aClass class.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2287
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2288
    classes := startClass allSuperclasses.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2289
    thisOne := Array with:startClass.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2290
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2291
    classes notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2292
	classes := classes reverse , thisOne.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2293
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2294
	classes := thisOne
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2295
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2296
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2297
    fullProtocol ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2298
	classes := classes , startClass allSubclassesInOrder
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2299
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2300
    ^ classes collect:[:c | c name]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2301
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2302
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2303
switchToClassNamed:aString
129
claus
parents: 126
diff changeset
  2304
    |meta str classSymbol theClass newCat element|
claus
parents: 126
diff changeset
  2305
claus
parents: 126
diff changeset
  2306
    meta := false.
132
claus
parents: 131
diff changeset
  2307
    str := aString.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2308
    classSymbol := aString asSymbolIfInterned.
129
claus
parents: 126
diff changeset
  2309
    classSymbol isNil ifTrue:[
132
claus
parents: 131
diff changeset
  2310
	(aString endsWith:'class') ifTrue:[
claus
parents: 131
diff changeset
  2311
	    str := aString copyWithoutLast:5.
129
claus
parents: 126
diff changeset
  2312
	    classSymbol := str asSymbolIfInterned.
claus
parents: 126
diff changeset
  2313
	    classSymbol isNil ifTrue:[
claus
parents: 126
diff changeset
  2314
		^ self
claus
parents: 126
diff changeset
  2315
	    ].
claus
parents: 126
diff changeset
  2316
	    meta := true
claus
parents: 126
diff changeset
  2317
	].
claus
parents: 126
diff changeset
  2318
    ].
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2319
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2320
    theClass := Smalltalk at:classSymbol.
132
claus
parents: 131
diff changeset
  2321
    (theClass isNil and:[str endsWith:'class']) ifTrue:[
claus
parents: 131
diff changeset
  2322
	str := str copyWithoutLast:5.
claus
parents: 131
diff changeset
  2323
	classSymbol := str asSymbolIfInterned.
claus
parents: 131
diff changeset
  2324
	classSymbol isNil ifTrue:[
claus
parents: 131
diff changeset
  2325
	    ^ self
claus
parents: 131
diff changeset
  2326
	].
claus
parents: 131
diff changeset
  2327
	meta := true.
claus
parents: 131
diff changeset
  2328
	theClass := Smalltalk at:classSymbol.
claus
parents: 131
diff changeset
  2329
    ].
claus
parents: 131
diff changeset
  2330
129
claus
parents: 126
diff changeset
  2331
    theClass == currentClass ifTrue:[^ self].
claus
parents: 126
diff changeset
  2332
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2333
    theClass isBehavior ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2334
	classCategoryListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2335
	    currentClassHierarchy isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2336
		((newCat := theClass category) ~= currentClassCategory) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2337
		    currentClassCategory := newCat.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2338
		    newCat isNil ifTrue:[
93
claus
parents: 92
diff changeset
  2339
			element := '* no category *'
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2340
		    ] ifFalse:[
93
claus
parents: 92
diff changeset
  2341
			element := newCat.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2342
		    ].
93
claus
parents: 92
diff changeset
  2343
		    classCategoryListView selectElement:element.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2344
		    "/ classCategoryListView makeSelectionVisible.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2345
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2346
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2347
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2348
	self updateClassList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2349
	self switchToClass:theClass.
132
claus
parents: 131
diff changeset
  2350
claus
parents: 131
diff changeset
  2351
	classListView selectElement:str.
129
claus
parents: 126
diff changeset
  2352
	self instanceProtocol:meta not.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2353
	self classSelectionChanged
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2354
    ]
132
claus
parents: 131
diff changeset
  2355
claus
parents: 131
diff changeset
  2356
    "Modified: 1.9.1995 / 01:41:35 / claus"
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2357
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2358
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2359
classClassDefinitionTemplateFor:name in:cat
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2360
    "common helper for newClass and newSubclass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2361
     - show a template to define class name in category cat.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2362
     Also, set acceptaction to install the class."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2363
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2364
    currentMethodCategory := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2365
    currentMethod := currentSelector := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2366
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2367
    classListView deselect.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2368
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2369
    fullClass ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2370
	methodCategoryListView contents:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2371
	methodListView contents:nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2372
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2373
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2374
    codeView contents:(self templateFor:name in:cat).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2375
    codeView modified:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2376
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2377
    codeView acceptAction:[:theCode |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2378
	codeView cursor:Cursor execute.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2379
	Object abortSignal catch:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2380
	    |cls|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2381
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2382
	    cls := (Compiler evaluate:theCode asString notifying:codeView compile:false).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2383
	    cls isBehavior ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2384
		codeView modified:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2385
		self classCategoryUpdate.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2386
		self updateClassListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2387
		self switchToClassNamed:(cls name).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2388
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2389
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2390
	codeView cursor:(Cursor normal).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2391
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2392
    codeView explainAction:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2393
    self switchToClass:nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2394
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2395
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2396
renameCurrentClassTo:aString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2397
    "helper - do the rename"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2398
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2399
    self doClassMenu:[:currentClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2400
	|oldName oldSym newSym|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2401
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2402
	oldName := currentClass name.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2403
	oldSym := oldName asSymbol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2404
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2405
	currentClass setName:aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2406
	newSym := aString asSymbol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2407
	Smalltalk at:oldSym put:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2408
	Smalltalk removeKey:oldSym.            
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2409
	Smalltalk at:newSym put:currentClass.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2410
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2411
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2412
	currentClass renameTo:aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2413
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2414
	Smalltalk renameClass:currentClass to:aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2415
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2416
	self updateClassList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2417
	self updateMethodCategoryListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2418
	self updateMethodListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2419
	self withWaitCursorDo:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2420
	    Transcript showCr:('searching for users of ' , oldSym); endEntry.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2421
	    SystemBrowser browseReferendsOf:oldSym warnIfNone:false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2422
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2423
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2424
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2425
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2426
switchToClassNameMatching:aMatchString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2427
    |classNames thisName box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2428
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2429
    classNames := OrderedCollection new.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2430
    Smalltalk allBehaviorsDo:[:aClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2431
	thisName := aClass name.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2432
	(aMatchString match:thisName) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2433
	    classNames add:thisName
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2434
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2435
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2436
    (classNames size == 0) ifTrue:[^ nil].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2437
    (classNames size == 1) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2438
	^ self switchToClassNamed:(classNames at:1)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2439
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2440
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2441
    box := self listBoxTitle:'select class to switch to:'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2442
		      okText:'ok'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2443
			list:classNames sort.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2444
    box action:[:aString | self switchToClassNamed:aString].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2445
    box showAtPointer
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2446
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2447
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2448
!BrowserView methodsFor:'variable stuff'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2449
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2450
unhilightMethods
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2451
    "unhighlight items in method list"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2452
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2453
    variableListView isNil ifTrue:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2454
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2455
    methodListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2456
	1 to:methodListView list size do:[:entry |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2457
	     methodListView attributeAt:entry put:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2458
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2459
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2460
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2461
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2462
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2463
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2464
hilightMethodsInMethodCategoryList:inCat inMethodList:inMethods 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2465
    "search for methods  which access the selected
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2466
     variable, and highlight them"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2467
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2468
    |name redefinedSelectors|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2469
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2470
    variableListView isNil ifTrue:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2471
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2472
    inCat ifTrue:[self unhilightMethodCategories].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2473
    inMethods ifTrue:[self unhilightMethods].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2474
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2475
    actualClass isNil ifTrue:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2476
    (methodCategoryListView isNil 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2477
    and:[methodListView isNil]) ifTrue:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2478
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2479
    name := variableListView selectionValue.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2480
    name isNil ifTrue:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2481
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2482
    self withCursor:(Cursor questionMark) do:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2483
	|classes filter any|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2484
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2485
	classes := Array with:actualClass.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2486
	currentClassHierarchy notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2487
	    classes := classes , actualClass allSuperclasses.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2488
	    redefinedSelectors := IdentitySet new.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2489
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2490
93
claus
parents: 92
diff changeset
  2491
	filter := SystemBrowser filterToSearchRefsTo:name classVars:showInstance not modificationsOnly:false. 
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2492
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2493
	any := false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2494
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2495
	 highlight the method that ref this variable
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2496
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2497
	classes do:[:someClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2498
	    (fullProtocol
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2499
	    and:[classListView valueIsInSelection:(someClass name)]) ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2500
		someClass methodArray with:someClass selectorArray 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2501
		do:[:method :selector |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2502
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2503
		    (inCat
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2504
		    or:[methodListView list notNil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2505
			and:[methodListView list includes:selector]])
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2506
		    ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2507
			(redefinedSelectors isNil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2508
			or:[(redefinedSelectors includes:selector) not])
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2509
		       ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2510
			   (filter value:someClass value:method value:selector) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2511
			       |idx cat|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2512
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2513
			       (inCat
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2514
			       and:[methodCategoryListView notNil 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2515
			       and:[methodCategoryListView list notNil]]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2516
				   cat := method category.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2517
				   "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2518
				    highlight the methodCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2519
				   "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2520
				   idx := methodCategoryListView list indexOf:cat.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2521
				   idx ~~ 0 ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2522
				       methodCategoryListView attributeAt:idx put:#bold.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2523
				   ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2524
			       ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2525
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2526
			       (inMethods
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2527
			       and:[methodListView notNil 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2528
			       and:[methodListView list notNil]]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2529
				   "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2530
				    highlight the method
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2531
				   "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2532
				   idx := methodListView list indexOf:selector.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2533
				   idx ~~ 0 ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2534
				       methodListView attributeAt:idx put:#bold.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2535
				   ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2536
				   any := true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2537
			       ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2538
			   ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2539
			   redefinedSelectors notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2540
			       redefinedSelectors add:selector
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2541
			   ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2542
			]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2543
		    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2544
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2545
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2546
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2547
	any ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2548
	    self setSearchPattern:name
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2549
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2550
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2551
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2552
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2553
updateVariableList
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2554
    |l subList last nameAccessSelector class oldSelection|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2555
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2556
    variableListView isNil ifTrue:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2557
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2558
    oldSelection := variableListView selectionValue.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2559
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2560
    l := OrderedCollection new.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2561
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2562
     show classVars, if classProtocol is shown (instead of classInstance vars)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2563
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2564
    showInstance ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2565
	nameAccessSelector := #instVarNames
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2566
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2567
	nameAccessSelector := #classVarNames
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2568
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2569
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2570
"/    class := currentClass notNil ifTrue:[currentClass] ifFalse:[actualClass].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2571
"/    class isNil ifTrue:[class := currentClassHierarchy].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2572
class := currentClassHierarchy notNil ifTrue:[currentClassHierarchy] ifFalse:[currentClass].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2573
    class withAllSuperclasses do:[:aClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2574
	|ignore|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2575
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2576
	ignore := fullProtocol 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2577
		  and:[classListView valueIsInSelection:(aClass name asString)].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2578
	ignore ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2579
	    subList := aClass perform:nameAccessSelector.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2580
	    subList size ~~ 0 ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2581
		l := l , (subList asOrderedCollection reverse).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2582
		l := l , (OrderedCollection with:'---- ' , aClass name , ' ---------').
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2583
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2584
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2585
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2586
    l reverse.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2587
    variableListView setAttributes:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2588
    variableListView list:l.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2589
    l keysAndValuesDo:[:index :entry |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2590
	(entry startsWith:'---') ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2591
	    variableListView attributeAt:index put:#disabled.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2592
	    last := index
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2593
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2594
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2595
    last notNil ifTrue:[variableListView scrollToLine:last].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2596
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2597
    oldSelection notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2598
	variableListView selectElement:oldSelection.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2599
	self hilightMethodsInMethodCategoryList:true inMethodList:true.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2600
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2601
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2602
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2603
unhilightMethodCategories
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2604
    "unhighlight items in method list"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2605
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2606
    variableListView isNil ifTrue:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2607
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2608
    methodCategoryListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2609
	1 to:methodCategoryListView list size do:[:entry |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2610
	    methodCategoryListView attributeAt:entry put:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2611
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2612
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2613
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2614
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2615
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2616
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2617
hilightMethodsInMethodCategoryList
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2618
    "search for methods  which access the selected
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2619
     variable, and highlight them"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2620
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2621
    self hilightMethodsInMethodCategoryList:true inMethodList:false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2622
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2623
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2624
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2625
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2626
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2627
hilightMethodsInMethodList
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2628
    "search for methods  which access the selected
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2629
     variable, and highlight them"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2630
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2631
    self hilightMethodsInMethodCategoryList:false inMethodList:true 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2632
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2633
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2634
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2635
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2636
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2637
!BrowserView methodsFor:'class list menu'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2638
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2639
classDefinition
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2640
    "show class definition in codeView and setup accept-action for
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2641
     a class-definition change.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2642
     Extract documentation either from a documentation method or
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2643
     from the comment - not a biggy, but beginners will like
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2644
     it when exploring the system."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2645
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2646
    self doClassMenu:[:currentClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2647
	|m s aStream isComment|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2648
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2649
	aStream := WriteStream on:(String new:200).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2650
	currentClass fileOutDefinitionOn:aStream.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2651
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2652
	currentClass isLoaded ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2653
	    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2654
	     add documentation as a comment, if there is any
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2655
	    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2656
	    m := currentClass class compiledMethodAt:#documentation.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2657
	    m notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2658
		s := m comment.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2659
		isComment := false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2660
	    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2661
		"try comment"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2662
		s := currentClass comment.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2663
		s notNil ifTrue:[
93
claus
parents: 92
diff changeset
  2664
		    s isEmpty ifTrue:[
claus
parents: 92
diff changeset
  2665
			s := nil
claus
parents: 92
diff changeset
  2666
		    ] ifFalse:[
claus
parents: 92
diff changeset
  2667
			isComment := true
claus
parents: 92
diff changeset
  2668
		    ]
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2669
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2670
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2671
	].
93
claus
parents: 92
diff changeset
  2672
	aStream cr.
claus
parents: 92
diff changeset
  2673
	aStream cr.
claus
parents: 92
diff changeset
  2674
	aStream cr.
claus
parents: 92
diff changeset
  2675
	aStream cr.
claus
parents: 92
diff changeset
  2676
	aStream cr.
claus
parents: 92
diff changeset
  2677
	s isNil ifTrue:[
claus
parents: 92
diff changeset
  2678
	    aStream nextPut:$" ; cr; nextPutAll:' no comment or documentation found'; cr.
claus
parents: 92
diff changeset
  2679
	] ifFalse:[
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2680
	    aStream nextPut:$" ; cr; nextPutAll:' Documentation:'; cr.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2681
	    aStream cr.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2682
	    aStream nextPutAll:s.    
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2683
	    aStream cr; cr.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2684
	    aStream nextPutAll:' Notice: '; cr.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2685
	    aStream nextPutAll:'   the above string has been extracted from the classes '.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2686
	    aStream nextPutAll:(isComment ifTrue:['comment.'] ifFalse:['documentation method.']).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2687
	    aStream cr.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2688
	    aStream nextPutAll:'   It will not be preserved when accepting a new class definition.'; cr.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2689
	].
93
claus
parents: 92
diff changeset
  2690
	aStream nextPut:$".
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2691
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2692
	codeView contents:(aStream contents).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2693
	codeView modified:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2694
	codeView acceptAction:[:theCode |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2695
	    codeView cursor:Cursor execute.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2696
	    Object abortSignal catch:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2697
		(Compiler evaluate:theCode asString notifying:codeView compile:false)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2698
		isBehavior ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2699
		    codeView modified:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2700
		    self classCategoryUpdate.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2701
		    self updateClassListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2702
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2703
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2704
	    codeView cursor:Cursor normal.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2705
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2706
	codeView explainAction:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2707
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2708
	methodListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2709
	    methodListView deselect
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2710
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2711
	aspect := #definition.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2712
	self normalLabel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2713
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2714
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2715
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2716
classMenu
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2717
    "sent by  classListView to ask for the menu"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2718
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2719
    |labels selectors|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2720
105
claus
parents: 98
diff changeset
  2721
    (device ctrlDown 
claus
parents: 98
diff changeset
  2722
    and:[currentClass notNil]) ifTrue:[
107
claus
parents: 106
diff changeset
  2723
	labels :=  #(
claus
parents: 106
diff changeset
  2724
		       'inspect class'
claus
parents: 106
diff changeset
  2725
		       '-'
claus
parents: 106
diff changeset
  2726
		       'primitive definitions'
claus
parents: 106
diff changeset
  2727
		       'primitive variables'
claus
parents: 106
diff changeset
  2728
		       'primitive functions'
claus
parents: 106
diff changeset
  2729
		    ).
claus
parents: 106
diff changeset
  2730
	selectors := #(
claus
parents: 106
diff changeset
  2731
		       classInspect
claus
parents: 106
diff changeset
  2732
		       nil
claus
parents: 106
diff changeset
  2733
		       classPrimitiveDefinitions
claus
parents: 106
diff changeset
  2734
		       classPrimitiveVariables
claus
parents: 106
diff changeset
  2735
		       classPrimitiveFunctions
claus
parents: 106
diff changeset
  2736
		     ).
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2737
    ] ifFalse:[
105
claus
parents: 98
diff changeset
  2738
	currentClass isNil ifTrue:[
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2739
	    labels :=    #(
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2740
			   'new class'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2741
			 ).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2742
	    selectors := #(
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2743
			   classNewClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2744
			 ).
105
claus
parents: 98
diff changeset
  2745
	] ifFalse:[
claus
parents: 98
diff changeset
  2746
	    currentClass isLoaded ifFalse:[
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2747
		labels :=    #(
105
claus
parents: 98
diff changeset
  2748
			       'new class'
claus
parents: 98
diff changeset
  2749
			       '-'
claus
parents: 98
diff changeset
  2750
			       'load '
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2751
			     ).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2752
		selectors := #(
105
claus
parents: 98
diff changeset
  2753
			       classNewClass
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2754
			       nil
105
claus
parents: 98
diff changeset
  2755
			       classLoad
claus
parents: 98
diff changeset
  2756
			     ).
claus
parents: 98
diff changeset
  2757
	    ] ifTrue:[
claus
parents: 98
diff changeset
  2758
		fullProtocol ifTrue:[
claus
parents: 98
diff changeset
  2759
		    labels :=    #(
claus
parents: 98
diff changeset
  2760
				   'hierarchy' 
claus
parents: 98
diff changeset
  2761
				   'definition' 
claus
parents: 98
diff changeset
  2762
				   'comment' 
claus
parents: 98
diff changeset
  2763
				   'class instvars' 
claus
parents: 98
diff changeset
  2764
				 ).
claus
parents: 98
diff changeset
  2765
		    selectors := #(
claus
parents: 98
diff changeset
  2766
				   classHierarchy
claus
parents: 98
diff changeset
  2767
				   classDefinition
claus
parents: 98
diff changeset
  2768
				   classComment
claus
parents: 98
diff changeset
  2769
				   classClassInstVars
claus
parents: 98
diff changeset
  2770
				  ).
claus
parents: 98
diff changeset
  2771
		] ifFalse:[
claus
parents: 98
diff changeset
  2772
		    labels :=    #(
claus
parents: 98
diff changeset
  2773
				   'fileOut'
claus
parents: 98
diff changeset
  2774
				   'printOut'
claus
parents: 98
diff changeset
  2775
				   'printOut protocol'
claus
parents: 98
diff changeset
  2776
				 " 'printOut full protocol' "
claus
parents: 98
diff changeset
  2777
				   '-'
claus
parents: 98
diff changeset
  2778
				   'SPAWN_CLASS' 
claus
parents: 98
diff changeset
  2779
				   'spawn full protocol' 
claus
parents: 98
diff changeset
  2780
				   'spawn hierarchy' 
claus
parents: 98
diff changeset
  2781
				   'spawn subclasses' 
claus
parents: 98
diff changeset
  2782
				   '-'
claus
parents: 98
diff changeset
  2783
				  ).
claus
parents: 98
diff changeset
  2784
		    selectors := #(
claus
parents: 98
diff changeset
  2785
				   classFileOut
claus
parents: 98
diff changeset
  2786
				   classPrintOut
claus
parents: 98
diff changeset
  2787
				   classPrintOutProtocol
claus
parents: 98
diff changeset
  2788
				"  classPrintOutFullProtocol "
claus
parents: 98
diff changeset
  2789
				   nil
claus
parents: 98
diff changeset
  2790
				   classSpawn
claus
parents: 98
diff changeset
  2791
				   classSpawnFullProtocol
claus
parents: 98
diff changeset
  2792
				   classSpawnHierarchy
claus
parents: 98
diff changeset
  2793
				   classSpawnSubclasses
claus
parents: 98
diff changeset
  2794
				   nil
claus
parents: 98
diff changeset
  2795
				  ).
claus
parents: 98
diff changeset
  2796
claus
parents: 98
diff changeset
  2797
		    fullClass ifFalse:[
claus
parents: 98
diff changeset
  2798
			labels := labels , #(
claus
parents: 98
diff changeset
  2799
				   'hierarchy' 
claus
parents: 98
diff changeset
  2800
				   'definition' 
claus
parents: 98
diff changeset
  2801
				   'comment' 
claus
parents: 98
diff changeset
  2802
				   'class instvars' 
claus
parents: 98
diff changeset
  2803
		   "/              'protocols' 
claus
parents: 98
diff changeset
  2804
				   '-'
claus
parents: 98
diff changeset
  2805
				  ).
claus
parents: 98
diff changeset
  2806
			selectors := selectors , #(
claus
parents: 98
diff changeset
  2807
				   classHierarchy
claus
parents: 98
diff changeset
  2808
				   classDefinition
claus
parents: 98
diff changeset
  2809
				   classComment
claus
parents: 98
diff changeset
  2810
				   classClassInstVars
claus
parents: 98
diff changeset
  2811
		   "/              classProtocols 
claus
parents: 98
diff changeset
  2812
				   nil
claus
parents: 98
diff changeset
  2813
				  ).
claus
parents: 98
diff changeset
  2814
		    ].
claus
parents: 98
diff changeset
  2815
claus
parents: 98
diff changeset
  2816
		    "
claus
parents: 98
diff changeset
  2817
		     dont offer this menu for now - you cannot recompile
claus
parents: 98
diff changeset
  2818
		     the stuff anyway. So there is only confusion in showing
claus
parents: 98
diff changeset
  2819
		     those ...
claus
parents: 98
diff changeset
  2820
		    "
claus
parents: 98
diff changeset
  2821
		    false "currentClass primitiveSpec notNil" ifTrue:[
claus
parents: 98
diff changeset
  2822
			labels := labels , #(
claus
parents: 98
diff changeset
  2823
				   'primitive definitions'
claus
parents: 98
diff changeset
  2824
				   'primitive variables'
claus
parents: 98
diff changeset
  2825
				   'primitive functions'
claus
parents: 98
diff changeset
  2826
				   '-'
claus
parents: 98
diff changeset
  2827
				  ).
claus
parents: 98
diff changeset
  2828
			selectors := selectors , #(
claus
parents: 98
diff changeset
  2829
				   classPrimitiveDefinitions
claus
parents: 98
diff changeset
  2830
				   classPrimitiveVariables
claus
parents: 98
diff changeset
  2831
				   classPrimitiveFunctions
claus
parents: 98
diff changeset
  2832
				   nil
claus
parents: 98
diff changeset
  2833
				  ).
claus
parents: 98
diff changeset
  2834
		    ].
claus
parents: 98
diff changeset
  2835
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2836
		    labels := labels , #(
105
claus
parents: 98
diff changeset
  2837
		   "/              'variable search'
claus
parents: 98
diff changeset
  2838
				   'class refs'
claus
parents: 98
diff changeset
  2839
				   '-'
claus
parents: 98
diff changeset
  2840
				   'new class'
claus
parents: 98
diff changeset
  2841
				   'new subclass'
claus
parents: 98
diff changeset
  2842
				   'rename ...'
claus
parents: 98
diff changeset
  2843
				   'remove'
claus
parents: 98
diff changeset
  2844
				  ).
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2845
		    selectors := selectors , #(
105
claus
parents: 98
diff changeset
  2846
		   "/              variables
claus
parents: 98
diff changeset
  2847
				   classRefs
claus
parents: 98
diff changeset
  2848
				   nil
claus
parents: 98
diff changeset
  2849
				   classNewClass
claus
parents: 98
diff changeset
  2850
				   classNewSubclass
claus
parents: 98
diff changeset
  2851
				   classRename
claus
parents: 98
diff changeset
  2852
				   classRemove
claus
parents: 98
diff changeset
  2853
				  ).
claus
parents: 98
diff changeset
  2854
		    currentClass wasAutoloaded ifTrue:[
claus
parents: 98
diff changeset
  2855
			labels := labels , #(
claus
parents: 98
diff changeset
  2856
				   'unload'
claus
parents: 98
diff changeset
  2857
				  ).
claus
parents: 98
diff changeset
  2858
			selectors := selectors , #(
claus
parents: 98
diff changeset
  2859
				   classUnload
claus
parents: 98
diff changeset
  2860
				  ).
claus
parents: 98
diff changeset
  2861
		    ]
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2862
		]
105
claus
parents: 98
diff changeset
  2863
	    ].
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2864
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2865
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2866
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2867
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2868
    ^ PopUpMenu labels:(resources array:labels)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2869
	     selectors:selectors
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2870
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2871
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2872
classFileOut
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2873
    "fileOut the current class.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2874
     Catch errors (sure, you like to know if it failed) and
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2875
     warn if any)"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2876
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2877
    self doClassMenu:[:currentClass |
105
claus
parents: 98
diff changeset
  2878
	|msg|
claus
parents: 98
diff changeset
  2879
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2880
	self busyLabel:'saving %1' with:currentClass name.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2881
	Class fileOutErrorSignal handle:[:ex |
105
claus
parents: 98
diff changeset
  2882
	    self warn:'cannot create: %1\(%2)' with:ex parameter with:ex errorString.
claus
parents: 98
diff changeset
  2883
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2884
	    ex return.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2885
	] do:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2886
	    currentClass fileOut.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2887
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2888
	self normalLabel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2889
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2890
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2891
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2892
doClassMenuWithSelection:aBlock
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2893
    "a helper - if there is a selection, which represents a classes name,
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2894
     evaluate aBlock, passing that class and optional selector as arguments.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2895
     Otherwise, check if a class is selected and evaluate aBlock with the
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2896
     current class."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2897
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2898
    |string words clsName cls sel isMeta|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2899
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2900
    string := codeView selection.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2901
    string notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2902
	self extractClassAndSelectorFromSelectionInto:[:c :s :m |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2903
	    clsName := c.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2904
	    sel := s.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2905
	    isMeta := m.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2906
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2907
	clsName isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2908
	    string := string asString withoutSeparators.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2909
	    words := string asCollectionOfWords.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2910
	    words notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2911
		clsName := words first.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2912
		(clsName endsWith:'class') ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2913
		    isMeta := true.
106
claus
parents: 105
diff changeset
  2914
		    clsName := clsName copyWithoutLast:5 "copyTo:(clsName size - 5)"
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2915
		] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2916
		    isMeta := false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2917
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2918
		sel := Parser selectorInExpression:string.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2919
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2920
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2921
	clsName notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2922
	    (cls := Smalltalk classNamed:clsName) notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2923
		isMeta ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2924
		    cls := cls class
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2925
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2926
		self withWaitCursorDo:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2927
		    aBlock value:cls value:sel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2928
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2929
		^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2930
	    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2931
		self warn:'no class named: %1 - spawning current' with:clsName
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2932
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2933
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2934
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2935
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2936
    classMethodListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2937
	sel := classMethodListView selectionValue.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2938
	sel notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2939
	    sel := self selectorFromClassMethodString:sel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2940
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2941
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2942
    self doClassMenu:[:currentClass | aBlock value:currentClass value:sel]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2943
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2944
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2945
classSpawn
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2946
    "create a new SystemBrowser browsing current class,
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2947
     or if there is a selection, spawn a browser on the selected class
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2948
     even a class/selector pair can be specified."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2949
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2950
    self doClassMenuWithSelection:[:cls :sel |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2951
	|browser|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2952
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2953
	cls isMeta ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2954
	    Smalltalk allBehaviorsDo:[:aClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2955
		aClass class == cls ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2956
		    browser := SystemBrowser browseClass:aClass.
95
claus
parents: 93
diff changeset
  2957
		    browser instanceProtocol:false.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2958
		    sel notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2959
			browser switchToMethodNamed:sel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2960
		    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2961
		    ^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2962
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2963
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2964
	    self warn:'oops, no class for this metaclass'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2965
	    ^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2966
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2967
	browser := SystemBrowser browseClass:cls. 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2968
	cls hasMethods ifFalse:[
95
claus
parents: 93
diff changeset
  2969
	    browser instanceProtocol:false.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2970
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2971
	sel notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2972
	    browser switchToMethodNamed:sel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2973
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2974
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2975
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2976
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2977
     select 'Smalltalk allClassesDo:' and use spawn from the class menu
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2978
     select 'Smalltalk'               and use spawn from the class menu
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2979
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2980
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2981
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2982
classSpawnHierarchy
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2983
    "create a new HierarchyBrowser browsing current class"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2984
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2985
    self doClassMenuWithSelection:[:cls :sel |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2986
	SystemBrowser browseClassHierarchy:cls 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2987
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2988
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2989
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2990
classSpawnSubclasses
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2991
    "create a new browser browsing current class's subclasses"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2992
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2993
    self doClassMenuWithSelection:[:cls :sel |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2994
	|subs|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2995
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2996
	subs := cls allSubclasses.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2997
	(subs notNil and:[subs size ~~ 0]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2998
	    SystemBrowser browseClasses:subs title:('subclasses of ' , cls name)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  2999
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3000
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3001
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3002
93
claus
parents: 92
diff changeset
  3003
classPrintOutWith:aSelector
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3004
    self doClassMenu:[:currentClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3005
	|printStream|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3006
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3007
	printStream := Printer new.
93
claus
parents: 92
diff changeset
  3008
	currentClass perform:aSelector with:printStream.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3009
	printStream close
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3010
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3011
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3012
93
claus
parents: 92
diff changeset
  3013
classPrintOutFullProtocol
claus
parents: 92
diff changeset
  3014
    self classPrintOutWith:#printOutFullProtocolOn:
claus
parents: 92
diff changeset
  3015
!
claus
parents: 92
diff changeset
  3016
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3017
classPrintOutProtocol
93
claus
parents: 92
diff changeset
  3018
    self classPrintOutWith:#printOutProtocolOn:
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3019
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3020
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3021
classPrintOut
93
claus
parents: 92
diff changeset
  3022
    self classPrintOutWith:#printOutOn:
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3023
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3024
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3025
classHierarchy
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3026
    "show current classes hierarchy in codeView"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3027
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3028
    self doClassMenu:[:currentClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3029
	|aStream|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3030
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3031
	aStream := WriteStream on:(String new:200).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3032
	actualClass printHierarchyOn:aStream.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3033
	codeView contents:(aStream contents).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3034
	codeView modified:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3035
	codeView acceptAction:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3036
	codeView explainAction:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3037
	methodListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3038
	    methodListView deselect
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3039
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3040
	aspect := #hierarchy. 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3041
	self normalLabel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3042
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3043
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3044
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3045
classNewClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3046
    "create a class-definition prototype in codeview"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3047
105
claus
parents: 98
diff changeset
  3048
    |nm cls cat|
claus
parents: 98
diff changeset
  3049
claus
parents: 98
diff changeset
  3050
    nm := 'Object'.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3051
    currentClass notNil ifTrue:[
105
claus
parents: 98
diff changeset
  3052
	(cls := currentClass superclass) notNil ifTrue:[
claus
parents: 98
diff changeset
  3053
	    nm := cls name 
claus
parents: 98
diff changeset
  3054
	]
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3055
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3056
    cat := currentClassCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3057
    cat isNil ifTrue:[
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3058
	cat := '* no category *'
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3059
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3060
    self classClassDefinitionTemplateFor:nm in:cat.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3061
    aspect := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3062
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3063
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3064
classClassInstVars
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3065
    "show class instance variables in codeView and setup accept-action
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3066
     for a class-instvar-definition change"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3067
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3068
    self doClassMenu:[:currentClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3069
	|s|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3070
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3071
	s := WriteStream on:(String new).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3072
	currentClass fileOutClassInstVarDefinitionOn:s.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3073
	codeView contents:(s contents).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3074
	codeView modified:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3075
	codeView acceptAction:[:theCode |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3076
	    codeView cursor:Cursor execute.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3077
	    Object abortSignal catch:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3078
		Compiler evaluate:theCode asString notifying:codeView compile:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3079
		codeView modified:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3080
		self updateClassList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3081
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3082
	    codeView cursor:Cursor normal.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3083
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3084
	codeView explainAction:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3085
	methodListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3086
	    methodListView deselect
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3087
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3088
	aspect := #classInstVars.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3089
	self normalLabel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3090
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3091
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3092
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3093
classSpawnFullProtocol
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3094
    "create a new browser, browsing current classes full protocol"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3095
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3096
    self doClassMenuWithSelection:[:cls :sel |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3097
	SystemBrowser browseFullClassProtocol:cls 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3098
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3099
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3100
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3101
classLoad
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3102
    "load an autoloaded class"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3103
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3104
    |nm|
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3105
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3106
    self checkClassSelected ifFalse:[^ self].
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3107
    nm := currentClass name.
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3108
    currentClass autoload.
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3109
    self switchToClassNamed:nm
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3110
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3111
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3112
classUnload
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3113
    "unload an autoloaded class"
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3114
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3115
    |nm|
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3116
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3117
    self checkClassSelected ifFalse:[^ self].
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3118
    nm := currentClass name.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3119
    currentClass unload.
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3120
    self switchToClassNamed:nm
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3121
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3122
105
claus
parents: 98
diff changeset
  3123
classInspect
claus
parents: 98
diff changeset
  3124
    "inspect the current class"
claus
parents: 98
diff changeset
  3125
claus
parents: 98
diff changeset
  3126
    self checkClassSelected ifFalse:[^ self].
claus
parents: 98
diff changeset
  3127
claus
parents: 98
diff changeset
  3128
    currentClass inspect.
claus
parents: 98
diff changeset
  3129
!
claus
parents: 98
diff changeset
  3130
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3131
classProtocols
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3132
     ^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3133
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3134
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3135
classRemove
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3136
    "user requested remove of current class and all subclasses -
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3137
     count subclasses and let user confirm removal."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3138
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3139
    |count t box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3140
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3141
    currentClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3142
	count := currentClass allSubclasses size.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3143
	t := 'remove %1'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3144
	count ~~ 0 ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3145
	   t := t , '\(with %2 subclass'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3146
	   count ~~ 1 ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3147
		t := t , 'es'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3148
	   ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3149
	   t := (t , ')') 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3150
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3151
	t := t , ' ?'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3152
	t := (resources string:t with:currentClass name with:count) withCRs.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3153
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3154
	box := YesNoBox 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3155
		   title:t
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3156
		   yesText:(resources at:'remove')
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3157
		   noText:(resources at:'abort').
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3158
	box confirm ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3159
	    "after querying user - do really remove current class
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3160
	     and all subclasses
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3161
	    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3162
	    self doClassMenu:[:currentClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3163
		|didRemove|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3164
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3165
		didRemove := false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3166
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3167
		"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3168
		 query ?
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3169
		"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3170
		currentClass allSubclassesDo:[:aSubClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3171
		    (CheckForInstancesWhenRemovingClasses not
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3172
		    or:[aSubClass hasInstances not
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3173
		    or:[self confirm:(aSubClass name , ' has instances - remove anyway ?')]])
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3174
			ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3175
			    Smalltalk removeClass:aSubClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3176
		    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3177
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3178
		(CheckForInstancesWhenRemovingClasses not
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3179
		or:[currentClass hasInstances not
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3180
		or:[self confirm:(currentClass name , ' has instances - remove anyway ?')]])
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3181
		    ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3182
			didRemove := true.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3183
			Smalltalk removeClass:currentClass.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3184
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3185
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3186
		self switchToClass:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3187
		Smalltalk changed.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3188
		self updateClassList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3189
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3190
		"if it was the last in its category, update class category list"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3191
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3192
		classListView numberOfLines == 0 ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3193
		    self updateClassCategoryListWithScroll:false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3194
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3195
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3196
		didRemove ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3197
		    methodCategoryListView notNil ifTrue:[methodCategoryListView contents:nil].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3198
		    methodListView notNil ifTrue:[methodListView contents:nil].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3199
		    codeView contents:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3200
		    codeView modified:false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3201
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3202
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3203
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3204
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3205
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3206
107
claus
parents: 106
diff changeset
  3207
classShowFrom:getSelector set:setSelector aspect:aspectSymbol default:default
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3208
    "common helper for comment, primitive-stuff etc.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3209
     show the string returned from the classes getSelector-method,
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3210
     Set acceptaction to change it via setSelector."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3211
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3212
    self doClassMenu:[:currentClass |
107
claus
parents: 106
diff changeset
  3213
	|text|
claus
parents: 106
diff changeset
  3214
claus
parents: 106
diff changeset
  3215
	text := currentClass perform:getSelector.
claus
parents: 106
diff changeset
  3216
	text isNil ifTrue:[
claus
parents: 106
diff changeset
  3217
	    text := default
claus
parents: 106
diff changeset
  3218
	].
claus
parents: 106
diff changeset
  3219
	codeView contents:text.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3220
	codeView modified:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3221
	codeView acceptAction:[:theCode |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3222
	    Object abortSignal catch:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3223
		lockUpdates := true.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3224
		currentClass perform:setSelector with:theCode asString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3225
		codeView modified:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3226
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3227
	    lockUpdates := false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3228
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3229
	codeView explainAction:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3230
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3231
	methodListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3232
	    methodListView deselect
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3233
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3234
	aspect := aspectSymbol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3235
	self normalLabel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3236
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3237
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3238
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3239
classComment
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3240
    "show the classes comment in the codeView.
93
claus
parents: 92
diff changeset
  3241
     Also, set accept action to change the comment."
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3242
107
claus
parents: 106
diff changeset
  3243
    self classShowFrom:#comment 
claus
parents: 106
diff changeset
  3244
		   set:#comment: 
claus
parents: 106
diff changeset
  3245
		aspect:#comment 
claus
parents: 106
diff changeset
  3246
	       default:nil
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3247
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3248
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3249
classPrimitiveDefinitions
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3250
    "show the classes primitiveDefinition in the codeView.
93
claus
parents: 92
diff changeset
  3251
     Also, set accept action to change it."
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3252
107
claus
parents: 106
diff changeset
  3253
    self classShowFrom:#primitiveDefinitionsString 
claus
parents: 106
diff changeset
  3254
		   set:#primitiveDefinitions: 
claus
parents: 106
diff changeset
  3255
		aspect:#primitiveDefinitions 
claus
parents: 106
diff changeset
  3256
	       default:'%{
claus
parents: 106
diff changeset
  3257
claus
parents: 106
diff changeset
  3258
/*
claus
parents: 106
diff changeset
  3259
 * includes, defines, structure definitions
claus
parents: 106
diff changeset
  3260
 * and typedefs come here.
claus
parents: 106
diff changeset
  3261
 */
claus
parents: 106
diff changeset
  3262
claus
parents: 106
diff changeset
  3263
%}'
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3264
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3265
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3266
classPrimitiveVariables
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3267
    "show the classes primitiveVariables in the codeView.
93
claus
parents: 92
diff changeset
  3268
     Also, set accept action to change it."
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3269
107
claus
parents: 106
diff changeset
  3270
    self classShowFrom:#primitiveVariablesString 
claus
parents: 106
diff changeset
  3271
		   set:#primitiveVariables: 
claus
parents: 106
diff changeset
  3272
		aspect:#primitiveVariables 
claus
parents: 106
diff changeset
  3273
	       default:'%{
claus
parents: 106
diff changeset
  3274
claus
parents: 106
diff changeset
  3275
/* 
claus
parents: 106
diff changeset
  3276
 * any local C variables
claus
parents: 106
diff changeset
  3277
 * come here (please, define as static)
claus
parents: 106
diff changeset
  3278
 */
claus
parents: 106
diff changeset
  3279
claus
parents: 106
diff changeset
  3280
%}'
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3281
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3282
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3283
classPrimitiveFunctions
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3284
    "show the classes primitiveFunctions in the codeView.
93
claus
parents: 92
diff changeset
  3285
     Also, set accept action to change it."
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3286
107
claus
parents: 106
diff changeset
  3287
    self classShowFrom:#primitiveFunctionsString 
claus
parents: 106
diff changeset
  3288
		   set:#primitiveFunctions: 
claus
parents: 106
diff changeset
  3289
		aspect:#primitiveFunctions 
claus
parents: 106
diff changeset
  3290
	       default:'%{
claus
parents: 106
diff changeset
  3291
claus
parents: 106
diff changeset
  3292
/* 
claus
parents: 106
diff changeset
  3293
 * any local C (helper) functions
claus
parents: 106
diff changeset
  3294
 * come here (please, define as static)
claus
parents: 106
diff changeset
  3295
 */
claus
parents: 106
diff changeset
  3296
claus
parents: 106
diff changeset
  3297
%}'
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3298
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3299
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3300
classNewSubclass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3301
    "create a subclass-definition prototype in codeview"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3302
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3303
    self doClassMenu:[:currentClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3304
	self classClassDefinitionTemplateFor:(currentClass name) 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3305
					  in:(currentClass category).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3306
	aspect := nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3307
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3308
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3309
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3310
classRefs
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3311
    self doClassMenu:[:currentClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3312
	self withCursor:(Cursor questionMark) do:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3313
	    SystemBrowser browseReferendsOf:currentClass name asSymbol
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3314
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3315
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3316
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3317
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3318
classUses
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3319
    "a powerful tool, when trying to learn more about where
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3320
     a class is used. This one searches all uses of a class,
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3321
     and shows a list of uses - try it and like it"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3322
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3323
    self doClassMenu:[:currentClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3324
	self withCursor:(Cursor questionMark) do:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3325
	    SystemBrowser browseUsesOf:currentClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3326
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3327
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3328
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3329
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3330
classRename
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3331
    "launch an enterBox for new name and query user"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3332
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3333
    |box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3334
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3335
    self checkClassSelected ifFalse:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3336
    box := self enterBoxTitle:(resources string:'rename %1 to:' with:currentClass name) okText:'rename'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3337
    box initialText:(currentClass name).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3338
    box action:[:aString | self renameCurrentClassTo:aString].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3339
    box showAtPointer
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3340
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3341
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3342
!BrowserView methodsFor:'unused'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3343
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3344
listOfAllSelectorsInCategory:aCategory inHierarchyOfClass:aClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3345
    "answer a list of all selectors in a given method category 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3346
     of the argument, aClass and its superclasses"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3347
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3348
    |newList|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3349
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3350
    newList := Set new.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3351
    self classesInHierarchy:aClass do:[:c |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3352
	|searchCategory|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3353
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3354
	(aCategory = '* all *') ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3355
	    newList addAll:(c selectorArray)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3356
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3357
	    (aCategory = '* no category *') ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3358
		searchCategory := nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3359
	    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3360
		searchCategory := aCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3361
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3362
	    c methodArray with:c selectorArray do:[:aMethod :selector |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3363
		(aMethod category = searchCategory) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3364
		    newList add:selector
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3365
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3366
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3367
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3368
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3369
    (newList size == 0) ifTrue:[^ nil].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3370
    ^ newList asOrderedCollection sort
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3371
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3372
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3373
listOfAllMethodCategoriesInHierarchy:aClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3374
    "answer a list of all method categories of the argument, aClass,
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3375
     and all of its superclasses"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3376
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3377
    |newList cat|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3378
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3379
    newList := Set new.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3380
    self classesInHierarchy:aClass do:[:c |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3381
	c methodArray do:[:aMethod |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3382
	    cat := aMethod category.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3383
	    cat isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3384
		cat := '* no category *'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3385
	    ].
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3386
	    newList add:cat
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3387
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3388
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3389
    (newList size == 0) ifTrue:[^ nil].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3390
    newList add:'* all *'.
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3391
    ^ newList asOrderedCollection sort
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3392
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3393
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3394
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3395
!BrowserView methodsFor:'class category stuff'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3396
129
claus
parents: 126
diff changeset
  3397
switchToAnyMethod:aSelectorString
claus
parents: 126
diff changeset
  3398
    "find all implementors of aSelectorString, and present a list
claus
parents: 126
diff changeset
  3399
     to choose from. When an entry is selected, switch to that class/selector.
claus
parents: 126
diff changeset
  3400
     This allows for quickly moving around in the system."
claus
parents: 126
diff changeset
  3401
claus
parents: 126
diff changeset
  3402
    |classes sel box theClassName|
claus
parents: 126
diff changeset
  3403
claus
parents: 126
diff changeset
  3404
    classes := OrderedCollection new.
claus
parents: 126
diff changeset
  3405
    aSelectorString knownAsSymbol ifTrue:[
claus
parents: 126
diff changeset
  3406
	sel := aSelectorString asSymbol.
claus
parents: 126
diff changeset
  3407
claus
parents: 126
diff changeset
  3408
	Smalltalk allClassesDo:[:aClass |
claus
parents: 126
diff changeset
  3409
	    (aClass implements:sel) ifTrue:[
claus
parents: 126
diff changeset
  3410
		classes add:aClass.
claus
parents: 126
diff changeset
  3411
	    ].
claus
parents: 126
diff changeset
  3412
	    (aClass class implements:sel) ifTrue:[
claus
parents: 126
diff changeset
  3413
		classes add:aClass class.
claus
parents: 126
diff changeset
  3414
	    ].
claus
parents: 126
diff changeset
  3415
	]
claus
parents: 126
diff changeset
  3416
    ].
claus
parents: 126
diff changeset
  3417
    classes size == 0 ifTrue:[
claus
parents: 126
diff changeset
  3418
	SystemBrowser showNoneFound.
claus
parents: 126
diff changeset
  3419
	^ self
claus
parents: 126
diff changeset
  3420
    ].
claus
parents: 126
diff changeset
  3421
    classes size > 1 ifTrue:[
131
claus
parents: 130
diff changeset
  3422
	box := ListSelectionBox title:(resources string:'#%1\in which class ?' with:aSelectorString) withCRs.
claus
parents: 130
diff changeset
  3423
	box okText:(resources string:'show').
claus
parents: 130
diff changeset
  3424
	box list:(classes collect:[:aClass | aClass name]) asSortedCollection.
129
claus
parents: 126
diff changeset
  3425
	box action:[:aString | theClassName := aString].
claus
parents: 126
diff changeset
  3426
	box entryCompletionBlock:[
claus
parents: 126
diff changeset
  3427
	    |s l what m|
claus
parents: 126
diff changeset
  3428
claus
parents: 126
diff changeset
  3429
	    s := box contents asString withoutSpaces.
claus
parents: 126
diff changeset
  3430
	    l := classes select:[:cls | cls name startsWith:s].
claus
parents: 126
diff changeset
  3431
	    l size > 0 ifTrue:[    
131
claus
parents: 130
diff changeset
  3432
		box list:(l collect:[:aClass | aClass name]) asSortedCollection.
129
claus
parents: 126
diff changeset
  3433
		box contents:l first name.
claus
parents: 126
diff changeset
  3434
		l size ~~ 1 ifTrue:[
claus
parents: 126
diff changeset
  3435
		    device beep
claus
parents: 126
diff changeset
  3436
		]
claus
parents: 126
diff changeset
  3437
	    ]
claus
parents: 126
diff changeset
  3438
	].
claus
parents: 126
diff changeset
  3439
	box showAtPointer.
claus
parents: 126
diff changeset
  3440
    ] ifFalse:[
claus
parents: 126
diff changeset
  3441
	theClassName := classes first name
claus
parents: 126
diff changeset
  3442
    ].
claus
parents: 126
diff changeset
  3443
claus
parents: 126
diff changeset
  3444
    theClassName notNil ifTrue:[
claus
parents: 126
diff changeset
  3445
	self switchToClassNamed:theClassName. 
claus
parents: 126
diff changeset
  3446
	self updateMethodCategoryList.
claus
parents: 126
diff changeset
  3447
	self switchToMethodNamed:aSelectorString.
claus
parents: 126
diff changeset
  3448
    ].
claus
parents: 126
diff changeset
  3449
132
claus
parents: 131
diff changeset
  3450
    "Modified: 1.9.1995 / 01:39:58 / claus"
129
claus
parents: 126
diff changeset
  3451
!
claus
parents: 126
diff changeset
  3452
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3453
listOfAllClassCategories
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3454
    "return a list of all class categories"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3455
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3456
    |newList cat|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3457
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3458
    newList := Set with:'* all *' with:'* hierarchy *'.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3459
    Smalltalk allBehaviorsDo:[:aClass |
108
claus
parents: 107
diff changeset
  3460
	aClass isMeta ifFalse:[
claus
parents: 107
diff changeset
  3461
	    cat := aClass category.
claus
parents: 107
diff changeset
  3462
	    cat isNil ifTrue:[
claus
parents: 107
diff changeset
  3463
		cat := '* no category *'
claus
parents: 107
diff changeset
  3464
	    ].
claus
parents: 107
diff changeset
  3465
	    cat ~= 'obsolete' ifTrue:[
claus
parents: 107
diff changeset
  3466
		newList add:cat
claus
parents: 107
diff changeset
  3467
	    ]
93
claus
parents: 92
diff changeset
  3468
	]
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3469
    ].
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3470
    ^ newList asOrderedCollection sort.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3471
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3472
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3473
classCategorySelectionChanged
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3474
    "class category has changed - update dependent views"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3475
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3476
    self withWaitCursorDo:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3477
	self switchToClass:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3478
	actualClass := acceptClass := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3479
	currentMethodCategory := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3480
	currentMethod := currentSelector := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3481
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3482
	self updateClassList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3483
	self updateMethodCategoryList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3484
	self updateMethodList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3485
	self updateCodeView.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3486
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3487
	codeView explainAction:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3488
	codeView acceptAction:nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3489
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3490
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3491
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3492
classCategorySelection:lineNr
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3493
    "user clicked on a class category line - show classes.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3494
     If switching to hierarchy or all, keep current selections"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3495
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3496
    |newCategory oldClass oldName classIndex|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3497
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3498
    newCategory := classCategoryListView selectionValue.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3499
    (newCategory startsWith:'*') ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3500
	"etiher all or hierarchy;
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3501
	 remember current selections and switch after showing class list"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3502
	oldClass := currentClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3503
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3504
    currentClassCategory := newCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3505
    oldClass isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3506
	self classCategorySelectionChanged
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3507
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3508
	oldName := oldClass name.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3509
	self withWaitCursorDo:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3510
	    self updateClassList
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3511
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3512
	"stupid - search for class name in (indented) list"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3513
	classIndex := classListView list findFirst:[:elem | elem endsWith:oldName].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3514
	classIndex ~~ 0 ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3515
	    classListView selection:classIndex.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3516
	    self switchToClass:(Smalltalk at:(oldName asSymbol))
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3517
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3518
	    self normalLabel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3519
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3520
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3521
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3522
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3523
updateClassCategoryListWithScroll:scroll
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3524
    |oldClassCategory oldClass oldMethodCategory oldMethod
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3525
     oldSelector newCategoryList|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3526
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3527
    classMethodListView notNil ifTrue:[ ^ self ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3528
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3529
    oldClassCategory := currentClassCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3530
    oldClass := currentClass.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3531
    oldMethodCategory := currentMethodCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3532
    oldMethod := currentMethod.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3533
    oldMethod notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3534
	oldSelector := currentSelector
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3535
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3536
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3537
    classCategoryListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3538
	newCategoryList := self listOfAllClassCategories.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3539
	newCategoryList = classCategoryListView list ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3540
	    scroll ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3541
		classCategoryListView contents:newCategoryList
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3542
	    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3543
		classCategoryListView setContents:newCategoryList
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3544
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3545
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3546
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3547
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3548
    oldClassCategory notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3549
	classCategoryListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3550
	    classCategoryListView selectElement:oldClassCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3551
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3552
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3553
    classListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3554
	oldClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3555
	    classListView selectElement:(oldClass name)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3556
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3557
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3558
    oldMethodCategory notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3559
	methodCategoryListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3560
	    methodCategoryListView selectElement:oldMethodCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3561
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3562
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3563
    oldSelector notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3564
	methodListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3565
	    methodListView selectElement:oldSelector
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3566
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3567
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3568
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3569
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3570
checkClassCategorySelected
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3571
    currentClassCategory isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3572
	self warn:'select a class category first'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3573
	^ false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3574
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3575
    ^ true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3576
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3577
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3578
updateClassCategoryList
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3579
    self updateClassCategoryListWithScroll:true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3580
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3581
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3582
renameCurrentClassCategoryTo:aString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3583
    "helper - do the rename"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3584
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3585
    |any categories|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3586
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3587
    currentClassCategory notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3588
	any := false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3589
	Smalltalk allBehaviorsDo:[:aClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3590
	    aClass category = currentClassCategory ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3591
		aClass category:aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3592
		any := true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3593
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3594
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3595
	any ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3596
	    categories := classCategoryListView list.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3597
	    categories remove:currentClassCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3598
	    categories add:aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3599
	    categories sort.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3600
	    classCategoryListView setContents:categories.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3601
	    currentClassCategory := aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3602
	    classCategoryListView selectElement:aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3603
	] ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3604
	    currentClassCategory := aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3605
	    self updateClassCategoryList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3606
	    self updateClassListWithScroll:false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3607
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3608
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3609
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3610
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3611
!BrowserView methodsFor:'class-method stuff'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3612
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3613
classFromClassMethodString:aString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3614
    "helper for classMethod-list - extract class name from the string"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3615
93
claus
parents: 92
diff changeset
  3616
"/    |pos|
claus
parents: 92
diff changeset
  3617
"/
claus
parents: 92
diff changeset
  3618
"/    pos := aString indexOf:(Character space).
claus
parents: 92
diff changeset
  3619
"/    ^ aString copyTo:(pos - 1)
claus
parents: 92
diff changeset
  3620
claus
parents: 92
diff changeset
  3621
      ^ aString upTo:Character space
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3622
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3623
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3624
selectorFromClassMethodString:aString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3625
    "helper for classMethod-list - extract selector from the string"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3626
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3627
    |pos|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3628
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3629
    pos := aString indexOf:(Character space).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3630
    ^ aString copyFrom:(pos + 1)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3631
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3632
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3633
classMethodSelection:lineNr
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3634
    "user clicked on a class/method line - show code"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3635
131
claus
parents: 130
diff changeset
  3636
    |cls string classString selectorString meta|
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3637
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3638
    string := classMethodListView selectionValue.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3639
    classString := self classFromClassMethodString:string.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3640
    selectorString := self selectorFromClassMethodString:string.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3641
    ((classString ~= 'Metaclass') and:[classString endsWith:'class']) ifTrue:[
106
claus
parents: 105
diff changeset
  3642
	classString := classString copyWithoutLast:5 "copyTo:(classString size - 5)".
131
claus
parents: 130
diff changeset
  3643
	meta := true.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3644
    ] ifFalse:[
131
claus
parents: 130
diff changeset
  3645
	meta := false.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3646
    ].
129
claus
parents: 126
diff changeset
  3647
    self switchToClass:(Smalltalk at:classString asSymbol).
131
claus
parents: 130
diff changeset
  3648
    meta ifTrue:[cls := currentClass class] ifFalse:[cls := currentClass].
claus
parents: 130
diff changeset
  3649
    actualClass := acceptClass := cls.
129
claus
parents: 126
diff changeset
  3650
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3651
    currentClass isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3652
	self warn:'oops class is gone'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3653
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3654
	currentClassCategory := currentClass category.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3655
	currentSelector := selectorString asSymbol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3656
	currentMethod := actualClass compiledMethodAt:currentSelector.
92
claus
parents: 85
diff changeset
  3657
	currentMethod isNil ifTrue:[
claus
parents: 85
diff changeset
  3658
	    self warn:'oops method is gone'
claus
parents: 85
diff changeset
  3659
	] ifFalse:[
claus
parents: 85
diff changeset
  3660
	    currentMethodCategory := currentMethod category.
claus
parents: 85
diff changeset
  3661
	].
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3662
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3663
	self methodSelectionChanged
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3664
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3665
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3666
    self setDoitActionForClass
131
claus
parents: 130
diff changeset
  3667
claus
parents: 130
diff changeset
  3668
    "Modified: 31.8.1995 / 11:56:02 / claus"
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3669
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3670
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3671
!BrowserView methodsFor:'class category list menu'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3672
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3673
classCategoryMenu
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3674
    |labels selectors|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3675
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3676
    currentClassCategory isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3677
	labels := #(
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3678
		    'spawn full class'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3679
		    '-'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3680
		    'update'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3681
		    'find class ...'
129
claus
parents: 126
diff changeset
  3682
		    'find method ...'
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3683
		    '-'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3684
		    'new class category ...'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3685
		   ).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3686
	selectors := #(
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3687
		    classCategorySpawnFullClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3688
		    nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3689
		    classCategoryUpdate
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3690
		    classCategoryFindClass
129
claus
parents: 126
diff changeset
  3691
		    classCategoryFindMethod
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3692
		    nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3693
		    classCategoryNewCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3694
		   ).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3695
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3696
	labels := #(
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3697
		    'fileOut'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3698
		    'fileOut each'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3699
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3700
		    'fileOut binary'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3701
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3702
		    'printOut' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3703
		    'printOut protocol'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3704
		    '-'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3705
		    'SPAWN_CATEGORY'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3706
		    'spawn full class'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3707
		    '-'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3708
		    'update'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3709
		    'find class ...'
129
claus
parents: 126
diff changeset
  3710
		    'find method ...'
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3711
		    '-'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3712
		    'new class category ...'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3713
		    'rename ...'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3714
		    'remove'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3715
		   ).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3716
	selectors := #(
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3717
		   classCategoryFileOut
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3718
		   classCategoryFileOutEach
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3719
		   classCategoryPrintOut
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3720
		   classCategoryPrintOutProtocol
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3721
		   nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3722
		   classCategorySpawn
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3723
		   classCategorySpawnFullClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3724
		   nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3725
		   classCategoryUpdate
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3726
		   classCategoryFindClass
129
claus
parents: 126
diff changeset
  3727
		   classCategoryFindMethod
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3728
		   nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3729
		   classCategoryNewCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3730
		   classCategoryRename
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3731
		   classCategoryRemove
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3732
		   ).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3733
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3734
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3735
    ^ PopUpMenu labels:(resources array:labels)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3736
		selectors:selectors
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3737
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3738
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3739
classCategoryUpdate
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3740
    "update class category list and dependants"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3741
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3742
    |oldClassName oldMethodCategory|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3743
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3744
    classCategoryListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3745
	currentClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3746
	    oldClassName := currentClass name.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3747
	    (oldClassName endsWith:'-old') ifTrue:[
106
claus
parents: 105
diff changeset
  3748
		oldClassName := oldClassName copyWithoutLast:4 "copyTo:(oldClassName size - 4)"
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3749
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3750
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3751
	oldMethodCategory := currentMethodCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3752
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3753
	classCategoryListView setContents:(self listOfAllClassCategories).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3754
	currentClassCategory notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3755
	    classCategoryListView selectElement:currentClassCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3756
	    self classCategorySelectionChanged.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3757
	    oldClassName notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3758
		classListView selectElement:oldClassName.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3759
		self switchToClass:(Smalltalk at:oldClassName asSymbol).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3760
		self classSelectionChanged.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3761
		oldMethodCategory notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3762
		    methodCategoryListView selectElement:oldMethodCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3763
		    currentMethodCategory := oldMethodCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3764
		    self methodCategorySelectionChanged
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3765
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3766
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3767
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3768
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3769
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3770
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3771
classCategoryPrintOutProtocol
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3772
    |printStream|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3773
106
claus
parents: 105
diff changeset
  3774
    Smalltalk allClassesInCategory:currentClassCategory inOrderDo:[:aClass |
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3775
	printStream := Printer new.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3776
	aClass printOutProtocolOn:printStream.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3777
	printStream close
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3778
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3779
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3780
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3781
classCategoryPrintOut
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3782
    |printStream|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3783
106
claus
parents: 105
diff changeset
  3784
    Smalltalk allClassesInCategory:currentClassCategory do:[:aClass |
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3785
	printStream := Printer new.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3786
	aClass printOutOn:printStream.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3787
	printStream close
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3788
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3789
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3790
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3791
classCategorySpawn
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3792
    "create a new SystemBrowser browsing current classCategory"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3793
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3794
    currentClassCategory notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3795
	self withWaitCursorDo:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3796
	    SystemBrowser browseClassCategory:currentClassCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3797
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3798
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3799
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3800
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3801
classCategoryFileOut
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3802
    "create a file 'categoryName' consisting of all classes in current category"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3803
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3804
    |aStream fileName|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3805
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3806
    self checkClassCategorySelected ifFalse:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3807
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3808
    fileName := currentClassCategory asString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3809
    fileName replaceAll:Character space by:$_.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3810
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3811
     this test allows a smalltalk to be built without Projects/ChangeSets
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3812
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3813
    Project notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3814
	fileName := Project currentProjectDirectory , fileName.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3815
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3816
106
claus
parents: 105
diff changeset
  3817
    self withWaitCursorDo:[
claus
parents: 105
diff changeset
  3818
	"
claus
parents: 105
diff changeset
  3819
	 if file exists, save original in a .sav file
claus
parents: 105
diff changeset
  3820
	"
claus
parents: 105
diff changeset
  3821
	fileName asFilename exists ifTrue:[
claus
parents: 105
diff changeset
  3822
	    self busyLabel:'saving existing %1' with:fileName.
claus
parents: 105
diff changeset
  3823
	    fileName asFilename copyTo:(fileName , '.sav')
claus
parents: 105
diff changeset
  3824
	].
claus
parents: 105
diff changeset
  3825
claus
parents: 105
diff changeset
  3826
	aStream := FileStream newFileNamed:fileName.
claus
parents: 105
diff changeset
  3827
	aStream isNil ifTrue:[
claus
parents: 105
diff changeset
  3828
	    self warn:'cannot create: %1' with:fileName
claus
parents: 105
diff changeset
  3829
	] ifFalse:[
claus
parents: 105
diff changeset
  3830
	    self busyLabel:'writing: %1' with:fileName.
claus
parents: 105
diff changeset
  3831
	    Smalltalk allClassesInCategory:currentClassCategory inOrderDo:[:aClass |
claus
parents: 105
diff changeset
  3832
		aClass fileOutOn:aStream.
claus
parents: 105
diff changeset
  3833
	    ].
claus
parents: 105
diff changeset
  3834
	    aStream close.
claus
parents: 105
diff changeset
  3835
	]
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3836
    ].
106
claus
parents: 105
diff changeset
  3837
    self normalLabel.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3838
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3839
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3840
classCategorySpawnFullClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3841
    "create a new SystemBrowser browsing full class"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3842
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3843
    |newBrowser|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3844
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3845
    self withWaitCursorDo:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3846
	newBrowser := SystemBrowser browseFullClasses
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3847
" "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3848
	.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3849
	currentClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3850
	    newBrowser switchToClassNamed:(currentClass name)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3851
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3852
" "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3853
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3854
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3855
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3856
classCategoryFileOutEach
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3857
    self withWaitCursorDo:[
106
claus
parents: 105
diff changeset
  3858
	Smalltalk allClassesInCategory:currentClassCategory do:[:aClass |
claus
parents: 105
diff changeset
  3859
	    self busyLabel:'saving: %1' with:aClass name.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3860
	    Class fileOutErrorSignal handle:[:ex |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3861
		self warn:'cannot create: %1' with:ex parameter.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3862
		ex return.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3863
	    ] do:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3864
		aClass fileOut
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3865
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3866
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3867
	self normalLabel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3868
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3869
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3870
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3871
classCategoryNewCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3872
    |box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3873
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3874
    box := self enterBoxTitle:'name of new class category:' okText:'create'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3875
    box action:[:aString |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3876
	|categories|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3877
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3878
	currentClass notNil ifTrue:[
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3879
	    categories := Set new.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3880
	    currentClass withAllSuperclasses do:[:aClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3881
		aClass methodArray do:[:aMethod |
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3882
		    categories add:aMethod category
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3883
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3884
	    ].
79
d78f92a07d5d *** empty log message ***
claus
parents: 74
diff changeset
  3885
	    categories := categories asOrderedCollection
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3886
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3887
	categories isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3888
	    categories := classCategoryListView list.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3889
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3890
	(categories includes:aString) ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3891
	    categories add:aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3892
	    categories sort.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3893
	    classCategoryListView setContents:categories.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3894
	    currentClassCategory := aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3895
	    classCategoryListView selectElement:aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3896
	    self switchToClass:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3897
	    actualClass := acceptClass := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3898
	    self classCategorySelectionChanged
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3899
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3900
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3901
    box showAtPointer
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3902
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3903
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3904
classCategoryFindClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3905
    |box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3906
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3907
    box := self enterBoxForCodeSelectionTitle:'class to find:' okText:'find'.
118
claus
parents: 117
diff changeset
  3908
    box entryCompletionBlock:[
claus
parents: 117
diff changeset
  3909
	|s what m|
claus
parents: 117
diff changeset
  3910
claus
parents: 117
diff changeset
  3911
	s := box contents asString withoutSpaces.
claus
parents: 117
diff changeset
  3912
	what := Smalltalk classnameCompletion:s.
claus
parents: 117
diff changeset
  3913
	box contents:what first.
claus
parents: 117
diff changeset
  3914
	(what at:2) size ~~ 1 ifTrue:[
claus
parents: 117
diff changeset
  3915
	    device beep
claus
parents: 117
diff changeset
  3916
	]
claus
parents: 117
diff changeset
  3917
    ].
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3918
    box action:[:aString | self switchToClassNameMatching:aString].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3919
    box showAtPointer
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3920
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3921
129
claus
parents: 126
diff changeset
  3922
classCategoryFindMethod
claus
parents: 126
diff changeset
  3923
    |box|
claus
parents: 126
diff changeset
  3924
claus
parents: 126
diff changeset
  3925
    box := self listBoxForCodeSelectionTitle:'selector to find:' okText:'find'.
claus
parents: 126
diff changeset
  3926
    box entryCompletionBlock:[
claus
parents: 126
diff changeset
  3927
	|s what m|
claus
parents: 126
diff changeset
  3928
130
claus
parents: 129
diff changeset
  3929
	s := box contents.
claus
parents: 129
diff changeset
  3930
	s isNil ifTrue:[s := ''].
claus
parents: 129
diff changeset
  3931
	s := s asString withoutSpaces.
129
claus
parents: 126
diff changeset
  3932
	box topView withWaitCursorDo:[
claus
parents: 126
diff changeset
  3933
	    what := Smalltalk selectorCompletion:s.
claus
parents: 126
diff changeset
  3934
	    box list:(what at:2).
claus
parents: 126
diff changeset
  3935
	    box contents:what first.
claus
parents: 126
diff changeset
  3936
	    (what at:2) size ~~ 1 ifTrue:[
claus
parents: 126
diff changeset
  3937
		device beep
claus
parents: 126
diff changeset
  3938
	    ]
claus
parents: 126
diff changeset
  3939
	]
claus
parents: 126
diff changeset
  3940
    ].
claus
parents: 126
diff changeset
  3941
    box action:[:aString | self switchToAnyMethod:aString].
claus
parents: 126
diff changeset
  3942
    box showAtPointer
claus
parents: 126
diff changeset
  3943
claus
parents: 126
diff changeset
  3944
    "Modified: 30.8.1995 / 22:49:49 / claus"
claus
parents: 126
diff changeset
  3945
!
claus
parents: 126
diff changeset
  3946
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3947
classCategoryRename
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3948
    "launch an enterBox to rename current class category"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3949
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3950
    |box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3951
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3952
    self checkClassCategorySelected ifFalse:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3953
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3954
    box := self enterBoxTitle:'rename class category to:' okText:'rename'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3955
    box initialText:currentClassCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3956
    box action:[:aString | self renameCurrentClassCategoryTo:aString].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3957
    box showAtPointer
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3958
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3959
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3960
classCategoryRemove
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3961
    "remove all classes in current category"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3962
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3963
    |count t classesToRemove subclassesRemoved box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3964
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3965
    self checkClassCategorySelected ifFalse:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3966
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3967
    classesToRemove := OrderedCollection new.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3968
    Smalltalk allBehaviorsDo:[:aClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3969
	aClass category = currentClassCategory ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3970
	    classesToRemove add:aClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3971
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3972
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3973
    subclassesRemoved := OrderedCollection new.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3974
    classesToRemove do:[:aClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3975
	aClass allSubclassesDo:[:aSubclass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3976
	    (classesToRemove includes:aSubclass) ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3977
		(subclassesRemoved includes:aSubclass) ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3978
		    subclassesRemoved add:aSubclass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3979
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3980
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3981
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3982
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3983
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3984
    count := classesToRemove size.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3985
    t := resources string:'remove %1 ?' with:currentClassCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3986
    count ~~ 0 ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3987
       t := t , (resources at:'\(with ') , count printString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3988
       count == 1 ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3989
	    t := t , (resources at:' class')
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3990
       ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3991
	    t := t , (resources at:' classes')
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3992
       ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3993
       t := (t , ')') withCRs
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3994
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3995
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3996
    count := subclassesRemoved size.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3997
    count ~~ 0 ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3998
       t := t , (resources at:'\(and ') , count printString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  3999
       count == 1 ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4000
	    t := t , (resources at:' subclass ')
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4001
       ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4002
	    t := t , (resources at:' subclasses ')
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4003
       ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4004
       t := (t , ')') withCRs
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4005
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4006
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4007
    t := t withCRs.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4008
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4009
    box := YesNoBox 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4010
	       title:t
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4011
	       yesText:(resources at:'remove')
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4012
	       noText:(resources at:'abort').
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4013
    box confirm ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4014
	"after querying user - do really remove classes in list1 and list2"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4015
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4016
	subclassesRemoved do:[:aClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4017
	    (CheckForInstancesWhenRemovingClasses not
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4018
	    or:[aClass hasInstances not
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4019
	    or:[self confirm:(aClass name , ' has instances - remove anyway ?')]])
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4020
		ifTrue:[   
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4021
		    Smalltalk removeClass:aClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4022
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4023
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4024
	classesToRemove do:[:aClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4025
	    (CheckForInstancesWhenRemovingClasses not
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4026
	    or:[aClass hasInstances not
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4027
	    or:[self confirm:(aClass name , ' has instances - remove anyway ?')]])
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4028
		ifTrue:[   
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4029
		    Smalltalk removeClass:aClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4030
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4031
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4032
	currentClassCategory := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4033
	self switchToClass:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4034
	Smalltalk changed
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4035
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4036
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4037
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4038
!BrowserView methodsFor:'method list menu'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4039
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4040
methodMenu
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4041
    "return a popupmenu as appropriate for the methodList"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4042
107
claus
parents: 106
diff changeset
  4043
    |m labels selectors 
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4044
     newLabels newSelectors
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4045
     mthdLabels mthdSelectors
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4046
     brkLabels brkSelectors
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4047
     fileLabels fileSelectors
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4048
     searchLabels searchSelectors
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4049
     sepLocalLabels sepLocalSelectors
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4050
     localSearchLabels localSearchSelectors|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4051
105
claus
parents: 98
diff changeset
  4052
    device ctrlDown ifTrue:[
claus
parents: 98
diff changeset
  4053
	"/ 'secret' developpers menu
claus
parents: 98
diff changeset
  4054
107
claus
parents: 106
diff changeset
  4055
	currentMethod isNil ifTrue:[
claus
parents: 106
diff changeset
  4056
	    methodListView flash.
claus
parents: 106
diff changeset
  4057
	    ^ nil
claus
parents: 106
diff changeset
  4058
	].
105
claus
parents: 98
diff changeset
  4059
	labels := #(
claus
parents: 98
diff changeset
  4060
			'inspect method'
117
claus
parents: 114
diff changeset
  4061
			'compile to machine code'
claus
parents: 114
diff changeset
  4062
			'decompile'
107
claus
parents: 106
diff changeset
  4063
			'-'
claus
parents: 106
diff changeset
  4064
			'make private'
claus
parents: 106
diff changeset
  4065
			'make protected'
claus
parents: 106
diff changeset
  4066
			'make public'
105
claus
parents: 98
diff changeset
  4067
		   ).
claus
parents: 98
diff changeset
  4068
	selectors := #(
claus
parents: 98
diff changeset
  4069
			methodInspect
117
claus
parents: 114
diff changeset
  4070
			methodSTCCompile
110
claus
parents: 109
diff changeset
  4071
			methodDecompile
107
claus
parents: 106
diff changeset
  4072
			nil
claus
parents: 106
diff changeset
  4073
			methodMakePrivate
claus
parents: 106
diff changeset
  4074
			methodMakeProtected
claus
parents: 106
diff changeset
  4075
			methodMakePublic
105
claus
parents: 98
diff changeset
  4076
		      )
claus
parents: 98
diff changeset
  4077
    ] ifFalse:[
claus
parents: 98
diff changeset
  4078
claus
parents: 98
diff changeset
  4079
	sepLocalLabels := sepLocalSelectors := #().
claus
parents: 98
diff changeset
  4080
claus
parents: 98
diff changeset
  4081
	searchLabels := #(
claus
parents: 98
diff changeset
  4082
				    'senders ...'
claus
parents: 98
diff changeset
  4083
				    'implementors ...'
claus
parents: 98
diff changeset
  4084
				    'globals ...'
claus
parents: 98
diff changeset
  4085
				    'string search ...'
claus
parents: 98
diff changeset
  4086
				    'apropos ...'
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4087
			).
105
claus
parents: 98
diff changeset
  4088
	searchSelectors := #(
claus
parents: 98
diff changeset
  4089
				    methodSenders
claus
parents: 98
diff changeset
  4090
				    methodImplementors
claus
parents: 98
diff changeset
  4091
				    methodGlobalReferends
claus
parents: 98
diff changeset
  4092
				    methodStringSearch
claus
parents: 98
diff changeset
  4093
				    methodAproposSearch
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4094
			    ).
105
claus
parents: 98
diff changeset
  4095
claus
parents: 98
diff changeset
  4096
	currentClass notNil ifTrue:[
claus
parents: 98
diff changeset
  4097
	    localSearchLabels := #(
claus
parents: 98
diff changeset
  4098
				    '-'
claus
parents: 98
diff changeset
  4099
				    'local senders ...'
claus
parents: 98
diff changeset
  4100
				    'local implementors ...'
claus
parents: 98
diff changeset
  4101
				    'local string search ...'
claus
parents: 98
diff changeset
  4102
				    'local apropos ...'
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4103
				).
105
claus
parents: 98
diff changeset
  4104
	    localSearchSelectors := #(
claus
parents: 98
diff changeset
  4105
				    nil
claus
parents: 98
diff changeset
  4106
				    methodLocalSenders
claus
parents: 98
diff changeset
  4107
				    methodLocalImplementors
claus
parents: 98
diff changeset
  4108
				    methodLocalStringSearch
claus
parents: 98
diff changeset
  4109
				    methodLocalAproposSearch
claus
parents: 98
diff changeset
  4110
				  ).
claus
parents: 98
diff changeset
  4111
	] ifFalse:[
claus
parents: 98
diff changeset
  4112
	    localSearchLabels := localSearchSelectors := #()
claus
parents: 98
diff changeset
  4113
	].
claus
parents: 98
diff changeset
  4114
claus
parents: 98
diff changeset
  4115
	currentMethodCategory notNil ifTrue:[
claus
parents: 98
diff changeset
  4116
	    sepLocalLabels := #('-'). sepLocalSelectors := #(nil).
claus
parents: 98
diff changeset
  4117
claus
parents: 98
diff changeset
  4118
	    newLabels :=           #(
claus
parents: 98
diff changeset
  4119
				    'new method' 
claus
parents: 98
diff changeset
  4120
				    ).
claus
parents: 98
diff changeset
  4121
claus
parents: 98
diff changeset
  4122
	    newSelectors :=    #(
claus
parents: 98
diff changeset
  4123
				    methodNewMethod
claus
parents: 98
diff changeset
  4124
				 ).
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4125
	] ifFalse:[
105
claus
parents: 98
diff changeset
  4126
	    newLabels := newSelectors := #()
claus
parents: 98
diff changeset
  4127
	].
claus
parents: 98
diff changeset
  4128
claus
parents: 98
diff changeset
  4129
	currentMethod notNil ifTrue:[
claus
parents: 98
diff changeset
  4130
	    fileLabels :=           #(
claus
parents: 98
diff changeset
  4131
				    'fileOut'
claus
parents: 98
diff changeset
  4132
				    'printOut'
claus
parents: 98
diff changeset
  4133
				    '-'
claus
parents: 98
diff changeset
  4134
				    'SPAWN_METHOD'
claus
parents: 98
diff changeset
  4135
				    '-'
claus
parents: 98
diff changeset
  4136
				    ).
claus
parents: 98
diff changeset
  4137
claus
parents: 98
diff changeset
  4138
	    fileSelectors :=    #(
claus
parents: 98
diff changeset
  4139
				    methodFileOut
claus
parents: 98
diff changeset
  4140
				    methodPrintOut
claus
parents: 98
diff changeset
  4141
				    nil
claus
parents: 98
diff changeset
  4142
				    methodSpawn
claus
parents: 98
diff changeset
  4143
				    nil
claus
parents: 98
diff changeset
  4144
				 ).
claus
parents: 98
diff changeset
  4145
claus
parents: 98
diff changeset
  4146
	    sepLocalLabels := #('-'). sepLocalSelectors := #(nil).
claus
parents: 98
diff changeset
  4147
claus
parents: 98
diff changeset
  4148
	    mthdLabels :=           #(
claus
parents: 98
diff changeset
  4149
				    'change category ...' 
claus
parents: 98
diff changeset
  4150
				    'remove'
claus
parents: 98
diff changeset
  4151
				    ).
claus
parents: 98
diff changeset
  4152
claus
parents: 98
diff changeset
  4153
	    mthdSelectors :=    #(
claus
parents: 98
diff changeset
  4154
				    methodChangeCategory
claus
parents: 98
diff changeset
  4155
				    methodRemove
claus
parents: 98
diff changeset
  4156
				 ).
claus
parents: 98
diff changeset
  4157
claus
parents: 98
diff changeset
  4158
	    currentMethod isWrapped ifTrue:[
claus
parents: 98
diff changeset
  4159
		brkLabels := #(
claus
parents: 98
diff changeset
  4160
				    'remove break/trace' 
claus
parents: 98
diff changeset
  4161
				    '-'
claus
parents: 98
diff changeset
  4162
			      ).
claus
parents: 98
diff changeset
  4163
claus
parents: 98
diff changeset
  4164
		brkSelectors := #(
claus
parents: 98
diff changeset
  4165
				    methodRemoveBreakOrTrace
claus
parents: 98
diff changeset
  4166
				    nil
claus
parents: 98
diff changeset
  4167
				 )
claus
parents: 98
diff changeset
  4168
	    ] ifFalse:[
claus
parents: 98
diff changeset
  4169
		brkLabels := #(
claus
parents: 98
diff changeset
  4170
				    'breakpoint' 
claus
parents: 98
diff changeset
  4171
				    'trace' 
claus
parents: 98
diff changeset
  4172
				    'trace sender' 
claus
parents: 98
diff changeset
  4173
				    '-'
claus
parents: 98
diff changeset
  4174
			      ).
claus
parents: 98
diff changeset
  4175
claus
parents: 98
diff changeset
  4176
		brkSelectors := #(
claus
parents: 98
diff changeset
  4177
				    methodBreakPoint
claus
parents: 98
diff changeset
  4178
				    methodTrace
claus
parents: 98
diff changeset
  4179
				    methodTraceSender
claus
parents: 98
diff changeset
  4180
				    nil
claus
parents: 98
diff changeset
  4181
				 )
claus
parents: 98
diff changeset
  4182
	    ]
claus
parents: 98
diff changeset
  4183
	] ifFalse:[
claus
parents: 98
diff changeset
  4184
	    fileLabels := fileSelectors := #().
claus
parents: 98
diff changeset
  4185
	    brkLabels := brkSelectors := #().
claus
parents: 98
diff changeset
  4186
	    mthdLabels := mthdSelectors := #().
claus
parents: 98
diff changeset
  4187
	].
claus
parents: 98
diff changeset
  4188
claus
parents: 98
diff changeset
  4189
claus
parents: 98
diff changeset
  4190
claus
parents: 98
diff changeset
  4191
	labels :=
claus
parents: 98
diff changeset
  4192
		    fileLabels ,
claus
parents: 98
diff changeset
  4193
		    searchLabels ,
claus
parents: 98
diff changeset
  4194
		    localSearchLabels ,
claus
parents: 98
diff changeset
  4195
		    sepLocalLabels ,
claus
parents: 98
diff changeset
  4196
		    brkLabels ,
claus
parents: 98
diff changeset
  4197
		    newLabels ,
claus
parents: 98
diff changeset
  4198
		    mthdLabels.
claus
parents: 98
diff changeset
  4199
claus
parents: 98
diff changeset
  4200
	selectors :=
claus
parents: 98
diff changeset
  4201
		    fileSelectors ,
claus
parents: 98
diff changeset
  4202
		    searchSelectors ,
claus
parents: 98
diff changeset
  4203
		    localSearchSelectors ,
claus
parents: 98
diff changeset
  4204
		    sepLocalSelectors ,
claus
parents: 98
diff changeset
  4205
		    brkSelectors ,
claus
parents: 98
diff changeset
  4206
		    newSelectors ,
claus
parents: 98
diff changeset
  4207
		    mthdSelectors.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4208
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4209
"
105
claus
parents: 98
diff changeset
  4210
	labels := #(
claus
parents: 98
diff changeset
  4211
				    'fileOut'
claus
parents: 98
diff changeset
  4212
				    'printOut'
claus
parents: 98
diff changeset
  4213
				    '-'
claus
parents: 98
diff changeset
  4214
				    'SPAWN_METHOD'
claus
parents: 98
diff changeset
  4215
				    '-'
claus
parents: 98
diff changeset
  4216
				    'senders ...'
claus
parents: 98
diff changeset
  4217
				    'implementors ...'
claus
parents: 98
diff changeset
  4218
				    'globals ...'
claus
parents: 98
diff changeset
  4219
				    'string search ...'
claus
parents: 98
diff changeset
  4220
				    'apropos ...'
claus
parents: 98
diff changeset
  4221
				    '-'
claus
parents: 98
diff changeset
  4222
				    'local senders ...'
claus
parents: 98
diff changeset
  4223
				    'local implementors ...'
claus
parents: 98
diff changeset
  4224
				    'local string search ...'
claus
parents: 98
diff changeset
  4225
				    'local apropos ...'
claus
parents: 98
diff changeset
  4226
				    '-'
claus
parents: 98
diff changeset
  4227
				    'breakpoint' 
claus
parents: 98
diff changeset
  4228
				    'trace' 
claus
parents: 98
diff changeset
  4229
				    'trace sender' 
claus
parents: 98
diff changeset
  4230
				    '-'
claus
parents: 98
diff changeset
  4231
				    'new method' 
claus
parents: 98
diff changeset
  4232
				    'change category ...' 
claus
parents: 98
diff changeset
  4233
				    'remove'
claus
parents: 98
diff changeset
  4234
				).
claus
parents: 98
diff changeset
  4235
	 selectors := #(
claus
parents: 98
diff changeset
  4236
				    methodFileOut
claus
parents: 98
diff changeset
  4237
				    methodPrintOut
claus
parents: 98
diff changeset
  4238
				    nil
claus
parents: 98
diff changeset
  4239
				    methodSpawn
claus
parents: 98
diff changeset
  4240
				    nil
claus
parents: 98
diff changeset
  4241
				    methodSenders
claus
parents: 98
diff changeset
  4242
				    methodImplementors
claus
parents: 98
diff changeset
  4243
				    methodGlobalReferends
claus
parents: 98
diff changeset
  4244
				    methodStringSearch
claus
parents: 98
diff changeset
  4245
				    methodAproposSearch
claus
parents: 98
diff changeset
  4246
				    nil
claus
parents: 98
diff changeset
  4247
				    methodLocalSenders
claus
parents: 98
diff changeset
  4248
				    methodLocalImplementors
claus
parents: 98
diff changeset
  4249
				    methodLocalStringSearch
claus
parents: 98
diff changeset
  4250
				    methodLocalAproposSearch
claus
parents: 98
diff changeset
  4251
				    nil
claus
parents: 98
diff changeset
  4252
				    methodBreakPoint
claus
parents: 98
diff changeset
  4253
				    methodTrace
claus
parents: 98
diff changeset
  4254
				    methodTraceSender
claus
parents: 98
diff changeset
  4255
				    nil
claus
parents: 98
diff changeset
  4256
				    methodNewMethod
claus
parents: 98
diff changeset
  4257
				    methodChangeCategory
claus
parents: 98
diff changeset
  4258
				    methodRemove
claus
parents: 98
diff changeset
  4259
				  )
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4260
"
105
claus
parents: 98
diff changeset
  4261
    ].
107
claus
parents: 106
diff changeset
  4262
    m := PopUpMenu
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4263
	 labels:(resources array:labels)
107
claus
parents: 106
diff changeset
  4264
	 selectors:selectors.
claus
parents: 106
diff changeset
  4265
claus
parents: 106
diff changeset
  4266
    currentMethod notNil ifTrue:[
claus
parents: 106
diff changeset
  4267
	currentMethod isPrivate ifTrue:[
claus
parents: 106
diff changeset
  4268
	    m disable:#methodMakePrivate
claus
parents: 106
diff changeset
  4269
	].
claus
parents: 106
diff changeset
  4270
	currentMethod isProtected ifTrue:[
claus
parents: 106
diff changeset
  4271
	    m disable:#methodMakeProtected
claus
parents: 106
diff changeset
  4272
	].
claus
parents: 106
diff changeset
  4273
	currentMethod isPublic ifTrue:[
claus
parents: 106
diff changeset
  4274
	    m disable:#methodMakePublic
claus
parents: 106
diff changeset
  4275
	].
claus
parents: 106
diff changeset
  4276
    ].
117
claus
parents: 114
diff changeset
  4277
    currentMethod notNil ifTrue:[
claus
parents: 114
diff changeset
  4278
	(currentMethod code notNil
claus
parents: 114
diff changeset
  4279
	or:[Compiler canCreateMachineCode not]) ifTrue:[
claus
parents: 114
diff changeset
  4280
	    m disable:#methodSTCCompile
claus
parents: 114
diff changeset
  4281
	].
claus
parents: 114
diff changeset
  4282
	currentMethod byteCode isNil ifTrue:[
claus
parents: 114
diff changeset
  4283
	    m disable:#methodDecompile
claus
parents: 114
diff changeset
  4284
	].
claus
parents: 114
diff changeset
  4285
    ].
107
claus
parents: 106
diff changeset
  4286
    ^ m
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4287
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4288
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4289
methodRemove
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4290
    "remove the current method"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4291
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4292
    self checkMethodSelected ifFalse:[^ self].
93
claus
parents: 92
diff changeset
  4293
    actualClass removeSelector:(actualClass selectorAtMethod:currentMethod).
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4294
    currentMethod := currentSelector := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4295
    self updateMethodListWithScroll:false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4296
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4297
124
claus
parents: 123
diff changeset
  4298
methodPrivacy:how
claus
parents: 123
diff changeset
  4299
    "change the current methods privacy.
107
claus
parents: 106
diff changeset
  4300
     EXPERIMENTAL"
claus
parents: 106
diff changeset
  4301
claus
parents: 106
diff changeset
  4302
    self checkMethodSelected ifFalse:[^ self].
123
claus
parents: 120
diff changeset
  4303
    currentMethod isPublic ifFalse:[
124
claus
parents: 123
diff changeset
  4304
	currentMethod privacy:how.
claus
parents: 123
diff changeset
  4305
	actualClass addChangeRecordForMethodPrivacy:currentMethod.
123
claus
parents: 120
diff changeset
  4306
	self updateMethodListWithScroll:false keepSelection:true.
claus
parents: 120
diff changeset
  4307
    ]
124
claus
parents: 123
diff changeset
  4308
!
claus
parents: 123
diff changeset
  4309
claus
parents: 123
diff changeset
  4310
methodMakePublic
claus
parents: 123
diff changeset
  4311
    "make the current method public.
claus
parents: 123
diff changeset
  4312
     EXPERIMENTAL"
claus
parents: 123
diff changeset
  4313
claus
parents: 123
diff changeset
  4314
    self methodPrivacy:#public 
107
claus
parents: 106
diff changeset
  4315
!
claus
parents: 106
diff changeset
  4316
claus
parents: 106
diff changeset
  4317
methodMakeProtected
claus
parents: 106
diff changeset
  4318
    "make the current method protected.
claus
parents: 106
diff changeset
  4319
     EXPERIMENTAL"
claus
parents: 106
diff changeset
  4320
124
claus
parents: 123
diff changeset
  4321
    self methodPrivacy:#protected 
107
claus
parents: 106
diff changeset
  4322
!
claus
parents: 106
diff changeset
  4323
claus
parents: 106
diff changeset
  4324
methodMakePrivate
claus
parents: 106
diff changeset
  4325
    "make the current method private.
claus
parents: 106
diff changeset
  4326
     EXPERIMENTAL"
claus
parents: 106
diff changeset
  4327
124
claus
parents: 123
diff changeset
  4328
    self methodPrivacy:#private 
107
claus
parents: 106
diff changeset
  4329
!
claus
parents: 106
diff changeset
  4330
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4331
methodSenders
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4332
    "launch an enterBox for selector to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4333
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4334
    self askForSelectorTitle:'selector to browse senders of:' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4335
		    openWith:#browseAllCallsOn:
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4336
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4337
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4338
methodImplementors
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4339
    "launch an enterBox for selector to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4340
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4341
    self askForSelectorTitle:'selector to browse implementors of:' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4342
		    openWith:#browseImplementorsOf:
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4343
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4344
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4345
methodLocalSenders
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4346
    "launch an enterBox for selector to search for in current class & subclasses"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4347
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4348
    self checkClassSelected ifFalse:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4349
    self askForSelectorTitle:'selector to browse local senders of:' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4350
		    openWith:#browseCallsOn:under:
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4351
			 and:currentClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4352
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4353
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4354
methodPrintOut
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4355
    "print out the current method"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4356
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4357
    |printStream|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4358
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4359
    self checkMethodSelected ifFalse:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4360
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4361
    printStream := Printer new.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4362
    actualClass printOutSource:(currentMethod source) on:printStream.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4363
    printStream close
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4364
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4365
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4366
methodLocalImplementors
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4367
    "launch an enterBox for selector to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4368
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4369
    self checkClassSelected ifFalse:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4370
    self askForSelectorTitle:'selector to browse local implementors of:' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4371
		    openWith:#browseImplementorsOf:under:
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4372
			 and:currentClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4373
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4374
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4375
methodGlobalReferends
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4376
    "launch an enterBox for global symbol to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4377
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4378
    self enterBoxForBrowseTitle:'global variable to browse users of:'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4379
			 action:[:aString | 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4380
				    SystemBrowser browseReferendsOf:aString asSymbol
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4381
				]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4382
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4383
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4384
methodSpawn
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4385
    "create a new SystemBrowser browsing current method,
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4386
     or if the current selection is of the form 'class>>selector', spawan
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4387
     a browser on that method."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4388
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4389
    |s sel selSymbol clsName clsSymbol cls isMeta w|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4390
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4391
    classMethodListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4392
	s := classMethodListView selectionValue.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4393
	clsName := self classFromClassMethodString:s.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4394
	sel := self selectorFromClassMethodString:s.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4395
	isMeta := false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4396
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4397
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4398
    self extractClassAndSelectorFromSelectionInto:[:c :s :m |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4399
	clsName := c.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4400
	sel := s.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4401
	isMeta := m
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4402
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4403
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4404
    (sel notNil and:[clsName notNil]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4405
	(clsName knownAsSymbol and:[sel knownAsSymbol]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4406
	    clsSymbol := clsName asSymbol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4407
	    (Smalltalk includesKey:clsSymbol) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4408
		cls := Smalltalk at:clsSymbol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4409
		isMeta ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4410
		    cls := cls class
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4411
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4412
		cls isBehavior ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4413
		    cls := cls class
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4414
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4415
		cls isBehavior ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4416
		    selSymbol := sel asSymbol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4417
		    self withWaitCursorDo:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4418
			(cls implements:selSymbol) ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4419
			    cls := cls class.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4420
			].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4421
			(cls implements:selSymbol) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4422
			    SystemBrowser browseClass:cls selector:selSymbol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4423
			    ^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4424
			].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4425
			w := ' does not implement #' , sel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4426
		    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4427
		] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4428
		    w := ' is not a class'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4429
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4430
	    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4431
		w := ' is unknown'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4432
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4433
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4434
	    w := ' and/or ' , sel , ' are unknown'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4435
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4436
	self warn:(clsName , w).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4437
	^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4438
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4439
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4440
    self checkMethodSelected ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4441
	self warn:'select a method first'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4442
	^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4443
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4444
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4445
    self withWaitCursorDo:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4446
	w := currentMethod who.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4447
	SystemBrowser browseClass:(w at:1) selector:(w at:2)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4448
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4449
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4450
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4451
methodChangeCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4452
    "move the current method into another category -
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4453
     nothing done here, but a query for the new category.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4454
     Remember the last category, to allow faster category change of a group of methods."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4455
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4456
    |box txt|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4457
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4458
    self checkMethodSelected ifFalse:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4459
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4460
    actualClass isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4461
	box := self enterBoxTitle:'' okText:'change'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4462
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4463
	|someCategories|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4464
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4465
	someCategories := actualClass categories sort.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4466
	box := self listBoxTitle:'' okText:'change' list:someCategories.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4467
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4468
    box title:('change category from ''' , currentMethod category , ''' to:').
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4469
    lastMethodCategory isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4470
	txt := currentMethod category.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4471
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4472
	txt := lastMethodCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4473
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4474
    box initialText:txt.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4475
    box action:[:aString |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4476
		    lastMethodCategory := aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4477
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4478
		    currentMethod category:aString asSymbol.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4479
		    actualClass changed.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4480
		    currentMethod changed:#category.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4481
		    actualClass addChangeRecordForMethodCategory:currentMethod category:aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4482
		    self updateMethodCategoryListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4483
		    self updateMethodListWithScroll:false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4484
	       ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4485
    box showAtPointer
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4486
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4487
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4488
methodFileOut
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4489
    "file out the current method"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4490
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4491
    self checkMethodSelected ifFalse:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4492
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4493
    self busyLabel:'saving:' with:currentSelector.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4494
    Class fileOutErrorSignal handle:[:ex |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4495
	self warn:'cannot create: %1' with:ex parameter.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4496
	ex return
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4497
    ] do:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4498
	actualClass fileOutMethod:currentMethod.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4499
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4500
    self normalLabel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4501
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4502
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4503
methodStringSearch
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4504
    "launch an enterBox for string to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4505
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4506
    self askForSelectorTitle:'string to search for in sources:' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4507
		    openWith:#browseForString:
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4508
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4509
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4510
methodLocalStringSearch
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4511
    "launch an enterBox for string to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4512
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4513
    self checkClassSelected ifFalse:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4514
    self askForSelectorTitle:'string to search for in local methods:' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4515
		    openWith:#browseForString:in:
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4516
			 and:(currentClass withAllSubclasses)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4517
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4518
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4519
methodAproposSearch
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4520
    "launch an enterBox for a keyword search"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4521
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4522
    self askForSelectorTitle:'keyword to search for:' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4523
		    openWith:#aproposSearch:
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4524
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4525
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4526
methodLocalAproposSearch
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4527
    "launch an enterBox for a local keyword search"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4528
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4529
    self askForSelectorTitle:'keyword to search for:' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4530
		    openWith:#aproposSearch:in:
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4531
			 and:(currentClass withAllSubclasses)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4532
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4533
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4534
methodNewMethod
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4535
    "prepare for definition of a new method - put a template into
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4536
     code view and define accept-action to compile it"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4537
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4538
    currentClass isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4539
	^ self warn:'select/create a class first'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4540
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4541
    currentMethodCategory isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4542
	^ self warn:'select/create a method category first'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4543
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4544
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4545
    currentMethod := currentSelector := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4546
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4547
    methodListView deselect.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4548
    codeView contents:(self template).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4549
    codeView modified:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4550
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4551
    self setAcceptAndExplainActionsForMethod.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4552
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4553
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4554
methodBreakPoint
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4555
    "set a breakpoint on the current method"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4556
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4557
    currentSelector notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4558
	currentMethod := actualClass compiledMethodAt:currentSelector.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4559
	currentMethod isWrapped ifFalse:[
93
claus
parents: 92
diff changeset
  4560
	    (currentMethod notNil and:[currentMethod isWrapped not]) ifTrue:[
claus
parents: 92
diff changeset
  4561
		self commonTraceHelperWith:#trapMethod:
claus
parents: 92
diff changeset
  4562
	    ]
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4563
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4564
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4565
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4566
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4567
methodTrace
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4568
    "turn on tracing of the current method"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4569
107
claus
parents: 106
diff changeset
  4570
    currentClass notNil ifTrue:[
claus
parents: 106
diff changeset
  4571
       currentSelector notNil ifTrue:[
claus
parents: 106
diff changeset
  4572
	  currentMethod := actualClass compiledMethodAt:currentSelector
claus
parents: 106
diff changeset
  4573
       ]
claus
parents: 106
diff changeset
  4574
    ].
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4575
93
claus
parents: 92
diff changeset
  4576
    (currentMethod notNil and:[currentMethod isWrapped not]) ifTrue:[
claus
parents: 92
diff changeset
  4577
	self commonTraceHelperWith:#traceMethod:
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4578
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4579
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4580
93
claus
parents: 92
diff changeset
  4581
commonTraceHelperWith:aSelector
claus
parents: 92
diff changeset
  4582
    currentMethod := MessageTracer perform:aSelector with:currentMethod.
107
claus
parents: 106
diff changeset
  4583
    self updateMethodListWithScroll:false keepSelection:true.
93
claus
parents: 92
diff changeset
  4584
    currentClass changed:#methodDictionary with:currentSelector.
claus
parents: 92
diff changeset
  4585
!
claus
parents: 92
diff changeset
  4586
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4587
methodRemoveBreakOrTrace
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4588
    "turn off tracing of the current method"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4589
93
claus
parents: 92
diff changeset
  4590
    (currentMethod notNil and:[currentMethod isWrapped]) ifTrue:[
claus
parents: 92
diff changeset
  4591
	self commonTraceHelperWith:#unwrapMethod:
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4592
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4593
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4594
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4595
methodTraceSender
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4596
    "turn on tracing of the current method"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4597
93
claus
parents: 92
diff changeset
  4598
    (currentMethod notNil and:[currentMethod isWrapped not]) ifTrue:[
claus
parents: 92
diff changeset
  4599
	self commonTraceHelperWith:#traceMethodSender:
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4600
    ]
105
claus
parents: 98
diff changeset
  4601
!
claus
parents: 98
diff changeset
  4602
claus
parents: 98
diff changeset
  4603
methodInspect
claus
parents: 98
diff changeset
  4604
    "inspect  the current method"
claus
parents: 98
diff changeset
  4605
claus
parents: 98
diff changeset
  4606
    self checkMethodSelected ifFalse:[^ self].
claus
parents: 98
diff changeset
  4607
claus
parents: 98
diff changeset
  4608
    currentMethod inspect.
110
claus
parents: 109
diff changeset
  4609
!
claus
parents: 109
diff changeset
  4610
117
claus
parents: 114
diff changeset
  4611
methodSTCCompile
claus
parents: 114
diff changeset
  4612
    "compile the current method to machine code.
claus
parents: 114
diff changeset
  4613
     This is not supported on all machines, and never supported in
claus
parents: 114
diff changeset
  4614
     the demo version."
claus
parents: 114
diff changeset
  4615
claus
parents: 114
diff changeset
  4616
    |prev|
claus
parents: 114
diff changeset
  4617
claus
parents: 114
diff changeset
  4618
    self checkMethodSelected ifFalse:[^ self].
claus
parents: 114
diff changeset
  4619
    prev := Compiler stcCompilation:#always.
claus
parents: 114
diff changeset
  4620
    [
claus
parents: 114
diff changeset
  4621
	codeView accept.
claus
parents: 114
diff changeset
  4622
    ] valueNowOrOnUnwindDo:[
claus
parents: 114
diff changeset
  4623
	Compiler stcCompilation:prev
claus
parents: 114
diff changeset
  4624
    ].
claus
parents: 114
diff changeset
  4625
!
claus
parents: 114
diff changeset
  4626
110
claus
parents: 109
diff changeset
  4627
methodDecompile
claus
parents: 109
diff changeset
  4628
    "decompile the current methods bytecodes.
claus
parents: 109
diff changeset
  4629
     The Decompiler is delivered as an extra, and not normally
claus
parents: 109
diff changeset
  4630
     avaliable with the system."
claus
parents: 109
diff changeset
  4631
claus
parents: 109
diff changeset
  4632
    self checkMethodSelected ifFalse:[^ self].
claus
parents: 109
diff changeset
  4633
    Decompiler notNil ifTrue:[
claus
parents: 109
diff changeset
  4634
	Autoload autoloadFailedSignal handle:[:ex |
claus
parents: 109
diff changeset
  4635
	    ex return
claus
parents: 109
diff changeset
  4636
	] do:[
claus
parents: 109
diff changeset
  4637
	    Decompiler autoload.
claus
parents: 109
diff changeset
  4638
	].
claus
parents: 109
diff changeset
  4639
    ].
claus
parents: 109
diff changeset
  4640
    Decompiler isLoaded ifFalse:[
117
claus
parents: 114
diff changeset
  4641
	Smalltalk 
claus
parents: 114
diff changeset
  4642
	    fileIn:'/phys/clam/claus/work/libcomp/not_delivered/Decomp.st'
claus
parents: 114
diff changeset
  4643
	    logged:false.
110
claus
parents: 109
diff changeset
  4644
    ].
claus
parents: 109
diff changeset
  4645
    Decompiler isLoaded ifFalse:[
claus
parents: 109
diff changeset
  4646
	^ self warn:'No decompiler available'.
claus
parents: 109
diff changeset
  4647
    ].
claus
parents: 109
diff changeset
  4648
claus
parents: 109
diff changeset
  4649
    Decompiler decompile:currentMethod.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4650
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4651
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4652
!BrowserView methodsFor:'method category list menu'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4653
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4654
methodCategoryMenu
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4655
    |labels selectors i|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4656
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4657
    currentClass isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4658
	methodCategoryListView flash.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4659
	^ nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4660
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4661
    currentMethodCategory isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4662
	labels := #(
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4663
		    'find method here ...'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4664
		    'find method ...'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4665
		    '-'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4666
		    'new category ...' 
85
d9713a3ca092 *** empty log message ***
claus
parents: 81
diff changeset
  4667
		    'copy category ...' 
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4668
		    'create access methods' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4669
		   ).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4670
	selectors := #(
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4671
		    methodCategoryFindMethod
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4672
		    methodCategoryFindAnyMethod
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4673
		    nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4674
		    methodCategoryNewCategory
85
d9713a3ca092 *** empty log message ***
claus
parents: 81
diff changeset
  4675
		    methodCategoryCopyCategory
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4676
		    methodCategoryCreateAccessMethods
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4677
		   ).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4678
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4679
	labels := #(
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4680
		    'fileOut' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4681
		    'fileOut all' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4682
		    'printOut'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4683
		    '-'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4684
		    'SPAWN_METHODCATEGORY'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4685
		    'spawn category'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4686
		    '-'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4687
		    'find method here ...'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4688
		    'find method ...'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4689
		    '-'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4690
		    'new category ...' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4691
		    'copy category ...' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4692
		    'create access methods' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4693
		    'rename ...' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4694
		    'remove'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4695
		   ).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4696
	selectors := #(
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4697
		    methodCategoryFileOut
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4698
		    methodCategoryFileOutAll
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4699
		    methodCategoryPrintOut
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4700
		    nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4701
		    methodCategorySpawn
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4702
		    methodCategorySpawnCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4703
		    nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4704
		    methodCategoryFindMethod
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4705
		    methodCategoryFindAnyMethod
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4706
		    nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4707
		    methodCategoryNewCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4708
		    methodCategoryCopyCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4709
		    methodCategoryCreateAccessMethods
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4710
		    methodCategoryRename
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4711
		    methodCategoryRemove
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4712
		   ).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4713
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4714
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4715
    showInstance ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4716
	labels := labels copy.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4717
	selectors := selectors copy.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4718
	i := labels indexOf:'create access methods'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4719
	labels at:i put:'create documentation stubs'. 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4720
	selectors at:i put:#methodCategoryCreateDocumentationMethods
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4721
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4722
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4723
    ^ PopUpMenu labels:(resources array:labels)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4724
		 selectors:selectors
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4725
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4726
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4727
methodCategoryFindAnyMethod
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4728
    |box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4729
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4730
    box := self enterBoxForSearchSelectorTitle:'method selector to search for:'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4731
    box action:[:aString | self switchToAnyMethodNamed:aString].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4732
    box showAtPointer
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4733
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4734
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4735
methodCategoryFindMethod
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4736
    |box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4737
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4738
    box := self enterBoxForSearchSelectorTitle:'method selector to search for:'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4739
    box action:[:aString | self switchToMethodNamed:aString].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4740
    box showAtPointer
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4741
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4742
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4743
methodCategoryPrintOut
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4744
    |printStream|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4745
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4746
    self checkClassSelected ifFalse:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4747
    self whenMethodCategorySelected:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4748
	printStream := Printer new.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4749
	actualClass printOutCategory:currentMethodCategory on:printStream.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4750
	printStream close
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4751
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4752
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4753
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4754
methodCategoryFileOut
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4755
    "fileOut all methods in the selected methodcategory of
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4756
     the current class"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4757
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4758
    self checkClassSelected ifFalse:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4759
    self whenMethodCategorySelected:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4760
	self busyLabel:'saving: %1' with:currentClass name , '-' , currentMethodCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4761
	Class fileOutErrorSignal handle:[:ex |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4762
	    self warn:'cannot create: %1' with:ex parameter.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4763
	    ex return.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4764
	] do:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4765
	    actualClass fileOutCategory:currentMethodCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4766
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4767
	self normalLabel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4768
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4769
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4770
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4771
methodCategorySpawn
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4772
    "create a new SystemBrowser browsing current method category"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4773
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4774
    currentMethodCategory notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4775
	self withWaitCursorDo:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4776
	    SystemBrowser browseClass:actualClass
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4777
		    methodCategory:currentMethodCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4778
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4779
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4780
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4781
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4782
methodCategoryNewCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4783
    "show the enter box to add a new method category.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4784
     Offer existing superclass categories in box to help avoiding
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4785
     useless typing."
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4786
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4787
    |someCategories existingCategories box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4788
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4789
    actualClass notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4790
	someCategories := actualClass allCategories
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4791
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4792
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4793
	 mhmh - offer some typical categories ...
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4794
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4795
	showInstance ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4796
	    someCategories := #('accessing' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4797
				'initialization'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4798
				'private' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4799
				'printing & storing'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4800
				'queries'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4801
				'testing'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4802
			       )
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4803
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4804
	    someCategories := #(
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4805
				'documentation'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4806
				'initialization'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4807
				'instance creation'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4808
			       ).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4809
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4810
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4811
    someCategories sort.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4812
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4813
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4814
     remove existing categories
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4815
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4816
    existingCategories := methodCategoryListView list.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4817
    existingCategories notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4818
	someCategories := someCategories select:[:cat | (existingCategories includes:cat) not].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4819
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4820
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4821
    box := self listBoxTitle:'name of new method category:'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4822
		      okText:'create'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4823
			list:someCategories.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4824
    box action:[:aString | self newMethodCategory:aString].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4825
    box showAtPointer
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4826
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4827
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4828
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4829
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4830
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4831
methodCategoryFileOutAll
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4832
    "fileOut all methods in the selected methodcategory of
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4833
     the current class"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4834
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4835
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4836
    self whenMethodCategorySelected:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4837
	|fileName outStream|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4838
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4839
	fileName := currentMethodCategory , '.st'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4840
	fileName replaceAll:Character space by:$_.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4841
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4842
	 this test allows a smalltalk to be built without Projects/ChangeSets
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4843
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4844
	Project notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4845
	    fileName := Project currentProjectDirectory , fileName.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4846
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4847
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4848
	 if file exists, save original in a .sav file
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4849
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4850
	fileName asFilename exists ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4851
	    fileName asFilename copyTo:(fileName , '.sav')
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4852
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4853
	outStream := FileStream newFileNamed:fileName.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4854
	outStream isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4855
	    ^ self warn:'cannot create: %1' with:fileName
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4856
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4857
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4858
	self busyLabel:'saving: ' with:currentMethodCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4859
	Class fileOutErrorSignal handle:[:ex |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4860
	    self warn:'cannot create: %1' with:ex parameter.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4861
	    ex return
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4862
	] do:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4863
	    Smalltalk allBehaviorsDo:[:class |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4864
		|hasMethodsInThisCategory|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4865
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4866
		hasMethodsInThisCategory := false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4867
		class methodArray do:[:method |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4868
		    method category = currentMethodCategory ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4869
			hasMethodsInThisCategory := true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4870
		    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4871
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4872
		hasMethodsInThisCategory ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4873
		    class fileOutCategory:currentMethodCategory on:outStream.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4874
		    outStream cr
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4875
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4876
		hasMethodsInThisCategory := false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4877
		class class methodArray do:[:method |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4878
		    method category = currentMethodCategory ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4879
			hasMethodsInThisCategory := true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4880
		    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4881
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4882
		hasMethodsInThisCategory ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4883
		    class class fileOutCategory:currentMethodCategory on:outStream.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4884
		    outStream cr
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4885
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4886
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4887
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4888
	outStream close.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4889
	self normalLabel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4890
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4891
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4892
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4893
methodCategorySpawnCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4894
    "create a new SystemBrowser browsing all methods from all
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4895
     classes with same category as current method category"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4896
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4897
    self askAndBrowseMethodCategory:'category to browse methods:'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4898
			     action:[:aString | 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4899
					SystemBrowser browseMethodCategory:aString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4900
				    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4901
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4902
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4903
methodCategoryCreateAccessMethods
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4904
    "create access methods for all instvars"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4905
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4906
    self checkClassSelected ifFalse:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4907
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4908
    showInstance ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4909
	self warn:'select instance - and try again'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4910
	^ self.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4911
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4912
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4913
    self withWaitCursorDo:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4914
	|nm names source|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4915
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4916
	(variableListView notNil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4917
	and:[(nm := variableListView selectionValue) notNil]) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4918
	    names := Array with:nm
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4919
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4920
	    names := currentClass instVarNames 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4921
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4922
	names do:[:name |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4923
	    "check, if method is not already present"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4924
	    (currentClass implements:(name asSymbol)) ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4925
		source := (name , '\    "return ' , name , '"\\    ^ ' , name) withCRs.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4926
		Compiler compile:source forClass:currentClass inCategory:'accessing'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4927
	    ] ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4928
		Transcript showCr:'method ''', name , ''' already present'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4929
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4930
	    (currentClass implements:((name , ':') asSymbol)) ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4931
		source := (name , ':something\    "set ' , name , '"\\    ' , name , ' := something.') withCRs.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4932
		Compiler compile:source forClass:currentClass inCategory:'accessing'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4933
	    ] ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4934
		Transcript showCr:'method ''', name , ':'' already present'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4935
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4936
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4937
	self updateMethodCategoryListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4938
	self updateMethodListWithScroll:false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4939
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4940
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4941
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4942
methodCategoryCreateDocumentationMethods
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4943
    "create empty documentation methods"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4944
120
claus
parents: 118
diff changeset
  4945
    |cls histStream|
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4946
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4947
    self checkClassSelected ifFalse:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4948
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4949
    cls := currentClass class.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4950
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4951
    self withWaitCursorDo:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4952
	|nm names source|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4953
120
claus
parents: 118
diff changeset
  4954
	"/ add version method containing RCS template
claus
parents: 118
diff changeset
  4955
	"/ but only if not already present.
claus
parents: 118
diff changeset
  4956
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4957
	(cls implements:#version) ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4958
	    Compiler compile:
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4959
'version
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4960
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4961
$' , 'Header$
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4962
"
120
claus
parents: 118
diff changeset
  4963
'                   forClass:cls 
claus
parents: 118
diff changeset
  4964
		  inCategory:'documentation'.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4965
	].
120
claus
parents: 118
diff changeset
  4966
claus
parents: 118
diff changeset
  4967
	"/ add documentation method containing doc template
claus
parents: 118
diff changeset
  4968
	"/ but only if not already present.
claus
parents: 118
diff changeset
  4969
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4970
	(cls implements:#documentation) ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4971
	    Compiler compile:
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4972
'documentation
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4973
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4974
    documentation to be added.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4975
"
120
claus
parents: 118
diff changeset
  4976
'                   forClass:cls 
claus
parents: 118
diff changeset
  4977
		  inCategory:'documentation'.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4978
	].
120
claus
parents: 118
diff changeset
  4979
claus
parents: 118
diff changeset
  4980
	"/ add examples method containing examples template
claus
parents: 118
diff changeset
  4981
	"/ but only if not already present.
claus
parents: 118
diff changeset
  4982
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4983
	(cls implements:#examples) ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4984
	    Compiler compile:
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4985
'examples
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4986
"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4987
    examples to be added.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4988
"
120
claus
parents: 118
diff changeset
  4989
'                   forClass:cls 
claus
parents: 118
diff changeset
  4990
		  inCategory:'documentation'.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  4991
	].
120
claus
parents: 118
diff changeset
  4992
claus
parents: 118
diff changeset
  4993
	"/ add history method containing created-entry
claus
parents: 118
diff changeset
  4994
	"/ but only if not already present.
claus
parents: 118
diff changeset
  4995
claus
parents: 118
diff changeset
  4996
	(cls implements:#history) ifFalse:[ 
claus
parents: 118
diff changeset
  4997
	    histStream := ReadWriteStream on: String new.
claus
parents: 118
diff changeset
  4998
	    histStream nextPutAll: 'history'; cr.
claus
parents: 118
diff changeset
  4999
	    HistoryLine isBehavior ifTrue:[ 
claus
parents: 118
diff changeset
  5000
		histStream nextPutAll: (HistoryLine created printString); cr.
claus
parents: 118
diff changeset
  5001
	    ] ifFalse:[
claus
parents: 118
diff changeset
  5002
		histStream cr.
claus
parents: 118
diff changeset
  5003
	    ].
claus
parents: 118
diff changeset
  5004
	    Compiler compile:(histStream contents)
claus
parents: 118
diff changeset
  5005
		    forClass:cls 
claus
parents: 118
diff changeset
  5006
		  inCategory:'documentation'.
claus
parents: 118
diff changeset
  5007
	].
claus
parents: 118
diff changeset
  5008
95
claus
parents: 93
diff changeset
  5009
	self instanceProtocol:false.
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5010
	self switchToMethodNamed:#documentation 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5011
"/        self updateMethodCategoryListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5012
"/        self updateMethodListWithScroll:false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5013
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5014
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5015
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5016
methodCategoryCopyCategory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5017
    "show the enter box to copy from an existing method category"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5018
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5019
    |title box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5020
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5021
    showInstance ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5022
	title := 'class to copy instance method category from:'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5023
    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5024
	title := 'class to copy class method category from:'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5025
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5026
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5027
    box := self listBoxTitle:title 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5028
		      okText:'ok' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5029
			list:(Smalltalk allClasses collect:[:cls | cls name]) asArray sort.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5030
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5031
    box action:[:aString | self copyMethodsFromClass:aString].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5032
    box showAtPointer
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5033
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5034
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5035
methodCategoryRename
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5036
    "launch an enterBox to rename current method category"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5037
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5038
    |box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5039
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5040
    self checkMethodCategorySelected ifFalse:[^ self].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5041
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5042
    box := self enterBoxTitle:(resources string:'rename method category %1 to:' with:currentMethodCategory)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5043
		okText:(resources at:'rename').
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5044
    box initialText:currentMethodCategory.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5045
    box action:[:aString | 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5046
	actualClass renameCategory:currentMethodCategory to:aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5047
	currentMethodCategory := aString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5048
	currentMethod := currentSelector := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5049
	self updateMethodCategoryList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5050
	self updateMethodListWithScroll:false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5051
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5052
    box showAtPointer
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5053
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5054
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5055
methodCategoryRemove
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5056
    "show number of methods to remove and query user"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5057
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5058
    |count t box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5059
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5060
    currentMethodCategory notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5061
	count := 0.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5062
	actualClass methodArray do:[:aMethod |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5063
	    (aMethod category = currentMethodCategory) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5064
		count := count + 1
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5065
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5066
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5067
	(count == 0) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5068
	    currentMethodCategory := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5069
	    currentMethod := currentSelector := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5070
	    self updateMethodCategoryListWithScroll:false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5071
	    self updateMethodList
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5072
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5073
	    (count == 1) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5074
		t := 'remove %1\(with 1 method) ?'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5075
	    ] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5076
		t := 'remove %1\(with %2 methods) ?'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5077
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5078
	    t := resources string:t with:currentMethodCategory with:count printString.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5079
	    t := t withCRs.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5080
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5081
	    box := YesNoBox 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5082
		       title:t
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5083
		       yesText:(resources at:'remove')
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5084
		       noText:(resources at:'abort').
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5085
	    box confirm ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5086
		actualClass methodArray do:[:aMethod |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5087
		    (aMethod category = currentMethodCategory) ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5088
			actualClass 
93
claus
parents: 92
diff changeset
  5089
			    removeSelector:(actualClass selectorAtMethod:aMethod)
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5090
		    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5091
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5092
		currentMethodCategory := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5093
		currentMethod := currentSelector := nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5094
		self updateMethodCategoryList.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5095
		self updateMethodList
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5096
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5097
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5098
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5099
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5100
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5101
!BrowserView methodsFor:'variable list menu'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5102
93
claus
parents: 92
diff changeset
  5103
variableListMenu
107
claus
parents: 106
diff changeset
  5104
    |labels selectors|
93
claus
parents: 92
diff changeset
  5105
claus
parents: 92
diff changeset
  5106
    currentClass isNil ifTrue:[
claus
parents: 92
diff changeset
  5107
	variableListView flash.
claus
parents: 92
diff changeset
  5108
	^ nil
claus
parents: 92
diff changeset
  5109
    ].
claus
parents: 92
diff changeset
  5110
claus
parents: 92
diff changeset
  5111
    labels := #(
claus
parents: 92
diff changeset
  5112
		    'instvar refs ...'
claus
parents: 92
diff changeset
  5113
		    'classvar refs ...'
claus
parents: 92
diff changeset
  5114
		    'all instvar refs ...'
claus
parents: 92
diff changeset
  5115
		    'all classvar refs ...'
claus
parents: 92
diff changeset
  5116
		    '-'
claus
parents: 92
diff changeset
  5117
		    'instvar mods ...'
claus
parents: 92
diff changeset
  5118
		    'classvar mods ...'
claus
parents: 92
diff changeset
  5119
		    'all instvar mods ...'
claus
parents: 92
diff changeset
  5120
		    'all classvar mods ...'
claus
parents: 92
diff changeset
  5121
	       ).
claus
parents: 92
diff changeset
  5122
    selectors := #(
claus
parents: 92
diff changeset
  5123
		    instVarRefs
claus
parents: 92
diff changeset
  5124
		    classVarRefs
claus
parents: 92
diff changeset
  5125
		    allInstVarRefs
claus
parents: 92
diff changeset
  5126
		    allClassVarRefs
claus
parents: 92
diff changeset
  5127
		    nil
claus
parents: 92
diff changeset
  5128
		    instVarMods
claus
parents: 92
diff changeset
  5129
		    classVarMods
claus
parents: 92
diff changeset
  5130
		    allInstVarMods
claus
parents: 92
diff changeset
  5131
		    allClassVarMods
claus
parents: 92
diff changeset
  5132
		 ).
claus
parents: 92
diff changeset
  5133
claus
parents: 92
diff changeset
  5134
    (showInstance and:[variableListView hasSelection]) ifTrue:[
claus
parents: 92
diff changeset
  5135
	labels := labels , #(
claus
parents: 92
diff changeset
  5136
				'-'
claus
parents: 92
diff changeset
  5137
				'type information'
claus
parents: 92
diff changeset
  5138
			   ).
claus
parents: 92
diff changeset
  5139
	selectors := selectors , #(
claus
parents: 92
diff changeset
  5140
				nil
claus
parents: 92
diff changeset
  5141
				varTypeInfo
claus
parents: 92
diff changeset
  5142
				).
claus
parents: 92
diff changeset
  5143
    ].
claus
parents: 92
diff changeset
  5144
claus
parents: 92
diff changeset
  5145
    ^ PopUpMenu labels:(resources array:labels)
claus
parents: 92
diff changeset
  5146
		selectors:selectors
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5147
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5148
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5149
variableSelection:lineNr
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5150
    "variable selection changed"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5151
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5152
    |name idx|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5153
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5154
    name := variableListView selectionValue.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5155
    name isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5156
	self unhilightMethodCategories.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5157
	self unhilightMethods.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5158
	self autoSearch:nil.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5159
	^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5160
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5161
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5162
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5163
     first, check if the selected variable is really the one 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5164
     we get - reselect if its hidden (for example, a class variable
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5165
     with the same name could be defined in a subclass)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5166
    "
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5167
    idx := variableListView list findLast:[:entry | entry = name].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5168
    idx ~~ lineNr ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5169
	"select it - user will see whats going on"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5170
	variableListView selection:idx
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5171
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5172
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5173
    "search for methods in the current category, which access the selected
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5174
     variable, and highlight them"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5175
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5176
    self hilightMethodsInMethodCategoryList:true inMethodList:true.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5177
    self autoSearch:name.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5178
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5179
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5180
enterBoxForVariableSearch:title
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5181
    |box sel|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5182
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5183
    box := self enterBoxForCodeSelectionTitle:title okText:'browse'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5184
    variableListView notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5185
	codeView hasSelection ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5186
	    (sel := variableListView selectionValue) notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5187
		(sel startsWith:'---') ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5188
		    box initialText:sel
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5189
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5190
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5191
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5192
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5193
    ^ box
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5194
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5195
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5196
allClassOrInstVarRefsTitle:title access:access mods:modifications
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5197
    "show an enterbox for instVar to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5198
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5199
    self doClassMenu:[:currentClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5200
	|box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5201
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5202
	box := self enterBoxForVariableSearch:title.
93
claus
parents: 92
diff changeset
  5203
	box action:[:aVariableName |
claus
parents: 92
diff changeset
  5204
	    |homeClass|
claus
parents: 92
diff changeset
  5205
claus
parents: 92
diff changeset
  5206
	    aVariableName isEmpty ifFalse:[
106
claus
parents: 105
diff changeset
  5207
		windowGroup showCursor:Cursor questionMark.
93
claus
parents: 92
diff changeset
  5208
claus
parents: 92
diff changeset
  5209
		homeClass := self findClassOfVariable:aVariableName accessWith:access.
108
claus
parents: 107
diff changeset
  5210
		access == #classVarNames ifTrue:[
claus
parents: 107
diff changeset
  5211
		    SystemBrowser 
claus
parents: 107
diff changeset
  5212
			browseClassRefsTo:aVariableName 
claus
parents: 107
diff changeset
  5213
			under:homeClass 
claus
parents: 107
diff changeset
  5214
			modificationsOnly:modifications
claus
parents: 107
diff changeset
  5215
		] ifFalse:[
claus
parents: 107
diff changeset
  5216
		    SystemBrowser 
claus
parents: 107
diff changeset
  5217
			browseInstRefsTo:aVariableName 
claus
parents: 107
diff changeset
  5218
			under:homeClass 
claus
parents: 107
diff changeset
  5219
			modificationsOnly:modifications
claus
parents: 107
diff changeset
  5220
		]
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5221
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5222
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5223
	box showAtPointer
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5224
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5225
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5226
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5227
instVarRefsOrModsTitle:title mods:mods
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5228
    "show an enterbox for instvar to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5229
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5230
    self doClassMenu:[:currentClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5231
	|box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5232
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5233
	box := self enterBoxForVariableSearch:title.
93
claus
parents: 92
diff changeset
  5234
	box action:[:aString |
claus
parents: 92
diff changeset
  5235
	    aString notEmpty ifTrue:[
106
claus
parents: 105
diff changeset
  5236
		windowGroup showCursor:(Cursor questionMark).
93
claus
parents: 92
diff changeset
  5237
		SystemBrowser 
claus
parents: 92
diff changeset
  5238
		    browseInstRefsTo:aString
claus
parents: 92
diff changeset
  5239
		    in:(Array with:currentClass)
claus
parents: 92
diff changeset
  5240
		    modificationsOnly:mods 
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5241
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5242
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5243
	box showAtPointer
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5244
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5245
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5246
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5247
allClassVarMods
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5248
    "show an enterbox for classVar to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5249
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5250
    self allClassOrInstVarRefsTitle:'class variable to browse modifications of:' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5251
				  access:#classVarNames
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5252
				  mods:true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5253
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5254
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5255
instVarMods
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5256
    "show an enterbox for instVar to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5257
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5258
    self instVarRefsOrModsTitle:'instance variable to browse modifications of:'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5259
				mods:true 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5260
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5261
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5262
instVarRefs
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5263
    "show an enterbox for instVar to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5264
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5265
    self instVarRefsOrModsTitle:'instance variable to browse references to:'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5266
			   mods:false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5267
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5268
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5269
classVarRefsOrModsTitle:title mods:mods
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5270
    "show an enterbox for classVar to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5271
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5272
    self doClassMenu:[:currentClass |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5273
	|box|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5274
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5275
	box := self enterBoxForVariableSearch:title.
93
claus
parents: 92
diff changeset
  5276
	box action:[:aString |
claus
parents: 92
diff changeset
  5277
	    aString notEmpty ifTrue:[
106
claus
parents: 105
diff changeset
  5278
		windowGroup showCursor:(Cursor questionMark).
93
claus
parents: 92
diff changeset
  5279
		SystemBrowser 
claus
parents: 92
diff changeset
  5280
		       browseClassRefsTo:aString
claus
parents: 92
diff changeset
  5281
		       in:(Array with:currentClass)
claus
parents: 92
diff changeset
  5282
		       modificationsOnly:mods 
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5283
	    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5284
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5285
	box showAtPointer
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5286
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5287
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5288
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5289
allInstVarRefs
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5290
    "show an enterbox for instVar to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5291
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5292
    self allClassOrInstVarRefsTitle:'instance variable to browse references to:' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5293
				  access:#instVarNames
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5294
				  mods:false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5295
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5296
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5297
classVarRefs
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5298
    "show an enterbox for classVar to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5299
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5300
    self classVarRefsOrModsTitle:'class variable to browse references to:'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5301
				 mods:false
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5302
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5303
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5304
classVarMods
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5305
    "show an enterbox for classVar to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5306
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5307
    self classVarRefsOrModsTitle:'class variable to browse modifications of:'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5308
				 mods:true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5309
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5310
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5311
allInstVarMods
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5312
    "show an enterbox for instVar to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5313
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5314
    self allClassOrInstVarRefsTitle:'instance variable to browse modifications of:' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5315
				  access:#instVarNames
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5316
				  mods:true
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5317
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5318
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5319
allClassVarRefs
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5320
    "show an enterbox for classVar to search for"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5321
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5322
    self allClassOrInstVarRefsTitle:'class variable to browse references to:' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5323
				  access:#classVarNames
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5324
				  mods:false
93
claus
parents: 92
diff changeset
  5325
!
claus
parents: 92
diff changeset
  5326
claus
parents: 92
diff changeset
  5327
varTypeInfo
claus
parents: 92
diff changeset
  5328
    "show typical usage of a variable"
claus
parents: 92
diff changeset
  5329
claus
parents: 92
diff changeset
  5330
    |name idx classes values value msg cut names instCount subInstCount box
claus
parents: 92
diff changeset
  5331
     searchClass|
claus
parents: 92
diff changeset
  5332
claus
parents: 92
diff changeset
  5333
    name := variableListView selectionValue.
claus
parents: 92
diff changeset
  5334
    name isNil ifTrue:[^ self].
claus
parents: 92
diff changeset
  5335
claus
parents: 92
diff changeset
  5336
    searchClass := actualClass whichClassDefinesInstVar:name.
claus
parents: 92
diff changeset
  5337
claus
parents: 92
diff changeset
  5338
    idx := searchClass instVarOffsetOf:name.
claus
parents: 92
diff changeset
  5339
    idx isNil ifTrue:[^ self].
claus
parents: 92
diff changeset
  5340
claus
parents: 92
diff changeset
  5341
    classes := IdentitySet new.
claus
parents: 92
diff changeset
  5342
    values := IdentitySet new.
claus
parents: 92
diff changeset
  5343
    instCount := 0.
claus
parents: 92
diff changeset
  5344
    subInstCount := 0.
claus
parents: 92
diff changeset
  5345
    searchClass allSubInstancesDo:[:i |
claus
parents: 92
diff changeset
  5346
	|val|
claus
parents: 92
diff changeset
  5347
claus
parents: 92
diff changeset
  5348
	val := i instVarAt:idx.
claus
parents: 92
diff changeset
  5349
	val notNil ifTrue:[values add:val].
claus
parents: 92
diff changeset
  5350
	classes add:val class.
claus
parents: 92
diff changeset
  5351
	(i isMemberOf:searchClass) ifTrue:[
claus
parents: 92
diff changeset
  5352
	    instCount := instCount + 1.
claus
parents: 92
diff changeset
  5353
	] ifFalse:[
claus
parents: 92
diff changeset
  5354
	    subInstCount := subInstCount + 1
claus
parents: 92
diff changeset
  5355
	]
claus
parents: 92
diff changeset
  5356
    ].
claus
parents: 92
diff changeset
  5357
    (instCount == 0 and:[subInstCount == 0]) ifTrue:[
claus
parents: 92
diff changeset
  5358
	self warn:'there are currently no instances of ' , currentClass name.
claus
parents: 92
diff changeset
  5359
	^ self
claus
parents: 92
diff changeset
  5360
    ].
claus
parents: 92
diff changeset
  5361
claus
parents: 92
diff changeset
  5362
    instCount ~~ 0 ifTrue:[
108
claus
parents: 107
diff changeset
  5363
	msg := 'in (currently: ' , instCount printString,') instances '.
93
claus
parents: 92
diff changeset
  5364
	subInstCount ~~ 0 ifTrue:[
claus
parents: 92
diff changeset
  5365
	    msg := msg , 'and '
claus
parents: 92
diff changeset
  5366
	]
108
claus
parents: 107
diff changeset
  5367
    ] ifFalse:[
claus
parents: 107
diff changeset
  5368
	msg := 'in '.
93
claus
parents: 92
diff changeset
  5369
    ].
claus
parents: 92
diff changeset
  5370
    subInstCount ~~ 0 ifTrue:[
claus
parents: 92
diff changeset
  5371
	msg := msg , '(currently: ' , subInstCount printString, ') derived instances '
claus
parents: 92
diff changeset
  5372
    ].
108
claus
parents: 107
diff changeset
  5373
    msg := msg, 'of ' , searchClass name , ',\'.
93
claus
parents: 92
diff changeset
  5374
    msg := msg , name , ' '.
claus
parents: 92
diff changeset
  5375
    ((values size == 1) 
claus
parents: 92
diff changeset
  5376
    or:[classes size == 1 and:[classes first == UndefinedObject]]) ifTrue:[
claus
parents: 92
diff changeset
  5377
	values size == 1 ifTrue:[value := values first].
109
claus
parents: 108
diff changeset
  5378
	(value isNumber or:[value isString]) ifTrue:[
93
claus
parents: 92
diff changeset
  5379
	    msg := msg , 'is always the same:\\      ' , 
claus
parents: 92
diff changeset
  5380
			 value class name , ' (' , value storeString , ')'.
claus
parents: 92
diff changeset
  5381
	] ifFalse:[
claus
parents: 92
diff changeset
  5382
	    (value isNil or:[value == true or:[value == false]]) ifTrue:[
claus
parents: 92
diff changeset
  5383
		msg := msg , 'is always:\\      ' , 
claus
parents: 92
diff changeset
  5384
			     value printString.
claus
parents: 92
diff changeset
  5385
	    ] ifFalse:[
claus
parents: 92
diff changeset
  5386
		msg := msg , 'is always the same:\\'.
claus
parents: 92
diff changeset
  5387
		msg := msg , '      ' , value class name.
claus
parents: 92
diff changeset
  5388
		value isLiteral ifTrue:[
claus
parents: 92
diff changeset
  5389
		    msg := msg , ' (' , value storeString , ')'
claus
parents: 92
diff changeset
  5390
		]
claus
parents: 92
diff changeset
  5391
	    ]
claus
parents: 92
diff changeset
  5392
	]
claus
parents: 92
diff changeset
  5393
    ] ifFalse:[
claus
parents: 92
diff changeset
  5394
	classes size == 1 ifTrue:[
claus
parents: 92
diff changeset
  5395
	    msg := msg , 'is always:\\'.
claus
parents: 92
diff changeset
  5396
	    msg := msg , '      ' , classes first name , '\'.
claus
parents: 92
diff changeset
  5397
	] ifFalse:[
claus
parents: 92
diff changeset
  5398
	    msg := msg , 'is one of:\\'.
claus
parents: 92
diff changeset
  5399
	    classes := classes asOrderedCollection.
claus
parents: 92
diff changeset
  5400
	    classes size > 20 ifTrue:[
claus
parents: 92
diff changeset
  5401
		classes := classes copyFrom:1 to:20.
claus
parents: 92
diff changeset
  5402
		cut := true
claus
parents: 92
diff changeset
  5403
	    ] ifFalse:[
claus
parents: 92
diff changeset
  5404
		cut := false.
claus
parents: 92
diff changeset
  5405
	    ].
claus
parents: 92
diff changeset
  5406
	    names := classes collect:[:cls |
claus
parents: 92
diff changeset
  5407
		|nm|
claus
parents: 92
diff changeset
  5408
		cls == UndefinedObject ifTrue:[
claus
parents: 92
diff changeset
  5409
		    'nil'
claus
parents: 92
diff changeset
  5410
		] ifFalse:[
claus
parents: 92
diff changeset
  5411
		    cls == True ifTrue:[
claus
parents: 92
diff changeset
  5412
			'true'
claus
parents: 92
diff changeset
  5413
		    ] ifFalse:[
claus
parents: 92
diff changeset
  5414
			cls == False ifTrue:[
claus
parents: 92
diff changeset
  5415
			    'false'
claus
parents: 92
diff changeset
  5416
			] ifFalse:[
claus
parents: 92
diff changeset
  5417
			    cls name
claus
parents: 92
diff changeset
  5418
			]
claus
parents: 92
diff changeset
  5419
		    ]
claus
parents: 92
diff changeset
  5420
		].
claus
parents: 92
diff changeset
  5421
	    ].
claus
parents: 92
diff changeset
  5422
	    names sort.
claus
parents: 92
diff changeset
  5423
	    names do:[:nm |
claus
parents: 92
diff changeset
  5424
		msg := msg , '      ' , nm , '\'.
claus
parents: 92
diff changeset
  5425
	    ].
claus
parents: 92
diff changeset
  5426
	]
claus
parents: 92
diff changeset
  5427
    ].
claus
parents: 92
diff changeset
  5428
claus
parents: 92
diff changeset
  5429
    box := InfoBox title:msg withCRs.
claus
parents: 92
diff changeset
  5430
    box label:'variable type information'.
claus
parents: 92
diff changeset
  5431
    box showAtPointer
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5432
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5433
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5434
!BrowserView methodsFor:'class-method list menu'!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5435
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5436
classMethodMenu
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5437
    |labels selectors|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5438
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5439
    labels := #(
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5440
				'fileOut'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5441
				'fileOut all'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5442
				'printOut'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5443
				'-'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5444
				'spawn'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5445
				'spawn class'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5446
				'spawn full protocol'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5447
				'spawn hierarchy'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5448
				'-'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5449
				'senders ...'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5450
				'implementors ...'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5451
				'globals ...'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5452
"/                              '-'
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5453
"/                              'breakpoint' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5454
"/                              'trace' 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5455
"/                              'trace sender' 
92
claus
parents: 85
diff changeset
  5456
				'-'
claus
parents: 85
diff changeset
  5457
				'remove'
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5458
	       ).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5459
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5460
    selectors := #(
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5461
				methodFileOut
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5462
				classMethodFileOutAll
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5463
				methodPrintOut
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5464
				nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5465
				methodSpawn
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5466
				classSpawn
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5467
				classSpawnFullProtocol
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5468
				classSpawnHierarchy
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5469
				nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5470
				methodSenders
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5471
				methodImplementors
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5472
				methodGlobalReferends
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5473
"/                              nil
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5474
"/                              methodBreakPoint 
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5475
"/                              methodTrace
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5476
"/                              methodTraceSender
92
claus
parents: 85
diff changeset
  5477
				nil
claus
parents: 85
diff changeset
  5478
				methodRemove
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5479
		  ).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5480
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5481
    ^ PopUpMenu labels:(resources array:labels)
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5482
		selectors:selectors
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5483
!
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5484
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5485
classMethodFileOutAll
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5486
    "fileout all methods into one source file"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5487
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5488
    |list classString selectorString cls mth outStream fileName append
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5489
     fileBox|
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5490
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5491
    append := false.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5492
    fileBox := FileSaveBox
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5493
			title:(resources string:'save methodss in:')
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5494
			okText:(resources string:'save')
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5495
			abortText:(resources string:'cancel')
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5496
			action:[:fName | fileName := fName].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5497
    fileBox appendAction:[:fName | fileName := fName. append := true].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5498
    fileBox initialText:'some_methods.st'.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5499
    Project notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5500
	fileBox directory:Project currentProjectDirectory
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5501
    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5502
    fileBox showAtPointer.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5503
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5504
    fileName notNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5505
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5506
	 if file exists, save original in a .sav file
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5507
	"
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5508
	fileName asFilename exists ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5509
	    fileName asFilename copyTo:(fileName , '.sav')
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5510
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5511
	append ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5512
	    outStream := FileStream appendingOldFileNamed:fileName
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5513
	] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5514
	    outStream := FileStream newFileNamed:fileName.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5515
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5516
	outStream isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5517
	    ^ self warn:'cannot create: %1' with:fileName
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5518
	].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5519
	self withWaitCursorDo:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5520
	    list := classMethodListView list.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5521
	    list do:[:line |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5522
		self busyLabel:'writing: ' with:line.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5523
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5524
		classString := self classFromClassMethodString:line.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5525
		selectorString := self selectorFromClassMethodString:line.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5526
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5527
		((classString ~= 'Metaclass') and:[classString endsWith:'class']) ifTrue:[
106
claus
parents: 105
diff changeset
  5528
		    classString := classString copyWithoutLast:5 "copyTo:(classString size - 5)".
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5529
		    cls := (Smalltalk at:classString asSymbol).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5530
		    cls := cls class
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5531
		] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5532
		    cls := (Smalltalk at:classString asSymbol).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5533
		].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5534
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5535
		cls isNil ifTrue:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5536
		    self warn:'oops class %1 is gone' with:classString
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5537
		] ifFalse:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5538
		    mth := cls compiledMethodAt:(selectorString asSymbol).
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5539
		    Class fileOutErrorSignal handle:[:ex |
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5540
			|box|
93
claus
parents: 92
diff changeset
  5541
			box := YesNoBox 
claus
parents: 92
diff changeset
  5542
				    title:('fileOut error: ' 
claus
parents: 92
diff changeset
  5543
					   , ex errorString 
claus
parents: 92
diff changeset
  5544
					   , '\\continue anyway ?') withCRs
claus
parents: 92
diff changeset
  5545
				    yesText:'continue' 
claus
parents: 92
diff changeset
  5546
				    noText:'abort'.
claus
parents: 92
diff changeset
  5547
			box confirm ifTrue:[
74
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5548
			    ex proceed
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5549
			].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5550
			self normalLabel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5551
			^ self
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5552
		    ] do:[
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5553
			cls fileOutMethod:mth on:outStream.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5554
		    ]    
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5555
		]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5556
	    ].
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5557
	    outStream close.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5558
	    self normalLabel.
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5559
	]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5560
    ]
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5561
! !
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5562
f2c56efa3599 Initial revision
claus
parents:
diff changeset
  5563
BrowserView initialize!