ContextInspectorView.st
author claus
Fri, 28 Oct 1994 04:31:16 +0100
changeset 49 6fe62433cfa3
parent 45 950b84ba89e6
child 51 57c1ccc3d7e0
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
     1
"{ Package: 'Programming Tools' }"
d904237f7c44 Initial revision
claus
parents:
diff changeset
     2
d904237f7c44 Initial revision
claus
parents:
diff changeset
     3
"
d904237f7c44 Initial revision
claus
parents:
diff changeset
     4
 COPYRIGHT (c) 1993 by Claus Gittinger
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
     5
	      All Rights Reserved
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
     6
d904237f7c44 Initial revision
claus
parents:
diff changeset
     7
 This software is furnished under a license and may be used
d904237f7c44 Initial revision
claus
parents:
diff changeset
     8
 only in accordance with the terms of that license and with the
d904237f7c44 Initial revision
claus
parents:
diff changeset
     9
 inclusion of the above copyright notice.   This software may not
d904237f7c44 Initial revision
claus
parents:
diff changeset
    10
 be provided or otherwise made available to, or used by, any
d904237f7c44 Initial revision
claus
parents:
diff changeset
    11
 other person.  No title to or ownership of the software is
d904237f7c44 Initial revision
claus
parents:
diff changeset
    12
 hereby transferred.
d904237f7c44 Initial revision
claus
parents:
diff changeset
    13
"
d904237f7c44 Initial revision
claus
parents:
diff changeset
    14
d904237f7c44 Initial revision
claus
parents:
diff changeset
    15
InspectorView subclass:#ContextInspectorView
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    16
	 instanceVariableNames:'inspectedContext'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    17
	 classVariableNames:''
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    18
	 poolDictionaries:''
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    19
	 category:'Interface-Inspector'
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
    20
!
d904237f7c44 Initial revision
claus
parents:
diff changeset
    21
d904237f7c44 Initial revision
claus
parents:
diff changeset
    22
ContextInspectorView comment:'
d904237f7c44 Initial revision
claus
parents:
diff changeset
    23
COPYRIGHT (c) 1993 by Claus Gittinger
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    24
	      All Rights Reserved
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
    25
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    26
$Header: /cvs/stx/stx/libtool/ContextInspectorView.st,v 1.4 1994-10-28 03:30:27 claus Exp $
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
    27
'!
d904237f7c44 Initial revision
claus
parents:
diff changeset
    28
d904237f7c44 Initial revision
claus
parents:
diff changeset
    29
!ContextInspectorView class methodsFor:'documentation'!
d904237f7c44 Initial revision
claus
parents:
diff changeset
    30
d904237f7c44 Initial revision
claus
parents:
diff changeset
    31
copyright
d904237f7c44 Initial revision
claus
parents:
diff changeset
    32
"
d904237f7c44 Initial revision
claus
parents:
diff changeset
    33
 COPYRIGHT (c) 1993 by Claus Gittinger
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    34
	      All Rights Reserved
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
    35
d904237f7c44 Initial revision
claus
parents:
diff changeset
    36
 This software is furnished under a license and may be used
d904237f7c44 Initial revision
claus
parents:
diff changeset
    37
 only in accordance with the terms of that license and with the
d904237f7c44 Initial revision
claus
parents:
diff changeset
    38
 inclusion of the above copyright notice.   This software may not
d904237f7c44 Initial revision
claus
parents:
diff changeset
    39
 be provided or otherwise made available to, or used by, any
d904237f7c44 Initial revision
claus
parents:
diff changeset
    40
 other person.  No title to or ownership of the software is
d904237f7c44 Initial revision
claus
parents:
diff changeset
    41
 hereby transferred.
d904237f7c44 Initial revision
claus
parents:
diff changeset
    42
"
d904237f7c44 Initial revision
claus
parents:
diff changeset
    43
!
d904237f7c44 Initial revision
claus
parents:
diff changeset
    44
d904237f7c44 Initial revision
claus
parents:
diff changeset
    45
version
d904237f7c44 Initial revision
claus
parents:
diff changeset
    46
