CodeView.st
author claus
Tue, 08 Aug 1995 03:07:33 +0200
changeset 136 80d2240b2cdc
parent 132 596439fe4efd
child 174 d80a6cc3f9b2
permissions -rw-r--r--
.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     1
"
4
88eb91574867 *** empty log message ***
claus
parents: 2
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
70
14443a9ea4ec *** empty log message ***
claus
parents: 59
diff changeset
     3
	      All Rights Reserved
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     4
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    11
"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    12
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    13
Workspace subclass:#CodeView
125
claus
parents: 123
diff changeset
    14
       instanceVariableNames:'explainAction'
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    15
       classVariableNames:''
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    16
       poolDictionaries:''
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    17
       category:'Interface-Workspace'
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    18
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    19
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    20
CodeView comment:'
4
88eb91574867 *** empty log message ***
claus
parents: 2
diff changeset
    21
COPYRIGHT (c) 1989 by Claus Gittinger
70
14443a9ea4ec *** empty log message ***
claus
parents: 59
diff changeset
    22
	    All Rights Reserved
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    23
136
claus
parents: 132
diff changeset
    24
$Header: /cvs/stx/stx/libwidg/CodeView.st,v 1.20 1995-08-08 01:06:44 claus Exp $
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    25
'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    26
32
b6c23dfd5663 *** empty log message ***
claus
parents: 27
diff changeset
    27
!CodeView class methodsFor:'documentation'!
b6c23dfd5663 *** empty log message ***
claus
parents: 27
diff changeset
    28
38
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    29
copyright
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    30
"
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    31
 COPYRIGHT (c) 1989 by Claus Gittinger
70
14443a9ea4ec *** empty log message ***
claus
parents: 59
diff changeset
    32
	      All Rights Reserved
38
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    33
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    34
 This software is furnished under a license and may be used
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    35
 only in accordance with the terms of that license and with the
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    36
 inclusion of the above copyright notice.   This software may not
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    37
 be provided or otherwise made available to, or used by, any
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    38
 other person.  No title to or ownership of the software is
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    39
 hereby transferred.
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    40
"
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    41
!
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    42
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    43
version
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    44
"
136
claus
parents: 132
diff changeset
    45
$Header: /cvs/stx/stx/libwidg/CodeView.st,v 1.20 1995-08-08 01:06:44 claus Exp $
38
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    46
"
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    47
!
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    48
32
b6c23dfd5663 *** empty log message ***
claus
parents: 27
diff changeset
    49
documentation
b6c23dfd5663 *** empty log message ***
claus
parents: 27
diff changeset
    50
"
125
claus
parents: 123
diff changeset
    51
    a view for text which is known to be smalltalk code. 
claus
parents: 123
diff changeset
    52
    It adds explain to the menu, and defines another action: 
claus
parents: 123
diff changeset
    53
      explainAction to be performed for explain.
32
b6c23dfd5663 *** empty log message ***
claus
parents: 27
diff changeset
    54
125
claus
parents: 123
diff changeset
    55
    This action is to be defined by the user of this view 
38
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    56
    (i.e. ususally the owning browser)
121
claus
parents: 118
diff changeset
    57
125
claus
parents: 123
diff changeset
    58
    If used with a model, accept sends the changeMsg to it (as defined in EditTextView).
121
claus
parents: 118
diff changeset
    59
    (however, it is possible to define moth changeMsg and acceptAction)
123
claus
parents: 121
diff changeset
    60
claus
parents: 121
diff changeset
    61
claus
parents: 121
diff changeset
    62
    Caveat:
claus
parents: 121
diff changeset
    63
	in this version, CodeView does not yet support MVC setups for doIt
claus
parents: 121
diff changeset
    64
	and explain.
claus
parents: 121
diff changeset
    65
	If required, simulate this by setting the doItAction and
claus
parents: 121
diff changeset
    66
	explainAction, to notify the model manually about whats going on.
32
b6c23dfd5663 *** empty log message ***
claus
parents: 27
diff changeset
    67
"
b6c23dfd5663 *** empty log message ***
claus
parents: 27
diff changeset
    68
! !
b6c23dfd5663 *** empty log message ***
claus
parents: 27
diff changeset
    69
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    70
!CodeView methodsFor:'initialization'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    71
97
cbf495fe3b64 *** empty log message ***
claus
parents: 95
diff changeset
    72
editMenu
121
claus
parents: 118
diff changeset
    73
    "return the popUpMenu;
claus
parents: 118
diff changeset
    74
     to make this independent from what is defined in superclasses,
