EditTextView.st
author claus
Thu, 13 Jan 1994 01:18:51 +0100
changeset 24 966098a893f8
parent 19 a696fb528758
child 25 975bead4571a
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     1
"
5
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     3
              All Rights Reserved
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
TextView subclass:#EditTextView
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:'cursorLine cursorVisibleLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    15
                              cursorCol cursorShown prevCursorState
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    16
                              readOnly modified fixedSize
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    17
                              exceptionBlock
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    18
                              errorMessage
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    19
                              cursorFgColor cursorBgColor
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
    20
                              undoAction  
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
    21
                              typeOfSelection 
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
    22
                              lastString lastReplacement lastAction 
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
    23
                              replacing showMatchingParenthesis'
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    24
       classVariableNames:''
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    25
       poolDictionaries:''
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    26
       category:'Views-Text'
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    27
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    28
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    29
EditTextView comment:'
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    30
5
claus
parents: 3
diff changeset
    31
COPYRIGHT (c) 1989 by Claus Gittinger
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    32
            All Rights Reserved
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    33
24
966098a893f8 *** empty log message ***
claus
parents: 19
diff changeset
    34
$Header: /cvs/stx/stx/libwidg/EditTextView.st,v 1.9 1994-01-13 00:15:09 claus Exp $
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    35
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    36
written jun-89 by claus
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    37
'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    38
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    39
!EditTextView class methodsFor:'documentation'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    40
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    41
documentation
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    42
"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    43
    a view for editable text - adds editing functionality to TextView
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    44
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    45
    Instance variables:
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    46
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    47
    cursorLine              <Number>        line where cursor sits (1..)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    48
    cursorVisibleLine       <Number>        visible line where cursor sits (1..nLinesShown)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    49
    cursorCol               <Number>        col where cursor sits (1..)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    50
    cursorShown             <Boolean>       true, if cursor is currently shown
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    51
    prevCursorState         <Boolean>       temporary
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    52
    readOnly                <Boolean>       true, if text may not be edited
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    53
    modified                <Boolean>       true, if text has been modified
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    54
    fixedSize               <Boolean>       true, if no lines may be added/removed
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    55
    exceptionBlock          <Block>         block to be evaluated when readonly text is about to be modified
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    56
    errorMessage            <String>        message text 
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    57
    cursorFgColor           <Color>         color used for cursor drawing
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    58
    cursorBgColor           <Color>         color used for cursor drawing
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
    59
    undoAction              <Block>         block which undoes last cut, paste or replace
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
    60
    typeOfSelection         <Symbol>        #paste, if selection created by paste, nil otherwise
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
    61
    lastCut                 <String>        last cut or replaced string
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
    62
    lastReplacement         <String>        last replacement
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
    63
    replacing               <Boolean>       true if entered characters replace last selection
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
    64
    showMatchingParenthesis <Boolean>       if true, shows matching parenthesis
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
    65
                                            when entering one
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    66
"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    67
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    68
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    69
!EditTextView methodsFor:'initialization'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    70
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    71
initialize
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    72
    super initialize.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    73
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    74
    self level:-1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    75
    errorMessage := 'Text may not me changed'.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    76
    readOnly := false.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    77
    fixedSize := false.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    78
    exceptionBlock := [:errorText | ].
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
    79
    cursorShown := prevCursorState := true.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    80
    cursorLine := 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    81
    cursorVisibleLine := 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    82
    cursorCol := 1.
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
    83
    modified := false.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
    84
    showMatchingParenthesis := false
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    85
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    86
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    87
initStyle
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    88
    super initStyle.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    89
    cursorFgColor := bgColor.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    90
    device hasColors ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    91
        cursorBgColor := Color red
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    92
    ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    93
        cursorBgColor := fgColor
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    94
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    95
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    96
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    97
initializeMiddleButtonMenu
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    98
    |labels|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    99
 
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   100
    labels := resources array:#(
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   101
"
10
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   102
                               'undo'
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   103
"
10
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   104
                               'again'
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   105
                               '-'
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   106
                               'copy'
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   107
                               'cut'
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   108
                               'paste'
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   109
                               '-'
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   110
                               'accept'
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   111
                               '-'
19
a696fb528758 *** empty log message ***
claus
parents: 15
diff changeset
   112
                               'others'
10
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   113
                               ).
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   114
10
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   115
    self middleButtonMenu:(PopUpMenu
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   116
                                labels:labels
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   117
                             selectors:#(
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   118
"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   119
                                         undo
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   120
"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   121
                                         again
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   122
                                         nil
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   123
                                         copySelection
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   124
                                         cut
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   125
                                         paste
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   126
                                         nil
10
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   127
                                         accept
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   128
                                         nil
10
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   129
                                         others
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   130
                                        )
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   131
                                receiver:self
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   132
                                     for:self).
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   133
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   134
    middleButtonMenu subMenuAt:#others put:(PopUpMenu
19
a696fb528758 *** empty log message ***
claus
parents: 15
diff changeset
   135
                                labels:(resources array:#(
10
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   136
                                         'search'
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   137
                                         'goto'
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   138
                                         '-'
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   139
                                         'explain'
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   140
                                         '-'
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   141
                                         'font'
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   142
                                         '-'
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   143
                                         'indent'
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   144
                                         '-'
19
a696fb528758 *** empty log message ***
claus
parents: 15
diff changeset
   145
                                         'save as ...'
10
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   146
                                         'print'
19
a696fb528758 *** empty log message ***
claus
parents: 15
diff changeset
   147
                                        ))
10
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   148
                              selectors:#(
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   149
                                          search
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   150
                                          gotoLine
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   151
                                          nil
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   152
                                          explain
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   153
                                          nil
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   154
                                          changeFont
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   155
                                          nil
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   156
                                          indent
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   157
                                          nil
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   158
                                          save
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   159
                                          print
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
   160
                                         )
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   161
                                receiver:self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   162
                                     for:self).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   163
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   164
    self enableOrDisableSelectionMenuEntries
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   165
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   166
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   167
realize
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   168
    super realize.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   169
    cursorFgColor := cursorFgColor on:device.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   170
    cursorBgColor := cursorBgColor on:device.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   171
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   172
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   173
!EditTextView methodsFor:'accessing'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   174
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   175
cursorForegroundColor:color1 backgroundColor:color2
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   176
    "set both cursor foreground and cursor background colors"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   177
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   178
    self hideCursor.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   179
    cursorFgColor := color1 on:device.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   180
    cursorBgColor := color2 on:device.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   181
    self showCursor
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   182
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   183
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   184
contents
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   185
    "answer the contents as a String"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   186
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   187
    list isNil ifTrue:[^ ''].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   188
    self removeTrailingBlankLines.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   189
    ^ list asString
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   190
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   191
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   192
list:something
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   193
    "position cursor home when setting contents"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   194
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   195
    super list:something.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   196
    self cursorHome
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   197
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   198
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   199
readOnly
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   200
    "make the text readonly"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   201
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   202
    readOnly := true
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   203
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   204
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   205
fixedSize
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   206
    "make the texts size fixed (no lines may be added)"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   207
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   208
    readOnly ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   209
        readOnly := true.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   210
        middleButtonMenu disable:#cut.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   211
        middleButtonMenu disable:#paste.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   212
        middleButtonMenu disable:#replace.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   213
        middleButtonMenu disable:#indent
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   214
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   215
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   216
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   217
exceptionBlock:aBlock
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   218
    "define the action to be triggered when user tries to modify
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   219
     readonly text"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   220
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   221
    exceptionBlock := aBlock
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   222
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   223
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   224
fromFile:aFileName
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   225
    "take contents from a named file"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   226