"
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    47
$Header: /cvs/stx/stx/libtool/ContextInspectorView.st,v 1.4 1994-10-28 03:30:27 claus Exp $
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
    48
"
d904237f7c44 Initial revision
claus
parents:
diff changeset
    49
!
d904237f7c44 Initial revision
claus
parents:
diff changeset
    50
d904237f7c44 Initial revision
claus
parents:
diff changeset
    51
documentation
d904237f7c44 Initial revision
claus
parents:
diff changeset
    52
"
d904237f7c44 Initial revision
claus
parents:
diff changeset
    53
    a modified Inspector for Contexts (used in Debugger)
d904237f7c44 Initial revision
claus
parents:
diff changeset
    54
"
d904237f7c44 Initial revision
claus
parents:
diff changeset
    55
! !
d904237f7c44 Initial revision
claus
parents:
diff changeset
    56
d904237f7c44 Initial revision
claus
parents:
diff changeset
    57
!ContextInspectorView methodsFor:'accessing'!
d904237f7c44 Initial revision
claus
parents:
diff changeset
    58
d904237f7c44 Initial revision
claus
parents:
diff changeset
    59
inspect:con
d904237f7c44 Initial revision
claus
parents:
diff changeset
    60
    "set the context to be inspected"
d904237f7c44 Initial revision
claus
parents:
diff changeset
    61
d904237f7c44 Initial revision
claus
parents:
diff changeset
    62
    |aList homeContext method names rec sel implementorClass argNames varNames|
d904237f7c44 Initial revision
claus
parents:
diff changeset
    63
d904237f7c44 Initial revision
claus
parents:
diff changeset
    64
    realized ifFalse:[^ self].
d904237f7c44 Initial revision
claus
parents:
diff changeset
    65
d904237f7c44 Initial revision
claus
parents:
diff changeset
    66
    inspectedObject := nil.
d904237f7c44 Initial revision
claus
parents:
diff changeset
    67
    inspectedContext := con.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    68
    self initializeListViewMiddleButtonMenus.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    69
    listView setMiddleButtonMenu:menu1.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    70
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
    71
    con isNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    72
	inspectedValues := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    73
	listView contents:nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    74
	^ self
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
    75
    ].
d904237f7c44 Initial revision
claus
parents:
diff changeset
    76
d904237f7c44 Initial revision
claus
parents:
diff changeset
    77
    homeContext := con methodHome.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    78
homeContext isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    79
    "its a cheap blocks context"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    80
    rec := con receiver.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    81
    sel := con selector.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    82
    names := OrderedCollection new.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    83
] ifFalse:[
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
    84
    rec := homeContext receiver.
d904237f7c44 Initial revision
claus
parents:
diff changeset
    85
    sel := homeContext selector.
d904237f7c44 Initial revision
claus
parents:
diff changeset
    86
d904237f7c44 Initial revision
claus
parents:
diff changeset
    87
    implementorClass := homeContext searchClass whichClassImplements:sel.
d904237f7c44 Initial revision
claus
parents:
diff changeset
    88
    implementorClass notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    89
	method := implementorClass compiledMethodAt:sel.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    90
	names := method methodArgAndVarNames
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
    91
    ].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    92
].
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
    93
    "create dummy names (if there is no source available)"
d904237f7c44 Initial revision
claus
parents:
diff changeset
    94
    names isNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    95
	names := OrderedCollection new.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    96
	1 to:homeContext numArgs do:[:index |
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    97
	    names add:('mArg' , index printString)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    98
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    99
	1 to:homeContext nvars do:[:index |
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   100
	    names add:('mVar' , index printString)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   101
	].
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
   102
    ].
d904237f7c44 Initial revision
claus
parents:
diff changeset
   103
d904237f7c44 Initial revision
claus
parents:
diff changeset
   104
    aList := OrderedCollection new.
d904237f7c44 Initial revision
claus
parents:
diff changeset
   105
d904237f7c44 Initial revision
claus
parents:
diff changeset
   106
    "
