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