claus
parents: 118
diff changeset
    75
     get the superclass menu and add my functions."
131
claus
parents: 125
diff changeset
    76
97
cbf495fe3b64 *** empty log message ***
claus
parents: 95
diff changeset
    77
    |m sub idx|
38
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    78
97
cbf495fe3b64 *** empty log message ***
claus
parents: 95
diff changeset
    79
    m := super editMenu.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    80
131
claus
parents: 125
diff changeset
    81
    self sensor ctrlDown ifTrue:[
claus
parents: 125
diff changeset
    82
	m addLabels:(resources array:#('-' 'commentIt' 'uncommentIt'))
claus
parents: 125
diff changeset
    83
	  selectors:#(nil commentSelection uncommentSelection)
claus
parents: 125
diff changeset
    84
	  after:(m labels size).
claus
parents: 125
diff changeset
    85
	self hasSelection ifFalse:[
claus
parents: 125
diff changeset
    86
	    m disableAll:#(commentSelection uncommentSelection) 
claus
parents: 125
diff changeset
    87
	].
claus
parents: 125
diff changeset
    88
    ] ifFalse:[
38
4b9b70b2cc87 2.10.3 pre-final version
claus
parents: 32
diff changeset
    89
131
claus
parents: 125
diff changeset
    90
	"
claus
parents: 125
diff changeset
    91
	 codeViews do support #accept
claus
parents: 125
diff changeset
    92
	 ... add it after #inspectIt
claus
parents: 125
diff changeset
    93
	"
claus
parents: 125
diff changeset
    94
	idx := m indexOf:#inspectIt.
claus
parents: 125
diff changeset
    95
	idx ~~ 0 ifTrue:[
claus
parents: 125
diff changeset
    96
	    m addLabels:(resources array:#('-' 'accept'))
claus
parents: 125
diff changeset
    97
	      selectors:#(nil accept)
claus
parents: 125
diff changeset
    98
	      after:idx.
claus
parents: 125
diff changeset
    99
	].
claus
parents: 125
diff changeset
   100
claus
parents: 125
diff changeset
   101
	"
claus
parents: 125
diff changeset
   102
	 and add #explain after $gotoLine in the extra menu
claus
parents: 125
diff changeset
   103
	"
claus
parents: 125
diff changeset
   104
	sub := m subMenuAt:#others.
claus
parents: 125
diff changeset
   105
	sub notNil ifTrue:[
claus
parents: 125
diff changeset
   106
	    idx := sub indexOf:#gotoLine.
claus
parents: 125
diff changeset
   107
	    sub addLabels:(resources array:#('-' 'explain'))
claus
parents: 125
diff changeset
   108
		selectors:#(nil explain)
claus
parents: 125
diff changeset
   109
		after:idx.
claus
parents: 125
diff changeset
   110
	    self hasSelection ifFalse:[
claus
parents: 125
diff changeset
   111
		sub disable:#explain 
claus
parents: 125
diff changeset
   112
	    ].
97
cbf495fe3b64 *** empty log message ***
claus
parents: 95
diff changeset
   113
	].
59
450ce95a72a4 *** empty log message ***
claus
parents: 38
diff changeset
   114
    ].
131
claus
parents: 125
diff changeset
   115
    ^ m.
claus
parents: 125
diff changeset
   116
! !
97
cbf495fe3b64 *** empty log message ***
claus
parents: 95
diff changeset
   117
131
claus
parents: 125
diff changeset
   118
!CodeView methodsFor:'editing'!
claus
parents: 125
diff changeset
   119
claus
parents: 125
diff changeset
   120
uncommentFrom:line1 to:line2
claus
parents: 125
diff changeset
   121
    "convenient function to comment out a block.
claus
parents: 125
diff changeset
   122
     All lines from line1 to line2 get an end-of-line comment
claus
parents: 125
diff changeset
   123
     in the first col."
claus
parents: 125
diff changeset
   124
claus
parents: 125
diff changeset
   125
    line1 to:line2 do:[:lineNr |
claus
parents: 125
diff changeset
   126
	|l|
claus
parents: 125
diff changeset
   127
claus
parents: 125
diff changeset
   128
	l := self listAt:lineNr.
claus
parents: 125
diff changeset
   129
	(l notNil and:[l startsWith:('"' ,'/')]) ifTrue:[
claus
parents: 125
diff changeset
   130
	    self at:lineNr put:(l copyFrom:3)
claus
parents: 125
diff changeset
   131
	]
claus
parents: 125
diff changeset
   132
    ].
claus
parents: 125
diff changeset
   133
    self textChanged.
claus
parents: 125
diff changeset
   134
!
claus
parents: 125
diff changeset
   135
claus
parents: 125
diff changeset
   136
commentFrom:line1 to:line2
claus
parents: 125
diff changeset
   137
    "convenient function to comment out a block.
claus
parents: 125
diff changeset
   138
     All lines from line1 to line2 get an end-of-line comment
claus
parents: 125
diff changeset
   139
     in the first col."
claus
parents: 125
diff changeset
   140
claus
parents: 125
diff changeset
   141
    line1 to:line2 do:[:lineNr |
claus
parents: 125
diff changeset
   142
	|l|
claus
parents: 125
diff changeset
   143
claus
parents: 125
diff changeset
   144
	l := self listAt:lineNr.
claus
parents: 125
diff changeset
   145
	l isNil ifTrue:[l := ''].
claus
parents: 125
diff changeset
   146
	self at:lineNr put:(('"' , '/') , l)
claus
parents: 125
diff changeset
   147
    ].
claus
parents: 125
diff changeset
   148
    self textChanged.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   149
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   150
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   151
!CodeView methodsFor:'accessing'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   152
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   153
explainAction:aBlock
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   154
    "set the action to be performed on explain"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   155
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   156
    explainAction := aBlock
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   157
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   158
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   159
!CodeView methodsFor:'user actions'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   160
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   161
accept
125
claus
parents: 123
diff changeset
   162
    "redefined accept action;
claus
parents: 123
diff changeset
   163
     save cursor and selection to allow restore in case of an error
claus
parents: 123
diff changeset
   164
     (we are typically compiling here ... and the compiler may show
claus
parents: 123
diff changeset
   165
     errors by highlighting them)"
95
7535cfca9509 *** empty log message ***
claus
parents: 70
diff changeset
   166
7535cfca9509 *** empty log message ***
claus
parents: 70
diff changeset
   167
    codeStartPosition := 1.
7535cfca9509 *** empty log message ***
claus
parents: 70
diff changeset
   168
    [
7535cfca9509 *** empty log message ***
claus
parents: 70
diff changeset
   169
	Object abortSignal handle:[:ex |
7535cfca9509 *** empty log message ***
claus
parents: 70
diff changeset
   170
	    self cursor:Cursor normal.
7535cfca9509 *** empty log message ***
claus
parents: 70
diff changeset
   171
	    "redraw selection in normal color"
7535cfca9509 *** empty log message ***
claus
parents: 70
diff changeset
   172
	    self selectFromLine:selectionStartLine col:selectionStartCol 
7535cfca9509 *** empty log message ***
claus
parents: 70
diff changeset
   173
			 toLine:selectionEndLine col:selectionEndCol.
7535cfca9509 *** empty log message ***
claus
parents: 70
diff changeset
   174
	    ex return
7535cfca9509 *** empty log message ***
claus
parents: 70
diff changeset
   175
	] do:[
125
claus
parents: 123
diff changeset
   176
	    super accept.
70
14443a9ea4ec *** empty log message ***
claus
parents: 59
diff changeset
   177
	]
95
7535cfca9509 *** empty log message ***
claus
parents: 70
diff changeset
   178
    ] valueNowOrOnUnwindDo:[
7535cfca9509 *** empty log message ***
claus
parents: 70
diff changeset
   179
	self unselect.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   180
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   181
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   182
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   183
explain
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   184
    "explain action;
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   185
     evaluate the explainBlock passing whole contents and 
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   186
     selection as arguments."
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   187
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   188
    |text|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   189
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   190
    explainAction notNil ifTrue:[
70
14443a9ea4ec *** empty log message ***
claus
parents: 59
diff changeset
   191
	text := self selection.
14443a9ea4ec *** empty log message ***
claus
parents: 59
diff changeset
   192
	text notNil ifTrue:[
121
claus
parents: 118
diff changeset
   193
	    explainAction value:(self contents) value:(text asString)
70
14443a9ea4ec *** empty log message ***
claus
parents: 59
diff changeset
   194
	]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   195
    ]
136
claus
parents: 132
diff changeset
   196
!
claus
parents: 132
diff changeset
   197
claus
parents: 132
diff changeset
   198
commentSelection
claus
parents: 132
diff changeset
   199
    "convenient function to comment out a block.
claus
parents: 132
diff changeset
   200
     All lines from line1 to line2 get an end-of-line comment
claus
parents: 132
diff changeset
   201
     in the first col."
claus
parents: 132
diff changeset
   202
claus
parents: 132
diff changeset
   203
    |e|
claus
parents: 132
diff changeset
   204
claus
parents: 132
diff changeset
   205
    (selectionStartCol == 1 and:[selectionEndCol == 0]) ifTrue:[
claus
parents: 132
diff changeset
   206
	self commentFrom:selectionStartLine to:selectionEndLine-1
claus
parents: 132
diff changeset
   207
    ] ifFalse:[
claus
parents: 132
diff changeset
   208
	self insert:$" atLine:selectionStartLine col:selectionStartCol.
claus
parents: 132
diff changeset
   209
	e := selectionEndCol + 1.
claus
parents: 132
diff changeset
   210
	selectionStartLine == selectionEndLine ifTrue:[e := e + 1].
claus
parents: 132
diff changeset
   211
	self insert:$" atLine:selectionEndLine col:e.
claus
parents: 132
diff changeset
   212
	self selectFromLine:selectionStartLine col:selectionStartCol
claus
parents: 132
diff changeset
   213
		     toLine:selectionEndLine col:e.
claus
parents: 132
diff changeset
   214
    ]
claus
parents: 132
diff changeset
   215
!
claus
parents: 132
diff changeset
   216
claus
parents: 132
diff changeset
   217
uncommentSelection
claus
parents: 132
diff changeset
   218
    "convenient function to comment out a block.
claus
parents: 132
diff changeset
   219
     All lines from line1 to line2 get an end-of-line comment
claus
parents: 132
diff changeset
   220
     in the first col."
claus
parents: 132
diff changeset
   221
claus
parents: 132
diff changeset
   222
    |e|
claus
parents: 132
diff changeset
   223
claus
parents: 132
diff changeset
   224
    (selectionStartCol == 1 and:[selectionEndCol == 0]) ifTrue:[
claus
parents: 132
diff changeset
   225
	self uncommentFrom:selectionStartLine to:selectionEndLine-1
claus
parents: 132
diff changeset
   226
    ] ifFalse:[
claus
parents: 132
diff changeset
   227
	((self characterAtLine:selectionStartLine col:selectionStartCol) == $"
claus
parents: 132
diff changeset
   228
	and:[(self characterAtLine:selectionEndLine col:selectionEndCol) == $"]) ifTrue:[
claus
parents: 132
diff changeset
   229
	    self deleteCharAtLine:selectionEndLine col:selectionEndCol.
claus
parents: 132
diff changeset
   230
	    self deleteCharAtLine:selectionStartLine col:selectionStartCol.
claus
parents: 132
diff changeset
   231
	    e := selectionEndCol - 1.
claus
parents: 132
diff changeset
   232
	    selectionStartLine == selectionEndLine ifTrue:[e := e - 1].
claus
parents: 132
diff changeset
   233
	    self selectFromLine:selectionStartLine col:selectionStartCol
claus
parents: 132
diff changeset
   234
			 toLine:selectionEndLine col:e.
claus
parents: 132
diff changeset
   235
	]
claus
parents: 132
diff changeset
   236
    ]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   237
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   238
70
14443a9ea4ec *** empty log message ***
claus
parents: 59
diff changeset
   239
!CodeView methodsFor:'event handling'!
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   240
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   241
keyPress:key x:x y:y
32
b6c23dfd5663 *** empty log message ***
claus
parents: 27
diff changeset
   242
    "catch keyboard shortcuts"
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   243
132
claus
parents: 131
diff changeset
   244
    <resource: #keyboard (#Accept #Explain #Help 
claus
parents: 131
diff changeset
   245
	       #CommentSelection #UncommentSelection)>
claus
parents: 131
diff changeset
   246
32
b6c23dfd5663 *** empty log message ***
claus
parents: 27
diff changeset
   247
    (key == #Accept)  ifTrue:[^ self accept].
10
a288b33897a5 *** empty log message ***
claus
parents: 6
diff changeset
   248
    (key == #Explain) ifTrue:[^ self explain].
32
b6c23dfd5663 *** empty log message ***
claus
parents: 27
diff changeset
   249
    (key == #Help)    ifTrue:[^ self explain].
132
claus
parents: 131
diff changeset
   250
    (key == #CommentSelection)    ifTrue:[^ self commentSelection].
claus
parents: 131
diff changeset
   251
    (key == #UncommentSelection)  ifTrue:[^ self uncommentSelection].
121
claus
parents: 118
diff changeset
   252
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   253
    super keyPress:key x:x y:y
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   254
! !