d904237f7c44 Initial revision
claus
parents:
diff changeset
   107
     stupid: should find the block via the contexts
d904237f7c44 Initial revision
claus
parents:
diff changeset
   108
     method-home and put real names in here
d904237f7c44 Initial revision
claus
parents:
diff changeset
   109
    "
d904237f7c44 Initial revision
claus
parents:
diff changeset
   110
    con isBlockContext ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   111
	argNames := (1 to:(con numArgs)) collect:[:i | 'arg' , i printString].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   112
	aList addAll:argNames.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   113
	varNames := (1 to:(con nvars)) collect:[:i | 'var' , i printString].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   114
	aList addAll:varNames.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   115
	aList addAll:names.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   116
	homeContext isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   117
	    inspectedValues := Array withAll:(con argsAndVars)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   118
	] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   119
	    inspectedValues := (Array withAll:(con argsAndVars)) , homeContext argsAndVars
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   120
	]
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
   121
    ] ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   122
	aList addAll:names.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   123
	inspectedValues := homeContext argsAndVars
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
   124
    ].
d904237f7c44 Initial revision
claus
parents:
diff changeset
   125
    listView contents:aList.
d904237f7c44 Initial revision
claus
parents:
diff changeset
   126
d904237f7c44 Initial revision
claus
parents:
diff changeset
   127
    workspace contents:nil.
d904237f7c44 Initial revision
claus
parents:
diff changeset
   128
    self setDoitActionIn:workspace for:con.
d904237f7c44 Initial revision
claus
parents:
diff changeset
   129
!
d904237f7c44 Initial revision
claus
parents:
diff changeset
   130
d904237f7c44 Initial revision
claus
parents:
diff changeset
   131
release
d904237f7c44 Initial revision
claus
parents:
diff changeset
   132
    "release inspected object"
d904237f7c44 Initial revision
claus
parents:
diff changeset
   133
d904237f7c44 Initial revision
claus
parents:
diff changeset
   134
    inspectedContext := nil.
d904237f7c44 Initial revision
claus
parents:
diff changeset
   135
    super release
d904237f7c44 Initial revision
claus
parents:
diff changeset
   136
! !
d904237f7c44 Initial revision
claus
parents:
diff changeset
   137
d904237f7c44 Initial revision
claus
parents:
diff changeset
   138
!ContextInspectorView methodsFor:'private'!
d904237f7c44 Initial revision
claus
parents:
diff changeset
   139
d904237f7c44 Initial revision
claus
parents:
diff changeset
   140
setDoitActionIn:aWorkspace for:aContext
d904237f7c44 Initial revision
claus
parents:
diff changeset
   141
    aWorkspace doItAction:[:theCode |
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   142
	Compiler evaluate:theCode
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   143
		       in:aContext
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   144
		 receiver:nil
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   145
		notifying:aWorkspace
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   146
		   logged:true 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   147
		   ifFail:nil
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
   148
    ]
d904237f7c44 Initial revision
claus
parents:
diff changeset
   149
! !
d904237f7c44 Initial revision
claus
parents:
diff changeset
   150
d904237f7c44 Initial revision
claus
parents:
diff changeset
   151
!ContextInspectorView methodsFor:'user actions'!
d904237f7c44 Initial revision
claus
parents:
diff changeset
   152
d904237f7c44 Initial revision
claus
parents:
diff changeset
   153
doAccept:theText
d904237f7c44 Initial revision
claus
parents:
diff changeset
   154
    |value|
d904237f7c44 Initial revision
claus
parents:
diff changeset
   155
d904237f7c44 Initial revision
claus
parents:
diff changeset
   156
    selectedLine notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   157
	value := Compiler evaluate:theText
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   158
			  receiver:inspectedObject 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   159
			 notifying:workspace.
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
   160
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   161
	"yes, you can do that with a context"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   162
	inspectedContext at:selectedLine put:value.
34
d904237f7c44 Initial revision
claus
parents:
diff changeset
   163
    ].
d904237f7c44 Initial revision
claus
parents:
diff changeset
   164
! !