3
claus
parents: 0
diff changeset
   227
    self contents:(aFileName asFilename readStream contents)
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   228
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   229
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   230
modified:aBoolean
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   231
    "set the modified flag"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   232
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   233
    modified := aBoolean
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   234
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   235
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   236
modified
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   237
    "return true if text was modified"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   238
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   239
    ^ modified
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   240
!
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   241
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   242
characterUnderCursor
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   243
    "return the character under the cursor - space if behond line"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   244
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   245
    ^ self characterAtLine:cursorLine col:cursorCol
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   246
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   247
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   248
!EditTextView methodsFor:'private'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   249
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   250
contentsChanged
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   251
    "triggered whenever text is changed"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   252
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   253
    super contentsChanged.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   254
    modified := true.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   255
    contentsWasSaved := false
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   256
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   257
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   258
!EditTextView methodsFor:'editing'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   259
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   260
mergeLine:lineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   261
    "merge line lineNr with line lineNr+1"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   262
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   263
    |leftPart rightPart bothParts nextLineNr|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   264
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   265
    list isNil ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   266
        nextLineNr := lineNr + 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   267
        (nextLineNr > list size) ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   268
            (list at:lineNr) isNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   269
                leftPart := ''
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   270
            ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   271
                leftPart := list at:lineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   272
            ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   273
            (list at:nextLineNr) isNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   274
                rightPart := ''
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   275
            ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   276
                rightPart := list at:nextLineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   277
            ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   278
            bothParts := leftPart , rightPart.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   279
            bothParts isBlank ifTrue:[bothParts := nil].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   280
            list at:lineNr put:bothParts.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   281
            self redrawLine:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   282
            self deleteLine:nextLineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   283
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   284
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   285
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   286
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   287
splitLine:lineNr before:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   288
    "split the line linNr before colNr; the right part (from colNr)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   289
     is cut off and inserted after lineNr; the view is redrawn"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   290
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   291
    |line lineSize leftRest rightRest visLine w      
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   292
     srcY    "{ Class: SmallInteger }" |
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   293
    
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   294
    list isNil ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   295
        lineNr > (list size) ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   296
            (colNr == 1) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   297
                self insertLine:nil before:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   298
                ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   299
            ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   300
            line := list at:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   301
            line isNil ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   302
                lineSize := line size.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   303
                (colNr <= lineSize) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   304
                    rightRest := line copyFrom:colNr to:lineSize.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   305
                    (colNr > 1) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   306
                        leftRest := line copyFrom:1 to:(colNr - 1)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   307
                    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   308
                ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   309
                    leftRest := line
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   310
                ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   311
            ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   312
            leftRest notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   313
                leftRest isBlank ifTrue:[leftRest := nil]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   314
            ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   315
            list at:lineNr put:leftRest.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   316
            modified := true.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   317
            contentsWasSaved := false.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   318
            self withoutRedrawInsertLine:rightRest before:(lineNr + 1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   319
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   320
            visLine := self listLineToVisibleLine:(lineNr).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   321
            visLine notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   322
                w := self widthForScrollBetween:lineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   323
                                            and:(firstLineShown + nLinesShown).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   324
                srcY := topMargin + (visLine * fontHeight).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   325
                self copyFrom:self x:textStartLeft y:srcY
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   326
                                 toX:textStartLeft y:(srcY + fontHeight)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   327
                               width:w
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   328
                              height:((nLinesShown - visLine - 1) * fontHeight).
24
966098a893f8 *** empty log message ***
claus
parents: 19
diff changeset
   329
                self catchExpose.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   330
                self redrawLine:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   331
                self redrawLine:(lineNr + 1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   332
                self waitForExpose
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   333
            ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   334
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   335
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   336
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   337
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   338
withoutRedrawInsertLine:aString before:lineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   339
    "insert the argument, aString before line lineNr; the string
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   340
     becomes line nileNr; everything else is moved down; the view
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   341
     is not redrawn"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   342
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   343
    |line|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   344
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   345
    readOnly ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   346
        exceptionBlock value:errorMessage.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   347
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   348
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   349
    line := aString.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   350
    line notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   351
        line isBlank ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   352
            line := nil
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   353
        ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   354
            (line occurrencesOf:(Character tab)) == 0 ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   355
                line := self withTabsExpanded:line
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   356
            ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   357
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   358
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   359
    list isNil ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   360
        list := Text new:lineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   361
    ] ifFalse: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   362
        list grow:((list size + 1) max:lineNr)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   363
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   364
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   365
    "I have changed 'replaceFrom:to:with:startingAt:' to correctly handle 
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   366
     overlapping copy - if it didn't, we had to use:"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   367
"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   368
    index := list size.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   369
    [index > lineNr] whileTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   370
        pIndex := index - 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   371
        list at:index put:(list at:pIndex).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   372
        index := pIndex
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   373
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   374
"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   375
    list replaceFrom:(lineNr + 1) to:(list size) with:list startingAt:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   376
    list at:lineNr put:line.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   377
    self contentsChanged
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   378
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   379
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   380
insertLine:aString before:lineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   381
    "insert the line aString before line lineNr"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   382
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   383
    |visLine w 
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   384
     dstY "{ Class: SmallInteger }" |
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   385
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   386
    self withoutRedrawInsertLine:aString before:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   387
    visLine := self listLineToVisibleLine:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   388
    visLine notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   389
        w := self widthForScrollBetween:lineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   390
                                    and:(firstLineShown + nLinesShown).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   391
        dstY := topMargin + ((visLine ) * fontHeight).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   392
        self copyFrom:self x:textStartLeft y:(dstY - fontHeight)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   393
                         toX:textStartLeft y:dstY
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   394
                       width:w
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   395
                      height:((nLinesShown - visLine "- 1") * fontHeight).
24
966098a893f8 *** empty log message ***
claus
parents: 19
diff changeset
   396
        self catchExpose.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   397
        self redrawVisibleLine:visLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   398
        self waitForExpose
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   399
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   400
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   401
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   402
insertLines:someText from:start to:end before:lineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   403
    "insert a bunch of lines before line lineNr"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   404
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   405
    |visLine w nLines "{ Class: SmallInteger }"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   406
     srcY "{ Class: SmallInteger }"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   407
     dstY "{ Class: SmallInteger }" |
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   408
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   409
    readOnly ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   410
        exceptionBlock value:errorMessage.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   411
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   412
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   413
    self withoutRedrawInsertLines:someText
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   414
                             from:start to:end
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   415
                           before:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   416
    visLine := self listLineToVisibleLine:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   417
    visLine notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   418
        nLines := end - start + 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   419
        ((visLine + nLines) >= nLinesShown) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   420
            self redrawFromVisibleLine:visLine to:nLinesShown
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   421
        ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   422
            w := self widthForScrollBetween:(lineNr + nLines)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   423
                                        and:(firstLineShown + nLines + nLinesShown).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   424
            srcY := topMargin + ((visLine - 1) * fontHeight).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   425
            dstY := srcY + (nLines * fontHeight).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   426
            self copyFrom:self x:textStartLeft y:srcY
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   427
                             toX:textStartLeft y:dstY
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   428
                           width:w
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   429
                          height:(height - dstY).
24
966098a893f8 *** empty log message ***
claus
parents: 19
diff changeset
   430
            self catchExpose.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   431
            self redrawFromVisibleLine:visLine to:(visLine + nLines - 1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   432
            self waitForExpose
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   433
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   434
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   435
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   436
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   437
insert:aCharacter atLine:lineNr col:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   438
    "insert a single character at lineNr/colNr"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   439
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   440
    |line lineSize newLine drawCharacterOnly|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   441
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   442
    readOnly ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   443
        exceptionBlock value:errorMessage.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   444
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   445
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   446
    aCharacter == (Character cr) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   447
        self splitLine:lineNr before:colNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   448
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   449
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   450
    drawCharacterOnly := false.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   451
    self checkForExistingLine:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   452
    line := list at:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   453
    lineSize := line size.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   454
    (aCharacter == Character space) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   455
        (colNr > lineSize)  ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   456
            ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   457
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   458
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   459
    (lineSize == 0) ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   460
        newLine := String new:colNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   461
        drawCharacterOnly := true
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   462
    ] ifFalse: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   463
        (colNr > lineSize) ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   464
            newLine := String new:colNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   465
            newLine replaceFrom:1 to:lineSize
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   466
                           with:line startingAt:1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   467
            drawCharacterOnly := true
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   468
        ] ifFalse: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   469
            newLine := String new:(lineSize + 1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   470
            newLine replaceFrom:1 to:(colNr - 1)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   471
                           with:line startingAt:1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   472
            newLine replaceFrom:(colNr + 1) to:(lineSize + 1)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   473
                           with:line startingAt:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   474
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   475
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   476
    newLine at:colNr put:aCharacter.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   477
    aCharacter == (Character tab) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   478
        newLine := self withTabsExpanded:newLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   479
        drawCharacterOnly := false
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   480
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   481
    list at:lineNr put:newLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   482
    modified := true.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   483
    contentsWasSaved := false.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   484
    drawCharacterOnly ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   485
        self redrawLine:lineNr col:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   486
    ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   487
        self redrawLine:lineNr from:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   488
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   489
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   490
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   491
withoutRedrawInsertLines:lines from:start to:end before:lineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   492
    "insert a bunch of lines before line lineNr; the view
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   493
     is not redrawn"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   494
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   495
    |newLine newLines nLines|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   496
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   497
    readOnly ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   498
        exceptionBlock value:errorMessage.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   499
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   500
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   501
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   502
    nLines := end - start + 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   503
    newLines := Array new:(lines size).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   504
    start to:end do:[:index |
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   505
        newLine := lines at:index.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   506
        newLine notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   507
            newLine isBlank ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   508
                newLine := nil
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   509
            ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   510
                (newLine occurrencesOf:(Character tab)) == 0 ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   511
                    newLine := self withTabsExpanded:newLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   512
                ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   513
            ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   514
        ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   515
        newLines at:index put:newLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   516
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   517
    list isNil ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   518
        list := Text new:(lineNr + nLines + 1)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   519
    ] ifFalse: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   520
        list grow:((list size + nLines) max:(lineNr + nLines - 1))
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   521
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   522
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   523
    "I have changed 'replaceFrom:to:with:startingAt:' to correctly handle 
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   524
     overlapping copy - if it didn't, we had to use:"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   525
"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   526
    index := list size.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   527
    [index > lineNr] whileTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   528
        pIndex := index - 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   529
        list at:index put:(list at:pIndex).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   530
        index := pIndex
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   531
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   532
"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   533
    list replaceFrom:(lineNr + nLines) to:(list size) with:list startingAt:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   534
    list replaceFrom:lineNr to:(lineNr + nLines - 1) with:newLines startingAt:start.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   535
    self contentsChanged
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   536
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   537
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   538
withoutRedrawInsertStringWithoutCRs:aString atLine:lineNr col:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   539
    "insert aString (which has no crs) at lineNr/colNr"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   540
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   541
    |strLen line lineSize newLine|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   542
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   543
    aString isNil ifTrue:[^ self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   544
    readOnly ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   545
        exceptionBlock value:errorMessage.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   546
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   547
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   548
    strLen := aString size.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   549
    self checkForExistingLine:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   550
    line := list at:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   551
    line notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   552
        lineSize := line size
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   553
    ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   554
        lineSize := 0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   555
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   556
    ((colNr == 1) and:[lineSize == 0]) ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   557
        newLine := aString
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   558
    ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   559
        (lineSize == 0) ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   560
            newLine := String new:(colNr + strLen - 1)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   561
        ] ifFalse: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   562
            (colNr > lineSize) ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   563
                newLine := String new:(colNr + strLen - 1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   564
                newLine replaceFrom:1 to:lineSize
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   565
                               with:line startingAt:1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   566
            ] ifFalse: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   567
                newLine := String new:(lineSize + strLen).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   568
                newLine replaceFrom:1 to:(colNr - 1)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   569
                               with:line startingAt:1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   570
                newLine replaceFrom:(colNr + strLen) to:(lineSize + strLen)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   571
                               with:line startingAt:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   572
            ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   573
        ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   574
        newLine replaceFrom:colNr to:(colNr + strLen - 1)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   575
                       with:aString startingAt:1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   576
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   577
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   578
    (aString occurrencesOf:(Character tab)) == 0 ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   579
        newLine := self withTabsExpanded:newLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   580
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   581
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   582
    list at:lineNr put:newLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   583
    modified := true.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   584
    contentsWasSaved := false.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   585
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   586
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   587
insertStringWithoutCRs:aString atLine:lineNr col:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   588
    "insert aString (which has no crs) at lineNr/colNr"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   589
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   590
    self withoutRedrawInsertStringWithoutCRs:aString atLine:lineNr col:colNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   591
    self redrawLine:lineNr from:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   592
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   593
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   594
insertStringWithoutCRsAtCursor:aString
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   595
    "insert a string (which has no crs) at cursor position
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   596
     - advance cursor"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   597
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   598
    aString notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   599
        self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   600
            self insertString:aString atLine:cursorLine col:cursorCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   601
            cursorCol := cursorCol + aString size
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   602
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   603
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   604
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   605
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   606
insertCharAtCursor:aCharacter
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   607
    "insert a single character at cursor-position - advance cursor"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   608
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   609
    self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   610
        self insert:aCharacter atLine:cursorLine col:cursorCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   611
        aCharacter == (Character cr) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   612
            self cursorReturn
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   613
        ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   614
            cursorCol := cursorCol + 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   615
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   616
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   617
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   618
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   619
insertString:aString atLine:lineNr col:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   620
    "insert the string, aString at line/col;
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   621
     handle cr's correctly"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   622
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   623
    |start           "{ Class: SmallInteger }"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   624
     stop            "{ Class: SmallInteger }"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   625
     end             "{ Class: SmallInteger }"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   626
     subString c
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   627
     l               "{ Class: SmallInteger }" |
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   628
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   629
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   630
    aString isNil ifTrue:[^ self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   631
    ((aString occurrencesOf:(Character cr)) == 0) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   632
        ^ self insertStringWithoutCRs:aString atLine:lineNr col:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   633
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   634
    l := lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   635
    c := colNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   636
    start := 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   637
    end := aString size.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   638
    [start <= end] whileTrue:[
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   639
        stop := aString indexOf:(Character cr) startingAt:start.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   640
        stop == 0 ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   641
            stop := end + 1
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   642
        ].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   643
        subString := aString copyFrom:start to:(stop - 1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   644
        self insertStringWithoutCRs:subString atLine:l col:c.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   645
        (stop < end) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   646
            c := c + subString size.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   647
            self insert:(Character cr) atLine:l col:c.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   648
            l := l + 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   649
            c := 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   650
        ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   651
        start := stop + 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   652
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   653
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   654
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   655
insertStringAtCursor:aString
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   656
    "insert the argument, aString at cursor position
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   657
     handle cr's correctly"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   658
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   659
    |start " { Class: SmallInteger }"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   660
     stop  " { Class: SmallInteger }"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   661
     end   " { Class: SmallInteger }"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   662
     subString|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   663
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   664
    aString isNil ifTrue:[^ self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   665
    ((aString occurrencesOf:(Character cr)) == 0) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   666
        ^ self insertStringWithoutCRsAtCursor:aString
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   667
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   668
    start := 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   669
    end := aString size.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   670
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   671
    "insert the 1st line"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   672
    (cursorCol ~~ 1) ifTrue:[
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   673
        stop := aString indexOf:(Character cr) startingAt:start.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   674
        stop == 0 ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   675
            stop := end + 1
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   676
        ].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   677
        subString := aString copyFrom:start to:(stop - 1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   678
        self insertStringWithoutCRsAtCursor:subString.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   679
        self insertCharAtCursor:(Character cr).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   680
        start := stop + 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   681
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   682
    "insert the block of full lines"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   683
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   684
    [start <= end] whileTrue:[
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   685
        stop := aString indexOf:(Character cr) startingAt:start.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   686
        stop == 0 ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   687
            stop := end + 1
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   688
        ].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   689
        subString := aString copyFrom:start to:(stop - 1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   690
        self insertStringWithoutCRsAtCursor:subString.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   691
        (stop < end) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   692
            self insertCharAtCursor:(Character cr)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   693
        ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   694
        start := stop + 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   695
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   696
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   697
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   698
insertSelectedStringAtCursor:aString
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   699
    "insert the argument, aString at cursor position and select it"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   700
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   701
    |startLine startCol|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   702
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   703
    startLine := cursorLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   704
    startCol := cursorCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   705
    self insertStringAtCursor:aString.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   706
    self selectFromLine:startLine col:startCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   707
                 toLine:cursorLine col:(cursorCol - 1)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   708
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   709
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   710
insertLines:lines withCr:withCr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   711
    "insert a bunch of lines at cursor position. Cursor
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   712
     is moved behind insertion.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   713
     If withCr is true, append cr after last line"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   714
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   715
    |start end nLines|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   716
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   717
    lines notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   718
        nLines := lines size.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   719
        (nLines == 1) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   720
            self insertStringAtCursor:(lines at:1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   721
            withCr ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   722
                self insertCharAtCursor:(Character cr)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   723
            ] 
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   724
        ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   725
            (cursorCol ~~ 1) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   726
                self insertStringAtCursor:(lines at:1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   727
                self insertCharAtCursor:(Character cr).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   728
                start := 2
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   729
            ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   730
                start := 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   731
            ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   732
            withCr ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   733
                end := nLines
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   734
            ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   735
                end := nLines - 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   736
            ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   737
            (start < nLines) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   738
                (end >= start) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   739
                    self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   740
                        self insertLines:lines 
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   741
                                    from:start to:end
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   742
                                  before:cursorLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   743
                        cursorLine := cursorLine + (end - start + 1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   744
                        cursorVisibleLine := self absoluteLineToVisibleLine:
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   745
                                                                     cursorLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   746
                    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   747
                ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   748
            ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   749
            withCr ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   750
                "last line without cr"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   751
                self insertStringAtCursor:(lines at:nLines)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   752
            ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   753
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   754
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   755
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   756
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   757
deleteFromLine:startLine col:startCol toLine:endLine col:endCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   758
    "delete all text from startLine/startCol to endLine/endCol -
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   759
     joining lines if nescessary"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   760
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   761
    |line lineSize|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   762
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   763
    readOnly ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   764
        exceptionBlock value:errorMessage.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   765
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   766
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   767
    list isNil ifTrue:[^ self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   768
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   769
    (startLine == endLine) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   770
        "delete chars within a line"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   771
        self deleteCharsAtLine:startLine fromCol:startCol toCol:endCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   772
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   773
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   774
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   775
    ((startCol == 1) and:[endCol == 0]) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   776
        "delete full lines only"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   777
        endLine > startLine ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   778
            self deleteFromLine:startLine toLine:(endLine - 1)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   779
        ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   780
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   781
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   782
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   783
    "delete right rest of 1st line"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   784
    self deleteCharsAtLine:startLine fromCol:startCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   785
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   786
    "delete the inner lines ..."
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   787
    endLine > (startLine + 1) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   788
        self deleteFromLine:(startLine + 1) toLine:(endLine - 1)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   789
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   790
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   791
    (endCol ~~ 0) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   792
        "delete the left rest of the last line"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   793
        self deleteCharsAtLine:(startLine + 1) toCol:endCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   794
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   795
        "must add blanks, if startCal lies behond end of startLine"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   796
        line := list at:startLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   797
        lineSize := line size.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   798
        (startCol > lineSize) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   799
            line isNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   800
                line := String new:(startCol - 1)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   801
            ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   802
                line := line , (String new:(startCol - 1 - lineSize))
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   803
            ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   804
            list at:startLine put:line.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   805
            modified := true.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   806
            contentsWasSaved := false.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   807
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   808
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   809
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   810
    "merge the left rest of 1st line with right rest of last line into one"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   811
    self mergeLine:startLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   812
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   813
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   814
deleteFromLine:startLineNr toLine:endLineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   815
    "delete some lines"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   816
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   817
    readOnly ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   818
        exceptionBlock value:errorMessage.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   819
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   820
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   821
    list isNil ifTrue:[^ self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   822
    list removeFromIndex:startLineNr toIndex:endLineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   823
    self contentsChanged.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   824
    self redrawFromLine:startLineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   825
    (firstLineShown >= list size) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   826
        self makeLineVisible:(list size)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   827
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   828
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   829
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   830
deleteLineWithoutRedraw:lineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   831
    "delete line - no redraw;
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   832
     answer true, if something was really deleted"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   833
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   834
    readOnly ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   835
        exceptionBlock value:errorMessage.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   836
        ^ false
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   837
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   838
    (list isNil or:[lineNr > list size]) ifTrue:[^ false].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   839
    list removeIndex:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   840
    self contentsChanged.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   841
    ^ true
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   842
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   843
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   844
deleteLinesWithoutRedrawFrom:startLine to:endLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   845
    "delete lines - no redraw;
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   846
     answer true, if something was really deleted"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   847
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   848
    |lastLine|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   849
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   850
    readOnly ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   851
        exceptionBlock value:errorMessage.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   852
        ^ false
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   853
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   854
    (list isNil or:[startLine > list size]) ifTrue:[^ false].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   855
    (endLine > list size) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   856
        lastLine := list size
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   857
    ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   858
        lastLine := endLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   859
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   860
    list removeFromIndex:startLine toIndex:lastLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   861
    self contentsChanged.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   862
    ^ true
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   863
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   864
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   865
deleteLine:lineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   866
    "delete line"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   867
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   868
    |visLine w
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   869
     srcY "{ Class: SmallInteger }" |
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   870
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   871
    w := self widthForScrollBetween:lineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   872
                                and:(firstLineShown + nLinesShown).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   873
    (self deleteLineWithoutRedraw:lineNr) ifFalse:[^ self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   874
    visLine := self listLineToVisibleLine:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   875
    visLine notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   876
        srcY :=  margin + topMargin + (visLine * fontHeight).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   877
        self copyFrom:self x:textStartLeft y:srcY
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   878
                         toX:textStartLeft y:(srcY - fontHeight)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   879
                       width:w height:((nLinesShown - visLine) * fontHeight).
24
966098a893f8 *** empty log message ***
claus
parents: 19
diff changeset
   880
        self catchExpose.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   881
        self redrawVisibleLine:nFullLinesShown.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   882
        (nFullLinesShown ~~ nLinesShown) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   883
            self redrawVisibleLine:nLinesShown
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   884
        ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   885
        self waitForExpose
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   886
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   887
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   888
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   889
deleteCursorLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   890
    "delete the line where the cursor sits"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   891
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   892
    self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   893
         self deleteLine:cursorLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   894
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   895
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   896
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   897
removeTrailingBlankLines
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   898
    "remove all blank lines at end of text"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   899
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   900
    |lastLine "{ Class: SmallInteger }"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   901
     line finished|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   902
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   903
    lastLine := list size.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   904
    finished := false.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   905
    [finished] whileFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   906
        (lastLine <= 1) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   907
            finished := true
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   908
        ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   909
            line := list at:lastLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   910
            line notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   911
                line isBlank ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   912
                    list at:lastLine put:nil.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   913
                    line := nil
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   914
                ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   915
            ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   916
            line notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   917
                finished := true
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   918
            ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   919
                lastLine := lastLine - 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   920
            ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   921
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   922
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   923
    (lastLine ~~ list size) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   924
        list grow:lastLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   925
        self contentsChanged
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   926
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   927
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   928
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   929
deleteCharsAtLine:lineNr toCol:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   930
    "delete characters from start up to colNr in line lineNr"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   931
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   932
    |line lineSize newLine|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   933
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   934
    readOnly ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   935
        exceptionBlock value:errorMessage.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   936
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   937
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   938
    list isNil ifTrue: [^self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   939
    (list size < lineNr) ifTrue: [^ self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   940
    line := list at:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   941
    line isNil ifTrue: [^self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   942
    lineSize := line size.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   943
    (colNr >= lineSize) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   944
        newLine := nil
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   945
    ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   946
        newLine := line copyFrom:(colNr + 1) to:lineSize.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   947
        newLine isBlank ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   948
            newLine := nil
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   949
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   950
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   951
    list at:lineNr put:newLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   952
    modified := true.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   953
    contentsWasSaved := false.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   954
    self redrawLine:lineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   955
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   956
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   957
deleteCharsAtLine:lineNr fromCol:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   958
    "delete characters from colNr up to the end in line lineNr"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   959
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   960
    |line newLine|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   961
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   962
    readOnly ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   963
        exceptionBlock value:errorMessage.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   964
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   965
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   966
    list isNil ifTrue: [^self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   967
    (list size < lineNr) ifTrue: [^ self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   968
    line := list at:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   969
    line isNil ifTrue: [^self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   970
    (colNr > line size) ifTrue: [^ self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   971
    newLine := line copyFrom:1 to:(colNr - 1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   972
    newLine isBlank ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   973
        newLine := nil
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   974
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   975
    list at:lineNr put:newLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   976
    modified := true.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   977
    contentsWasSaved := false.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   978
    self redrawLine:lineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   979
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   980
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   981
deleteCharsAtLine:lineNr fromCol:startCol toCol:endCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   982
    "delete characters from startCol to endCol in line lineNr"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   983
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   984
    |line lineSize newLine|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   985
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   986
    readOnly ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   987
        exceptionBlock value:errorMessage.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   988
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   989
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   990
    list isNil ifTrue: [^self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   991
    (list size < lineNr) ifTrue: [^ self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   992
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   993
    line := list at:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   994
    line isNil ifTrue: [^self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   995
    lineSize := line size.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   996
    (startCol > lineSize) ifTrue: [^ self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   997
    (endCol == 0) ifTrue:[^ self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   998
    (endCol < startCol) ifTrue:[^ self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   999
    (startCol == endCol) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1000
        self deleteCharAtLine:lineNr col:startCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1001
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1002
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1003
    (endCol >= lineSize) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1004
        self deleteCharsAtLine:lineNr fromCol:startCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1005
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1006
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1007
    (startCol <= 1) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1008
        self deleteCharsAtLine:lineNr toCol:endCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1009
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1010
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1011
    newLine := (line copyFrom:1 to:(startCol - 1)) 
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1012
               , (line copyFrom:(endCol + 1) to:lineSize).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1013
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1014
    newLine isBlank ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1015
        newLine := nil
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1016
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1017
    list at:lineNr put:newLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1018
    modified := true.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1019
    contentsWasSaved := false.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1020
    self redrawLine:lineNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1021
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1022
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1023
deleteCharAtLine:lineNr col:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1024
    "delete single character at colNr in line lineNr"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1025
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1026
    |line lineSize newLine drawCharacterOnly|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1027
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1028
    readOnly ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1029
        exceptionBlock value:errorMessage.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1030
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1031
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1032
    list isNil ifTrue: [^self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1033
    (list size < lineNr) ifTrue: [^ self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1034
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1035
    line := list at:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1036
    line isNil ifTrue: [^self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1037
    lineSize := line size.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1038
    (colNr > lineSize) ifTrue: [^ self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1039
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1040
    drawCharacterOnly := false.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1041
    (colNr == lineSize) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1042
        newLine := line copyFrom:1 to:(lineSize - 1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1043
        fontIsFixedWidth ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1044
            drawCharacterOnly := true
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1045
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1046
    ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1047
        newLine := String new:(lineSize - 1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1048
        newLine replaceFrom:1 to:(colNr - 1)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1049
                       with:line startingAt:1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1050
        newLine replaceFrom:colNr to:(lineSize - 1)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1051
                       with:line startingAt:(colNr + 1)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1052
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1053
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1054
    newLine isBlank ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1055
        newLine := nil
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1056
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1057
    list at:lineNr put:newLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1058
    modified := true.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1059
    contentsWasSaved := false.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1060
    drawCharacterOnly ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1061
        self redrawLine:lineNr col:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1062
    ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1063
        self redrawLine:lineNr from:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1064
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1065
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1066
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1067
deleteCharBeforeCursor
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1068
    "delete single character to the left of cursor and move cursor to left"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1069
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1070
    |oldSize lineNrAboveCursor|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1071
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1072
    (cursorCol == 1) ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1073
         self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1074
             cursorCol := cursorCol - 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1075
             self deleteCharAtLine:cursorLine col:cursorCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1076
         ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1077
    ] ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1078
         (cursorLine == 1) ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1079
             oldSize := 0.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1080
             lineNrAboveCursor := cursorLine - 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1081
             list notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1082
                (list size >= lineNrAboveCursor) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1083
                    (list at:lineNrAboveCursor) notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1084
                        oldSize := (list at:lineNrAboveCursor) size
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1085
                    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1086
                ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1087
             ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1088
             self mergeLine:lineNrAboveCursor.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1089
             self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1090
                 cursorLine := lineNrAboveCursor.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1091
                 cursorCol := oldSize + 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1092
                 cursorVisibleLine := self listLineToVisibleLine:cursorLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1093
             ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1094
         ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1095
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1096
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1097
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1098
deleteCharAtCursor
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1099
    "delete single character under cursor"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1100
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1101
    self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1102
        self deleteCharAtLine:cursorLine col:cursorCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1103
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1104
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1105
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1106
deleteSelection
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1107
    "delete the selection"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1108
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1109
    |startLine startCol endLine endCol|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1110
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1111
    readOnly ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1112
        exceptionBlock value:errorMessage.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1113
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1114
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1115
    selectionStartLine notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1116
        startLine := selectionStartLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1117
        startCol := selectionStartCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1118
        endLine := selectionEndLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1119
        endCol := selectionEndCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1120
        self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1121
            self unselectWithoutRedraw.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1122
            self deleteFromLine:startLine col:startCol 
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1123
                         toLine:endLine col:endCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1124
            cursorCol := startCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1125
            cursorLine := startLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1126
            cursorVisibleLine := self listLineToVisibleLine:cursorLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1127
            self makeLineVisible:cursorLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1128
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1129
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1130
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1131
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1132
replaceSelectionBy:something
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1133
    "delete the selection (if any) and insert something, a character or string;
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1134
     leave cursor after insertion"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1135
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1136
    |sel|
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1137
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1138
    sel := self selection.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1139
    sel notNil ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1140
        lastString := sel.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1141
        self deleteSelection.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1142
        replacing := true.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1143
        lastReplacement := ''
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1144
    ].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1145
    (something isMemberOf:Character) ifTrue:[
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1146
        lastReplacement notNil ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1147
            lastReplacement := lastReplacement copyWith:something.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1148
        ].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1149
        self insertCharAtCursor:something
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1150
    ] ifFalse:[
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1151
        lastReplacement := something.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1152
        self insertStringAtCursor:something
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1153
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1154
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1155
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1156
!EditTextView methodsFor:'formatting'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1157
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1158
indent
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1159
    "indent selected line-range"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1160
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1161
    |start end|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1162
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1163
    start := selectionStartLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1164
    end := selectionEndLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1165
    (selectionEndCol == 0) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1166
        end := end - 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1167
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1168
    self unselect.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1169
    self indentFromLine:start toLine:end
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1170
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1171
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1172
indentFromLine:start toLine:end
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1173
    "indent a line-range - this is don by searching for the 
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1174
     last non-empty line before start, and change the indent
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1175
     of the line based on that indent."
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1176
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1177
    |leftStart lnr delta d line spaces|
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1178
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1179
    "find a line to base indent on..."
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1180
    leftStart := -1.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1181
    lnr := start.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1182
    [(leftStart == -1) and:[lnr ~~ 1]] whileTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1183
        lnr := lnr - 1.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1184
        leftStart := self leftIndentOfLine:lnr
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1185
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1186
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1187
    (leftStart == -1) ifTrue:[^ self].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1188
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1189
    delta := leftStart - (self leftIndentOfLine:start).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1190
    (delta == 0) ifTrue:[^ self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1191
    (delta > 0) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1192
        spaces := String new:delta
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1193
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1194
    start to:end do:[:lineNr |
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1195
        line := self listAt:lineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1196
        line notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1197
            line isBlank ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1198
                list at:lineNr put:nil
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1199
            ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1200
                (delta > 0) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1201
                    line := spaces , line
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1202
                ] ifFalse:[
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1203
                    "check if deletion is ok"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1204
                    d := delta negated + 1.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1205
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1206
                    line size > d ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1207
                        (line copyFrom:1 to:(d - 1)) withoutSeparators isEmpty ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1208
                            line := line copyFrom:d
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1209
                        ]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1210
                    ]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1211
                ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1212
                list at:lineNr put:line.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1213
                modified := true.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1214
                contentsWasSaved := false.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1215
            ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1216
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1217
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1218
    self redrawFromLine:start to:end
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1219
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1220
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1221
!EditTextView methodsFor:'cursor handling'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1222
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1223
makeCursorVisible
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1224
    "scroll to make cursor visible"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1225
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1226
    cursorLine notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1227
        self makeLineVisible:cursorLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1228
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1229
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1230
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1231
drawCursorCharacter
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1232
    "draw the cursor - helper for many below"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1233
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1234
    |oldFg oldBg|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1235
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1236
    oldFg := fgColor.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1237
    oldBg := bgColor.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1238
    fgColor := cursorFgColor.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1239
    bgColor := cursorBgColor.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1240
    super redrawVisibleLine:cursorVisibleLine col:cursorCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1241
    fgColor := oldFg.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1242
    bgColor := oldBg
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1243
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1244
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1245
drawCursor
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1246
    "draw the cursor if shown and cursor is visible"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1247
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1248
    shown ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1249
        cursorVisibleLine notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1250
            self drawCursorCharacter
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1251
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1252
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1253
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1254
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1255
undrawCursor
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1256
    "undraw the cursor"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1257
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1258
    cursorVisibleLine notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1259
        super redrawVisibleLine:cursorVisibleLine col:cursorCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1260
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1261
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1262
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1263
hideCursor
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1264
    "make cursor invisible if currently visible; return true if cursor
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1265
     was visible"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1266
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1267
    cursorShown ifTrue: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1268
        self undrawCursor.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1269
        cursorShown := false.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1270
        ^ true
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1271
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1272
    ^ false
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1273
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1274
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1275
showCursor
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1276
    "make cursor visible if currently invisible"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1277
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1278
    cursorShown ifFalse: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1279
        self drawCursor.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1280
        cursorShown := true
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1281
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1282
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1283
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1284
withCursorOffDo:aBlock
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1285
    "evaluate aBlock with cursor off"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1286
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1287
    |cShown|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1288
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1289
    shown ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1290
        aBlock value
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1291
    ] ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1292
        cShown := self hideCursor.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1293
        aBlock value.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1294
        cShown ifTrue:[self showCursor]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1295
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1296
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1297
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1298
cursorHome
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1299
    "scroll to top AND move cursor to first line of text"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1300
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1301
    self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1302
        self scrollToTop.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1303
        cursorCol := 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1304
        cursorVisibleLine := 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1305
        cursorLine := self visibleLineToAbsoluteLine:1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1306
        self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1307
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1308
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1309
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1310
cursorToBottom
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1311
    "move cursor to last line of text"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1312
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1313
    |newTop|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1314
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1315
    self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1316
        newTop := list size - nFullLinesShown.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1317
        (newTop < 1) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1318
            newTop := 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1319
        ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1320
        self scrollToLine:newTop.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1321
        cursorCol := 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1322
        cursorLine := list size.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1323
        cursorVisibleLine := self listLineToVisibleLine:cursorLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1324
        self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1325
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1326
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1327
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1328
cursorUp
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1329
    "move cursor up; scroll if at start of visible text"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1330
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1331
    (cursorLine == 1) ifFalse: [
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1332
        cursorLine isNil ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1333
            cursorLine := firstLineShown + nFullLinesShown - 1.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1334
        ].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1335
        self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1336
            (cursorVisibleLine == 1) ifTrue:[self scrollUp].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1337
            cursorLine := cursorLine - 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1338
            cursorVisibleLine := self listLineToVisibleLine:cursorLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1339
        ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1340
        self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1341
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1342
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1343
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1344
cursorDown
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1345
    "move cursor down; scroll if at end of visible text"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1346
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1347
    cursorVisibleLine notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1348
        self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1349
            (cursorVisibleLine >= nFullLinesShown) ifTrue:[self scrollDown].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1350
            cursorLine := cursorLine + 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1351
            cursorVisibleLine := self listLineToVisibleLine:cursorLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1352
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1353
    ] ifFalse:[
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1354
        cursorLine isNil ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1355
            cursorLine := firstLineShown
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1356
        ].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1357
        cursorLine := cursorLine + 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1358
        cursorVisibleLine := self listLineToVisibleLine:cursorLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1359
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1360
    self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1361
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1362
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1363
cursorLeft
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1364
    "move cursor to left"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1365
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1366
    (cursorCol == 1) ifFalse: [
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1367
        self withCursorOffDo:[cursorCol := cursorCol - 1]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1368
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1369
    self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1370
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1371
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1372
cursorRight
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1373
    "move cursor to right"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1374
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1375
    self withCursorOffDo:[cursorCol := cursorCol + 1].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1376
    self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1377
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1378
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1379
cursorToBeginOfLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1380
    "move cursor to start of current line"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1381
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1382
    self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1383
        cursorCol := 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1384
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1385
    self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1386
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1387
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1388
cursorToEndOfLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1389
    "move cursor to end of current line"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1390
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1391
    |line|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1392
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1393
    self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1394
        line := list at:cursorLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1395
        cursorCol := line size + 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1396
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1397
    self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1398
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1399
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1400
cursorTab
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1401
    "move cursor to next tabstop"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1402
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1403
    self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1404
        cursorCol := self nextTabAfter:cursorCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1405
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1406
    self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1407
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1408
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1409
cursorBacktab
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1410
    "move cursor to prev tabstop"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1411
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1412
    self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1413
        cursorCol := self prevTabBefore:cursorCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1414
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1415
    self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1416
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1417
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1418
cursorReturn
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1419
    "move cursor to start of next line; scroll if at end of visible text"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1420
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1421
    self checkForExistingLine:(cursorLine + 1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1422
    cursorVisibleLine notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1423
        nFullLinesShown notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1424
            (cursorVisibleLine >= nFullLinesShown) ifTrue:[self scrollDown]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1425
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1426
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1427
    self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1428
        cursorCol := 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1429
        cursorLine := cursorLine + 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1430
        cursorVisibleLine := self listLineToVisibleLine:cursorLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1431
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1432
    self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1433
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1434
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1435
cursorVisibleLine:visibleLineNr col:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1436
    "put cursor to visibleline/col"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1437
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1438
    self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1439
        cursorLine := self visibleLineToAbsoluteLine:visibleLineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1440
        cursorVisibleLine := visibleLineNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1441
        cursorCol := colNr.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1442
        (cursorCol < 1) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1443
            cursorCol := 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1444
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1445
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1446
    self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1447
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1448
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1449
cursorX:x y:y
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1450
    "put cursor to position next to x/y coordinate in view"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1451
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1452
    |line col|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1453
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1454
    line := self visibleLineOfY:y.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1455
    col := self colOfX:x inVisibleLine:line.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1456
    self cursorVisibleLine:line col:col.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1457
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1458
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1459
cursorLine:line col:col
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1460
    "this positions onto physical - not visible - line"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1461
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1462
    self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1463
        cursorLine := line.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1464
        cursorVisibleLine := self listLineToVisibleLine:line.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1465
        cursorCol := col.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1466
        (cursorCol < 1) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1467
            cursorCol := 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1468
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1469
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1470
    self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1471
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1472
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1473
cursorToTop
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1474
    "move cursor to absolute home"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1475
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1476
    self cursorLine:1 col:1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1477
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1478
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1479
gotoLine:aLineNumber
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1480
    self makeLineVisible:aLineNumber.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1481
    self cursorLine:aLineNumber col:1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1482
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1483
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1484
!EditTextView methodsFor:'undo & again'!
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1485
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1486
undo
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1487
    "currently not implemented"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1488
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1489
    undoAction notNil ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1490
        undoAction value
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1491
    ]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1492
!
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1493
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1494
again
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1495
    "repeat the last action (which was a cut or replace).
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1496
     If current selection is not last string, search forward to
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1497
     next occurence of it before repeating the last operation."
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1498
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1499
    |s l c sel|
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1500
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1501
    lastString notNil ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1502
        s := lastString asString.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1503
        "remove final cr"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1504
        s := s copyTo:(s size - 1).
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1505
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1506
        sel := self selection.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1507
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1508
        "if we are already there (after a find), ommit search"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1509
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1510
        (sel notNil and:[sel asString withoutSeparators = s]) ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1511
            undoAction := [self insertLines:lastString atLine:cursorLine col:cursorCol].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1512
            l := selectionStartLine "cursorLine". 
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1513
            c := selectionStartCol "cursorCol".
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1514
            self deleteSelection.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1515
            lastReplacement notNil ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1516
                self insertLines:lastReplacement asText withCr:false.
19
a696fb528758 *** empty log message ***
claus
parents: 15
diff changeset
  1517
                self selectFromLine:l col:c toLine:cursorLine col:(cursorCol - 1).
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1518
            ].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1519
            ^ true
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1520
        ].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1521
19
a696fb528758 *** empty log message ***
claus
parents: 15
diff changeset
  1522
        self searchForwardFor:s startingAtLine:cursorLine col:cursorCol ifFound:[:line :col |
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1523
            self selectFromLine:line col:col
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1524
                         toLine:line col:(col + s size - 1).
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1525
            self makeLineVisible:line.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1526
            undoAction := [self insertLines:lastString atLine:line col:col].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1527
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1528
            self deleteSelection.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1529
            lastReplacement notNil ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1530
                self insertLines:lastReplacement asText withCr:false.
19
a696fb528758 *** empty log message ***
claus
parents: 15
diff changeset
  1531
                self selectFromLine:line col:col toLine:cursorLine col:(cursorCol - 1).
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1532
            ].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1533
            ^ true
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1534
        ] else:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1535
            self showNotFound.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1536
            ^ false
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1537
        ]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1538
    ]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1539
!
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1540
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1541
multipleAgain
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1542
    "repeat the last action (which was a cut or replace) until search fails"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1543
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1544
    [self again] whileTrue:[]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1545
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1546
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1547
!EditTextView methodsFor:'cut & paste'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1548
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1549
cut
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1550
    "cut selection into copybuffer"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1551
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1552
    |line col|
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1553
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1554
    lastString := self selection.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1555
    lastString notNil ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1556
        line := selectionStartLine.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1557
        col := selectionStartCol.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1558
        undoAction := [self insertLines:lastString atLine:line col:col].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1559
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1560
        Smalltalk at:#CopyBuffer put:lastString.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1561
        self deleteSelection.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1562
        lastReplacement := nil
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1563
    ]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1564
!
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1565
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1566
paste:someText
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1567
    "paste someText at cursor"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1568
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1569
    |startLine startCol|
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1570
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1571
    someText notNil ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1572
        startLine := cursorLine.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1573
        startCol := cursorCol.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1574
        self insertLines:someText asText withCr:false.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1575
        self selectFromLine:startLine col:startCol
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1576
                     toLine:cursorLine col:(cursorCol - 1).
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1577
        typeOfSelection := #paste.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1578
        undoAction := [self cut].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1579
    ]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1580
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1581
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1582
paste
19
a696fb528758 *** empty log message ***
claus
parents: 15
diff changeset
  1583
    "paste copybuffer; if there is a selection, replace it.
a696fb528758 *** empty log message ***
claus
parents: 15
diff changeset
  1584
     otherwise paste at cursor position. Replace is not done
a696fb528758 *** empty log message ***
claus
parents: 15
diff changeset
  1585
     for selections originating by a paste, to allow multiple
a696fb528758 *** empty log message ***
claus
parents: 15
diff changeset
  1586
     paste."
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1587
19
a696fb528758 *** empty log message ***
claus
parents: 15
diff changeset
  1588
    (self selection notNil and:[typeOfSelection ~~ #paste]) ifTrue:[
15
0dbce35d3c69 *** empty log message ***
claus
parents: 13
diff changeset
  1589
        ^ self replace
0dbce35d3c69 *** empty log message ***
claus
parents: 13
diff changeset
  1590
    ].
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1591
    self paste:(Smalltalk at:#CopyBuffer).
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1592
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1593
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1594
replace
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1595
    "replace selection by copybuffer"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1596
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1597
    |selected selectedString replacement replacementString 
19
a696fb528758 *** empty log message ***
claus
parents: 15
diff changeset
  1598
     cutOffSpace addSpace|
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1599
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1600
    selected := self selection.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1601
    selected isNil ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1602
        ^ self paste
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1603
    ].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1604
    self deleteSelection.
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1605
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1606
    "take care, if we replace a selection without space by a word selected
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1607
     with one - in this case we usually do not want the space.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1608
     But, if we replace a word-selected selection by something without a
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1609
     space, we DO want the space added."
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1610
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1611
    cutOffSpace := false.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1612
    addSpace := false.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1613
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1614
    replacement := (Smalltalk at:#CopyBuffer) copy.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1615
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1616
    selected size == 1 ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1617
        selectedString := selected at:1.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1618
    ].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1619
    selectedString notNil ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1620
        ((selectedString startsWith:' ') or:[selectedString endsWith:' ']) ifFalse:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1621
           "selection has no space"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1622
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1623
            wordSelectStyle notNil ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1624
                cutOffSpace := true
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1625
            ]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1626
        ] ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1627
            addSpace := true
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1628
        ]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1629
    ].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1630
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1631
    replacement size == 1 ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1632
        replacementString := replacement at:1.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1633
        cutOffSpace ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1634
            (replacementString startsWith:' ') ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1635
                replacementString := replacementString withoutSpaces
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1636
            ].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1637
        ] ifFalse:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1638
            wordSelectStyle == #left ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1639
                "want a space at left"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1640
                (replacementString startsWith:' ') ifFalse:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1641
                    replacementString := replacementString withoutSpaces.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1642
                    replacementString := ' ' , replacementString
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1643
                ]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1644
            ].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1645
            wordSelectStyle == #right ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1646
                "want a space at right"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1647
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1648
                (replacementString endsWith:' ') ifFalse:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1649
                    replacementString := replacementString withoutSpaces.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1650
                    replacementString := replacementString , ' '
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1651
                ]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1652
            ].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1653
        ].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1654
        replacement at:1 put: replacementString.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1655
        self paste:replacement
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1656
    ] ifFalse:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1657
        self paste:(Smalltalk at:#CopyBuffer).
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1658
    ].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1659
    lastString := selectedString.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1660
    lastReplacement := Smalltalk at:#CopyBuffer
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1661
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1662
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1663
!EditTextView methodsFor:'selections'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1664
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1665
disableSelectionMenuEntries
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1666
    "disable relevant menu entries for a selection"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1667
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1668
    middleButtonMenu notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1669
        super disableSelectionMenuEntries.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1670
        middleButtonMenu disable:#cut.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1671
        middleButtonMenu disable:#replace.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1672
        middleButtonMenu disable:#indent
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1673
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1674
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1675
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1676
enableSelectionMenuEntries
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1677
    "enable relevant menu entries for a selection"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1678
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1679
    middleButtonMenu notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1680
        readOnly ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1681
            super disableSelectionMenuEntries.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1682
            middleButtonMenu disable:#cut.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1683
            middleButtonMenu disable:#replace.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1684
            middleButtonMenu disable:#indent.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1685
            middleButtonMenu disable:#paste.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1686
        ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1687
            super enableSelectionMenuEntries.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1688
            middleButtonMenu enable:#cut.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1689
            middleButtonMenu enable:#replace.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1690
            middleButtonMenu enable:#indent.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1691
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1692
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1693
! 
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1694
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1695
unselect
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1696
    "forget and unhilight selection - must take care of cursor here"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1697
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1698
    self withCursorOffDo:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1699
        super unselect
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1700
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1701
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1702
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1703
selectCursorLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1704
    "select cursorline up to cursor position"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1705
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1706
    self selectFromLine:cursorLine col:1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1707
                 toLine:cursorLine col:cursorCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1708
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1709
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1710
selectWordUnderCursor
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1711
    "select the word under the cursor"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1712
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1713
    self selectWordAtLine:cursorLine col:cursorCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1714
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1715
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1716
selectFromLine:startLine col:startCol toLine:endLine col:endCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1717
    "when a range is selected, position the cursor behind the selection
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1718
     for easier editing. Also typeOfSelection is nilled here."
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1719
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1720
    super selectFromLine:startLine col:startCol toLine:endLine col:endCol.
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1721
    self cursorLine:selectionEndLine col:(selectionEndCol + 1).
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1722
    typeOfSelection := nil
10
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
  1723
!
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
  1724
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
  1725
selectAll
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
  1726
    "select the whole text.
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
  1727
     redefined to send super selectFrom... since we dont want the
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
  1728
     cursor to be moved in this case."
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
  1729
13
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1730
    list isNil ifTrue:[
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1731
        self unselect
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1732
    ] ifFalse:[
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1733
        super selectFromLine:1 col:1 toLine:(list size + 1) col:0.
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1734
        typeOfSelection := nil
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1735
    ]
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1736
!
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1737
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1738
selectFromBeginning
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1739
    "select the text from the beginning to the current cursor position."
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1740
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1741
    list isNil ifTrue:[
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1742
        self unselect
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1743
    ] ifFalse:[
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1744
        super selectFromLine:1 col:1 toLine:cursorLine col:cursorCol.
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1745
        typeOfSelection := nil
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1746
    ]
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1747
!
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1748
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1749
selectUpToEnd
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1750
    "select the text from the current cursor position to the end."
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1751
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1752
    list isNil ifTrue:[
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1753
        self unselect
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1754
    ] ifFalse:[
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1755
        super selectFromLine:cursorLine col:cursorCol toLine:(list size + 1) col:0.
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1756
        typeOfSelection := nil
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  1757
    ]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1758
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1759
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1760
!EditTextView methodsFor:'scrolling'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1761
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1762
originWillChange
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1763
    "sent before scrolling - have to hide the cursor"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1764
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1765
    prevCursorState := cursorShown.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1766
    cursorShown ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1767
        self hideCursor
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1768
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1769
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1770
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1771
originChanged:delta
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1772
    "sent after scrolling - have to show the cursor if it was on before"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1773
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1774
    super originChanged:delta.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1775
    "
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1776
     should we move the cursor with the scroll - or leave it ?
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1777
    "
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1778
    cursorVisibleLine := self listLineToVisibleLine:cursorLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1779
    prevCursorState ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1780
        self showCursor
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1781
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1782
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1783
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1784
pageUp
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1785
    "page up - to keep cursor on same visible line, it has to be moved
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1786
     within the real text  "
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1787
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1788
    |prevCursorLine|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1789
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1790
    prevCursorLine := cursorVisibleLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1791
    super pageUp.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1792
    self cursorVisibleLine:prevCursorLine col:cursorCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1793
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1794
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1795
pageDown
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1796
    "page down - to keep cursor on same visible line, it has to be moved
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1797
     within the real text  "
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1798
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1799
    |prevCursorLine|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1800
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1801
    prevCursorLine := cursorVisibleLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1802
    super pageDown.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1803
    self cursorVisibleLine:prevCursorLine col:cursorCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1804
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1805
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1806
!EditTextView methodsFor:'searching'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1807
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1808
setSearchPattern
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1809
    "set the searchpattern from the selection if there is one, and position
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1810
     corsor to start of pattern"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1811
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1812
    |sel|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1813
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1814
    "if last operation was a replcae, set pattern to last
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1815
     original string (for search after again)"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1816
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1817
    (lastString notNil and:[lastReplacement notNil]) ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1818
        searchPattern := lastString asString withoutSeparators.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1819
        ^ self
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1820
    ].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1821
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1822
    sel := self selection.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1823
    sel notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1824
        self cursorLine:selectionStartLine col:selectionStartCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1825
        searchPattern := sel asString withoutSeparators
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1826
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1827
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1828
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1829
searchFwd:pattern
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1830
    "do the forward search"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1831
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1832
    self searchForwardFor:pattern startingAtLine:cursorLine col:cursorCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1833
    ifFound:[:line :col |
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1834
        self cursorLine:line col:col.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1835
        self selectFromLine:line col:col
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1836
                     toLine:line col:(col + pattern size - 1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1837
        self makeLineVisible:cursorLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1838
    ] else:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1839
        self showNotFound
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1840
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1841
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1842
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1843
searchBwd:pattern
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1844
    "do the backward search"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1845
24
966098a893f8 *** empty log message ***
claus
parents: 19
diff changeset
  1846
    self searchBackwardFor:pattern startingAtLine:(cursorLine min:list size) col:cursorCol
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1847
    ifFound:[:line :col |
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1848
        self cursorLine:line col:col.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1849
        self selectFromLine:line col:col
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1850
                     toLine:line col:(col + pattern size - 1).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1851
        self makeLineVisible:cursorLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1852
    ] else:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1853
        self showNotFound
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1854
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1855
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1856
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1857
searchForMatchingParenthesisFromLine:startLine col:startCol
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1858
                     ifFound:foundBlock 
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1859
                  ifNotFound:notFoundBlock
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1860
                     onError:failBlock
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1861
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1862
    "search for a matching parenthesis, parChar is one of '$( $[ ${ $) $] $}'. 
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1863
     Search for the corresponding character is done forward if its an opening,
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1864
     backwards if its a closing parenthesis.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1865
     Performs foundBlock with line/col as argument if found, notFoundBlock if not.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1866
     If there is a parth. nesting error, performs failBlock."
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1867
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1868
    |i direction lineString line col parChar charSet ignoreSet closingChar 
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1869
     ignoring delta endCol cc incSet decSet nesting maxLine|
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1870
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1871
    charSet := #( $( $) $[ $] ${ $} ).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1872
    ignoreSet := #( $' $" ).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1873
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1874
    parChar := self characterAtLine:startLine col:startCol.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1875
    i := charSet indexOf:parChar.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1876
    i == 0 ifTrue:[
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1877
        ^ failBlock value   "not a parenthesis"
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1878
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1879
    direction := #( fwd bwd fwd bwd fwd bwd) at:i.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1880
    closingChar := #( $) $( $] $[ $} ${ ) at:i.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1881
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1882
    col := startCol.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1883
    line := startLine.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1884
    direction == #fwd ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1885
        delta := 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1886
        incSet := #( $( $[ ${ ).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1887
        decSet := #( $) $] $} ).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1888
    ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1889
        delta := -1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1890
        incSet := #( $) $] $} ).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1891
        decSet := #( $( $[ ${ ).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1892
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1893
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1894
    nesting := 1.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1895
    ignoring := false.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1896
    lineString := list at:line.
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1897
    maxLine := list size.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1898
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1899
    col := col + delta.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1900
    [nesting ~~ 0] whileTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1901
        lineString notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1902
            direction == #fwd ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1903
                endCol := lineString size.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1904
            ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1905
                endCol := 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1906
            ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1907
            col to:endCol by:delta do:[:runCol |
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1908
                cc := lineString at:runCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1909
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1910
                (ignoreSet includes:cc) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1911
                    ignoring := ignoring not
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1912
                ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1913
                ignoring ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1914
                    (incSet includes:cc) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1915
                        nesting := nesting + 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1916
                    ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1917
                        (decSet includes:cc) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1918
                            nesting := nesting - 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1919
                        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1920
                    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1921
                ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1922
                nesting == 0 ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1923
                    "check if legal"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1924
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1925
                    cc == closingChar ifFalse:[
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1926
                        ^ failBlock value
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1927
                    ].
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1928
                    ^ foundBlock value:line value:runCol.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1929
                ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1930
            ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1931
        ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1932
        line := line + delta.
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1933
        (line < 1 or:[line > maxLine]) ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1934
            ^ failBlock value
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1935
        ].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1936
        lineString := list at:line.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1937
        direction == #fwd ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1938
            col := 1
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1939
        ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1940
            col := lineString size
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1941
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1942
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1943
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1944
    ^ notFoundBlock value
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1945
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1946
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1947
searchForMatchingParenthesis
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1948
    "search for a matching parenthesis starting at cursor position. 
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1949
     Search for the corresponding character is done forward if its an opening, 
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1950
     backwards if its a closing parenthesis.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1951
     Positions the cursor if found, peeps if not"
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1952
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1953
     self searchForMatchingParenthesisFromLine:cursorLine col:cursorCol
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1954
                               ifFound:[:line :col | self cursorLine:line col:col]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1955
                            ifNotFound:[self showNotFound]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1956
                               onError:[device beep]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1957
!
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1958
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1959
searchForAndSelectMatchingParenthesis
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1960
    "select characters enclosed by matching parenthesis if one is under cusor"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1961
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1962
    self searchForMatchingParenthesisFromLine:cursorLine col:cursorCol
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1963
                              ifFound:[:line :col | 
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1964
                                          self selectFromLine:cursorLine col:cursorCol
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1965
                                                       toLine:line col:col
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1966
                                      ]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1967
                           ifNotFound:[self showNotFound]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  1968
                              onError:[device beep]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1969
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1970
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1971
!EditTextView methodsFor:'redrawing'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1972
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1973
redrawCursorIfBetweenVisibleLine:startVisLine and:endVisLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1974
    "redraw the cursor, if it sits in a line range"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1975
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1976
    cursorShown ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1977
        cursorVisibleLine notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1978
            (cursorVisibleLine between:startVisLine and:endVisLine) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1979
                self drawCursorCharacter
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1980
            ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1981
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1982
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1983
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1984
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1985
redrawCursorIfInVisibleLine:visLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1986
    "redraw the cursor, if it sits in visible line"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1987
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1988
    cursorShown ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1989
        (visLine == cursorVisibleLine) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1990
            self drawCursorCharacter
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1991
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1992
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1993
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1994
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1995
redrawFromVisibleLine:startVisLine to:endVisLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1996
    "redraw a visible line range"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1997
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1998
    super redrawFromVisibleLine:startVisLine to:endVisLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  1999
    self redrawCursorIfBetweenVisibleLine:startVisLine and:endVisLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2000
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2001
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2002
redrawVisibleLine:visLine col:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2003
    "redraw the single character in visibleline at colNr"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2004
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2005
    cursorShown ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2006
        (visLine == cursorVisibleLine) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2007
            (colNr == cursorCol) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2008
                self drawCursorCharacter.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2009
                ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2010
            ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2011
        ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2012
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2013
    super redrawVisibleLine:visLine col:colNr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2014
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2015
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2016
redrawVisibleLine:visLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2017
    "redraw a visible line"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2018
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2019
    super redrawVisibleLine:visLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2020
    self redrawCursorIfInVisibleLine:visLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2021
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2022
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2023
redrawVisibleLine:visLine from:startCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2024
    "redraw a visible line from startCol to the end of line"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2025
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2026
    super redrawVisibleLine:visLine from:startCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2027
    self redrawCursorIfInVisibleLine:visLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2028
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2029
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2030
redrawVisibleLine:visLine from:startCol to:endCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2031
    "redraw a visible line from startCol to endCol"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2032
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2033
    super redrawVisibleLine:visLine from:startCol to:endCol.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2034
    self redrawCursorIfInVisibleLine:visLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2035
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2036
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2037
!EditTextView methodsFor:'event processing'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2038
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2039
sizeChanged:how
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2040
    "make certain, cursor is visible after the sizechange"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2041
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2042
    |cv|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2043
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2044
    cv := cursorVisibleLine.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2045
    super sizeChanged:how.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2046
    cv notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2047
        self makeLineVisible:cursorLine
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2048
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2049
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2050
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2051
keyPress:key x:x y:y
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2052
    "handle keyboard input"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2053
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2054
    (key isMemberOf:Character) ifTrue:[
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2055
        typeOfSelection == #paste ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2056
            "pasted selection will NOT be replaced by keystroke"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2057
            self unselect
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2058
        ].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2059
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2060
        "replace selection by what is typed in -
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2061
         if word was selected with a space, keep it"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2062
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2063
        (wordSelectStyle == #left) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2064
            self replaceSelectionBy:(' ' copyWith:key)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2065
        ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2066
            (wordSelectStyle == #right) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2067
                self replaceSelectionBy:(key asString , ' ').
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2068
                self cursorLeft
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2069
            ] ifFalse:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2070
                self replaceSelectionBy:key
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2071
            ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2072
        ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2073
        wordSelectStyle := nil.
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2074
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2075
        showMatchingParenthesis ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2076
            "emacs style parenthesis shower"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2077
            (#( $( $) $[ $] ${ $} ) includes:key) ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2078
            self searchForMatchingParenthesisFromLine:cursorLine col:(cursorCol - 1)
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2079
                               ifFound:[:line :col |
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2080
                                            |savLine savCol|
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2081
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2082
                                            savLine := cursorLine.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2083
                                            savCol := cursorCol.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2084
                                            self cursorLine:line col:col.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2085
                                            device synchronizeOutput.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2086
                                            OperatingSystem millisecondDelay:200.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2087
                                            self cursorLine:savLine col:savCol
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2088
                                       ]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2089
                            ifNotFound:[self showNotFound]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2090
                               onError:[device beep]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2091
            ].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2092
        ].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2093
        ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2094
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2095
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2096
    replacing := false.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2097
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2098
    "Fn      pastes a key-sequence,
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2099
     Cmd-Fn evaluates a key-sequence"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2100
    (#(F1 F2 F3 F4 F5 F6 F7 F8 F9) includes:key) ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2101
        device shiftDown ifFalse:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2102
            device metaDown ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2103
                (Smalltalk at:#FunctionKeySequences) notNil ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2104
                    Parser evaluate:((Smalltalk at:#FunctionKeySequences) at:key) asString
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2105
                           receiver:self
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2106
                          notifying:nil
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2107
                ]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2108
            ] ifFalse:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2109
                (Smalltalk at:#FunctionKeySequences) notNil ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2110
                    self paste:((Smalltalk at:#FunctionKeySequences) at:key) asText.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2111
                ]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2112
            ]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2113
        ]
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2114
    ].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2115
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2116
    ((key == #Paste) or:[key == #Insert]) ifTrue:[self paste. ^self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2117
    (key == #Cut) ifTrue:[self cut. ^self].
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2118
    (key == #Again) ifTrue:[self again. ^self].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2119
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2120
    (key == #Replace) ifTrue:[self replace. ^self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2121
    (key == #Cmdw) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2122
        self makeCursorVisible.
13
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  2123
        ^ self selectWordUnderCursor. 
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2124
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2125
13
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  2126
    (key == #SearchMatchingParent) ifTrue:[^ self searchForMatchingParenthesis.].
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  2127
    (key == #SelectMatchingParents) ifTrue:[^ self searchForAndSelectMatchingParenthesis.].
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  2128
    (key == #SelectToEnd) ifTrue:[^ self selectUpToEnd.].
1d005be9ad7e *** empty log message ***
claus
parents: 10
diff changeset
  2129
    (key == #SelectFromBeginning) ifTrue:[^ self selectFromBeginning.].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2130
10
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
  2131
" disabled - nobody liked it ...
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
  2132
  and if you like it, its better done in the keymap.
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
  2133
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2134
    (key == #Ctrlb) ifTrue:[self unselect. self cursorLeft. ^self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2135
    (key == #Ctrlf) ifTrue:[self unselect. self cursorRight. ^self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2136
    (key == #Ctrln) ifTrue:[self unselect. self cursorDown. ^self].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2137
    (key == #Ctrlp) ifTrue:[self unselect. self cursorUp. ^self].
10
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
  2138
"
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2139
10
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
  2140
    (key == #BeginOfLine) ifTrue:[self cursorToBeginOfLine. ^self].
a288b33897a5 *** empty log message ***
claus
parents: 7
diff changeset
  2141
    (key == #EndOfLine) ifTrue:[self cursorToEndOfLine. ^self].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2142
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2143
    (key == #CursorRight)     ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2144
        self unselect. self cursorRight. ^self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2145
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2146
    (key == #CursorLeft)      ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2147
        self unselect. self cursorLeft. ^self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2148
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2149
    (key == #CursorUp)        ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2150
        self unselect. self cursorUp. ^self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2151
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2152
    (key == #CursorDown)      ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2153
        self unselect. self cursorDown. ^self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2154
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2155
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2156
    (key == #Return)    ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2157
        device shiftDown ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2158
            self unselect. self cursorReturn. ^self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2159
        ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2160
        self unselect. 
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2161
        self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2162
        self insertCharAtCursor:(Character cr). 
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2163
        ^self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2164
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2165
    (key == #Tab) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2166
        device shiftDown ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2167
            self unselect. self cursorBacktab. ^self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2168
        ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2169
        self unselect. self cursorTab. ^self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2170
    ].
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2171
    (key == #BackSpace) ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2172
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2173
" old version just did unselect here "
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2174
"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2175
        self unselect. 
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2176
"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2177
" new version deletes selection if any "
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2178
        selectionStartLine notNil ifTrue:[
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2179
            Smalltalk at:#CopyBuffer put:(self selection).
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2180
            self deleteSelection. ^ self
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2181
        ].
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2182
        self makeCursorVisible.
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2183
        self deleteCharBeforeCursor. ^self
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2184
    ].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2185
    (key == #Delete)    ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2186
        selectionStartLine notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2187
            Smalltalk at:#CopyBuffer put:(self selection).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2188
            self deleteSelection. ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2189
        ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2190
        self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2191
        self deleteCharBeforeCursor. ^self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2192
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2193
    (key == #Home)      ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2194
        self unselect. self cursorHome. ^self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2195
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2196
    (key == #End)       ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2197
        self unselect. self cursorToBottom. ^self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2198
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2199
    (key == #Escape)    ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2200
        self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2201
        self unselect. self selectCursorLine. ^ self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2202
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2203
    (key == #DeleteLine)    ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2204
        self makeCursorVisible.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2205
        self unselect. self deleteCursorLine. ^self
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2206
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2207
    super keyPress:key x:x y:y
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2208
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2209
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2210
buttonPress:button x:x y:y
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2211
    "hide the cursor when button is activated"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2212
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2213
    (button == 1) ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2214
        self hideCursor
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2215
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2216
    super buttonPress:button x:x y:y
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2217
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2218
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2219
buttonRelease:button x:x y:y
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2220
    "move the cursor to the click-position of previous button press"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2221
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2222
    (button == 1) ifTrue:[
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2223
        lastString := nil. "new selection invalidates remembered string"
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
  2224
        typeOfSelection := nil. 
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2225
        selectionStartLine isNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2226
            clickCol notNil ifTrue:[
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2227
                self cursorLine:clickLine col:clickCol
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2228
            ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2229
        ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2230
        self showCursor
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2231
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2232
    super buttonRelease:button x:x y:y
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
  2233
! !