TextCollector.st
author Claus Gittinger <cg@exept.de>
Tue, 05 Dec 1995 20:12:25 +0100
changeset 238 a81e517187e4
parent 174 d80a6cc3f9b2
child 308 b216a5efa2c8
permissions -rw-r--r--
examples
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
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
     3
	      All Rights Reserved
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     4
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    11
"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    12
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    13
EditTextView subclass:#TextCollector
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:'entryStream lineLimit destroyAction
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
    15
			      outstandingLines outstandingLine
119
claus
parents: 110
diff changeset
    16
			      flushBlock flushPending inFlush collecting timeDelay access'
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    17
       classVariableNames:''
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    18
       poolDictionaries:''
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    19
       category:'Views-Text'
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    20
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    21
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
    22
!TextCollector class methodsFor:'documentation'!
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
    23
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    24
copyright
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    25
"
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    26
 COPYRIGHT (c) 1989 by Claus Gittinger
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
    27
	      All Rights Reserved
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    28
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    29
 This software is furnished under a license and may be used
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    30
 only in accordance with the terms of that license and with the
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    31
 inclusion of the above copyright notice.   This software may not
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    32
 be provided or otherwise made available to, or used by, any
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    33
 other person.  No title to or ownership of the software is
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    34
 hereby transferred.
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    35
"
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    36
!
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    37
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    38
version
174
d80a6cc3f9b2 uff - version methods changed to return stings
Claus Gittinger <cg@exept.de>
parents: 155
diff changeset
    39
    ^ '$Header: /cvs/stx/stx/libwidg/TextCollector.st,v 1.24 1995-11-11 16:23:12 cg Exp $'
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    40
!
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    41
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
    42
documentation
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
    43
"
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    44
    a view for editable text, which also understands some stream messages.
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    45
    Instances of this view can take the place of a stream and display the 
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    46
    received text.
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    47
    Its main use in the system is the Transcript, but it can also be used for
110
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
    48
    things like trace-windows, errorLogs etc.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    49
60
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
    50
    If collecting is turned on, a textcollector will not immediately display 
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    51
    entered text, but wait for some short time (timeDelay) and collect incoming 
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    52
    data - finally updating the whole chunk in one piece. 
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    53
    This helps slow display devices, which would otherwise scroll a lot. 
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    54
    (on fast displays this is less of a problem).
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
    55
60
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
    56
    The total number of lines kept is controlled by lineLimit, if more lines 
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
    57
    than this limit are added at the bottom, the textcollector will forget lines 
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
    58
    at the top. 
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
    59
    You can set linelimit to nil (i.e. no limit), but you may need a lot 
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    60
    of memory then ...
77
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
    61
110
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
    62
    StyleSheet paramters (transcript only):
77
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
    63
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
    64
	transcriptForegroundColor       defaults to textForegroundColor
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
    65
	transcriptBackgroundColor'      defaults to textBackgroundColor.
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
    66
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
    67
	transcriptCursorForegroundColor
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
    68
	transcriptCursorBackgroundColor
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
    69
"
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
    70
! !
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    71
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    72
!TextCollector class methodsFor:'defaults'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    73
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    74
defaultLineLimit
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
    75
    "the number of lines remembered by default"
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
    76
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
    77
    ^ 600
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
    78
! 
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
    79
60
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
    80
defaultTranscriptSize
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
    81
    "the number of cols/lines by which the Transcript should come up"
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
    82
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
    83
    ^ 70@11
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
    84
! 
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
    85
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
    86
defaultTimeDelay
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
    87
    "the time in seconds to wait & collect by default"
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
    88
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    89
    ^ 0.3 
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    90
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    91
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    92
!TextCollector class methodsFor:'instance creation'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    93
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    94
newTranscript
110
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
    95
    "create and open a new transcript."
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
    96
130
claus
parents: 119
diff changeset
    97
    |topView transcript f v lines cols|
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
    98
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
    99
    topView := StandardSystemView label:'Transcript' minExtent:(100 @ 100).
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   100
60
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   101
    v := HVScrollableView for:self miniScrollerH:true miniScrollerV:false in:topView.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   102
    v origin:(0.0 @ 0.0) corner:(1.0 @ 1.0).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   103
    transcript := v scrolledView.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   104
    "transcript partialLines:false."
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   105
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   106
    f := transcript font.
60
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   107
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   108
    "
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   109
     should add the height of the frame & scrollbars to be exact ...
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   110
    "
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   111
    cols := self defaultTranscriptSize x.
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   112
    lines := self defaultTranscriptSize y.
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   113
    topView extent:(((f widthOf:'x') * cols) @ (f height * lines)).
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   114
110
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   115
    transcript beTranscript.
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   116
80
5a878a1eebf2 *** empty log message ***
claus
parents: 77
diff changeset
   117
    "
5a878a1eebf2 *** empty log message ***
claus
parents: 77
diff changeset
   118
     run it at a slightly higher prio, to allow for
5a878a1eebf2 *** empty log message ***
claus
parents: 77
diff changeset
   119
     delayed buffered updates to be performed
5a878a1eebf2 *** empty log message ***
claus
parents: 77
diff changeset
   120
    "
5a878a1eebf2 *** empty log message ***
claus
parents: 77
diff changeset
   121
    topView openWithPriority:(Processor userSchedulingPriority + 1).
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   122
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   123
    ^ transcript
110
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   124
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   125
    "
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   126
     TextCollector newTranscript
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   127
    "
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   128
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   129
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   130
!TextCollector methodsFor:'initialize / release'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   131
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   132
initialize
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   133
    super initialize.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   134
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   135
    outstandingLines := OrderedCollection new.
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   136
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   137
    flushBlock := [self endEntry].
119
claus
parents: 110
diff changeset
   138
    flushPending := inFlush := false.
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   139
    collecting := true.
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   140
    timeDelay := self class defaultTimeDelay.
119
claus
parents: 110
diff changeset
   141
    access := RecursionLock new. "/ Semaphore forMutualExclusion.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   142
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   143
    lineLimit := self class defaultLineLimit.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   144
    entryStream := ActorStream new.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   145
    entryStream nextPutBlock:[:something | self nextPut:something].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   146
    entryStream nextPutAllBlock:[:something | self nextPutAll:something]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   147
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   148
97
cbf495fe3b64 *** empty log message ***
claus
parents: 80
diff changeset
   149
editMenu
cbf495fe3b64 *** empty log message ***
claus
parents: 80
diff changeset
   150
    |m idx|
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   151
97
cbf495fe3b64 *** empty log message ***
claus
parents: 80
diff changeset
   152
    m := super editMenu.
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   153
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   154
    "
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   155
     textcollectors do not support #accept
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   156
     remove it from the menu (and the preceeding separating line)
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   157
    "
97
cbf495fe3b64 *** empty log message ***
claus
parents: 80
diff changeset
   158
    idx := m indexOf:#accept.
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   159
    idx ~~ 0 ifTrue:[
97
cbf495fe3b64 *** empty log message ***
claus
parents: 80
diff changeset
   160
	m remove:idx.
cbf495fe3b64 *** empty log message ***
claus
parents: 80
diff changeset
   161
	(m labels at:(idx - 1)) = '-' ifTrue:[
cbf495fe3b64 *** empty log message ***
claus
parents: 80
diff changeset
   162
	    m remove:idx - 1
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   163
	].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   164
    ].
97
cbf495fe3b64 *** empty log message ***
claus
parents: 80
diff changeset
   165
    ^ m
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   166
!
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   167
36
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   168
reinitialize
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   169
    "recreate access-semaphore; image could have been save (theoretically)
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   170
     with the semaphore locked - int this case, we had a deadlock"
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   171
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   172
    flushPending := false.
119
claus
parents: 110
diff changeset
   173
    access := RecursionLock new. "/ Semaphore forMutualExclusion.
36
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   174
    super reinitialize.
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   175
!
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   176
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   177
mapped
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   178
    "view became visible - show collected lines (if any)"
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   179
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   180
    super mapped.
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   181
    self endEntry
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   182
!
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   183
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   184
destroy
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   185
    destroyAction notNil ifTrue:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   186
	destroyAction value
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   187
    ].
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   188
    Processor removeTimedBlock:flushBlock.
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   189
    flushBlock := nil.
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   190
    outstandingLines := OrderedCollection new.
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   191
    outstandingLine := ''.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   192
    super destroy
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   193
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   194
110
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   195
!TextCollector methodsFor:'transcript specials'!
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   196
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   197
beTranscript
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   198
    |fg bg cFg cBg|
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   199
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   200
    Smalltalk at:#Transcript put:self.
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   201
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   202
    "
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   203
     fancy feature: whenever Transcript is closed, reset to StdError
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   204
    "
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   205
    self destroyAction:[Smalltalk at:#Transcript put:Stderr].
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   206
130
claus
parents: 119
diff changeset
   207
    fg := styleSheet colorAt:'transcriptForegroundColor' default:self foregroundColor.
claus
parents: 119
diff changeset
   208
    bg := styleSheet colorAt:'transcriptBackgroundColor' default:self backgroundColor.
110
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   209
    self foregroundColor:fg backgroundColor:bg.
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   210
    self viewBackground:bg.
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   211
130
claus
parents: 119
diff changeset
   212
    cFg := styleSheet colorAt:'transcriptCursorForegroundColor' default:bg.
claus
parents: 119
diff changeset
   213
    cBg := styleSheet colorAt:'transcriptCursorBackgroundColor' default:fg.
110
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   214
    self cursorForegroundColor:cFg backgroundColor:cBg. 
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   215
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   216
    "self lineLimit:1000. " "or whatever you think makes sense"
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   217
! !
eb59f6e31e84 *** empty log message ***
claus
parents: 97
diff changeset
   218
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   219
!TextCollector methodsFor:'accessing'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   220
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   221
collect:aBoolean
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   222
    "turn on/off collecting - if on, do not output immediately
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   223
     but collect text and output en-bloque after some time delta"
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   224
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   225
    collecting := aBoolean
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   226
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   227
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   228
lineLimit:aNumber
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   229
    "define the number of text-lines I am supposed to hold"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   230
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   231
    lineLimit := aNumber
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   232
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   233
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   234
destroyAction:aBlock
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   235
    "define the action to be performed when I get destroyed.
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   236
     This is a special feature, to allow resetting Transcript to Stderr
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   237
     when closed. (see TextCollectorclass>>newTranscript)"
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   238
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   239
    destroyAction := aBlock
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   240
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   241
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   242
endEntry
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   243
    "flush collected output"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   244
36
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   245
    |nLines lines|
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   246
133
claus
parents: 131
diff changeset
   247
    shown ifFalse:[
claus
parents: 131
diff changeset
   248
	flushPending ifFalse:[
claus
parents: 131
diff changeset
   249
	    self installDelayedUpdate.
claus
parents: 131
diff changeset
   250
	].
claus
parents: 131
diff changeset
   251
	^ self
claus
parents: 131
diff changeset
   252
    ].
119
claus
parents: 110
diff changeset
   253
    inFlush ifTrue:[^ self].
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   254
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   255
    Processor removeTimedBlock:flushBlock.
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   256
    flushPending ifFalse:[^ self].
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   257
52
e69fade0aa8e mutual exclusion when updating contents
claus
parents: 36
diff changeset
   258
    access critical:[
119
claus
parents: 110
diff changeset
   259
	inFlush := true.
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   260
	flushPending := false.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   261
	outstandingLines size ~~ 0 ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   262
	    "insert the bunch of lines - if any"
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   263
	    lines := outstandingLines.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   264
	    outstandingLines := OrderedCollection new.
36
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   265
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   266
	    nLines := lines size.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   267
	    (nLines ~~ 0) ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   268
		self insertLines:lines withCr:true.
131
claus
parents: 130
diff changeset
   269
		self cursorToEnd.
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   270
		self withCursorOffDo:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   271
		    (cursorLine >= (firstLineShown + nFullLinesShown)) ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   272
			self scrollDown:nLines
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   273
		    ]
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   274
		].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   275
	    ].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   276
	].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   277
	"and the last partial line - if any"
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   278
	outstandingLine notNil ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   279
	    self insertStringAtCursor:outstandingLine.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   280
	    outstandingLine := ''.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   281
	].
119
claus
parents: 110
diff changeset
   282
	self checkLineLimit.
claus
parents: 110
diff changeset
   283
	inFlush := false.
155
claus
parents: 145
diff changeset
   284
	device flush.
119
claus
parents: 110
diff changeset
   285
    ].
claus
parents: 110
diff changeset
   286
    flushPending ifTrue:[
claus
parents: 110
diff changeset
   287
	flushPending := false.
claus
parents: 110
diff changeset
   288
	self installDelayedUpdate
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   289
    ]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   290
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   291
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   292
!TextCollector methodsFor:'private'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   293
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   294
checkLineLimit
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   295
    "this method checks if the text has become too large (> lineLimit)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   296
     and cuts off some lines at the top if so; it must be called whenever lines
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   297
     have been added to the bottom"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   298
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   299
    |nDel|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   300
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   301
    lineLimit notNil ifTrue:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   302
	(cursorLine > lineLimit) ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   303
	    nDel := list size - lineLimit.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   304
	    list removeFromIndex:1 toIndex:nDel.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   305
	    cursorLine := cursorLine - nDel.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   306
	    firstLineShown := firstLineShown - nDel.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   307
	    (firstLineShown < 1) ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   308
		cursorLine := cursorLine - firstLineShown + 1.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   309
		firstLineShown := 1
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   310
	    ].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   311
	    self contentsChanged
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   312
	]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   313
    ]
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   314
!
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   315
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   316
installDelayedUpdate
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   317
    "arrange for collecting input for some time,
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   318
     and output all buffered strings at once after a while.
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   319
     This makes output to the transcript much faster on systems
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   320
     with poor scrolling performance (i.e. dump vga cards ...)."
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   321
131
claus
parents: 130
diff changeset
   322
    |p|
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   323
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   324
    flushPending ifFalse:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   325
	flushPending := true.
119
claus
parents: 110
diff changeset
   326
	inFlush ifFalse:[
claus
parents: 110
diff changeset
   327
	    "
claus
parents: 110
diff changeset
   328
	     we could run under a process, which dies in the meantime;
claus
parents: 110
diff changeset
   329
	     therefore, we have to arrange for the transcript process to
claus
parents: 110
diff changeset
   330
	     be interrupted and do the update.
claus
parents: 110
diff changeset
   331
	    "
131
claus
parents: 130
diff changeset
   332
	    windowGroup isNil ifTrue:[
119
claus
parents: 110
diff changeset
   333
		p := Processor activeProcess
claus
parents: 110
diff changeset
   334
	    ] ifFalse:[
131
claus
parents: 130
diff changeset
   335
		p := windowGroup process
119
claus
parents: 110
diff changeset
   336
	    ].
claus
parents: 110
diff changeset
   337
	    Processor addTimedBlock:flushBlock for:p afterSeconds:timeDelay.
claus
parents: 110
diff changeset
   338
	]
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   339
    ]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   340
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   341
135
claus
parents: 133
diff changeset
   342
!TextCollector methodsFor:'events'!
claus
parents: 133
diff changeset
   343
claus
parents: 133
diff changeset
   344
exposeX:x y:y width:w height:h
claus
parents: 133
diff changeset
   345
    "flush buffered text when exposed"
claus
parents: 133
diff changeset
   346
claus
parents: 133
diff changeset
   347
    super exposeX:x y:y width:w height:h.
claus
parents: 133
diff changeset
   348
    self endEntry
claus
parents: 133
diff changeset
   349
! !
claus
parents: 133
diff changeset
   350
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   351
!TextCollector methodsFor:'stream messages'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   352
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   353
lineLength
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   354
    ^ width // (font width)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   355
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   356
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   357
nextPut:something
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   358
    "this allows TextCollectors to be used Stream-wise"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   359
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   360
    flushPending ifTrue:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   361
	self endEntry
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   362
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   363
    (something isMemberOf:Character) ifTrue:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   364
	((something == Character cr) or:[something == Character nl]) ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   365
	    ^ self cr
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   366
	].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   367
	self insertCharAtCursor:something
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   368
    ] ifFalse:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   369
	self insertStringAtCursor:(something printString).
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   370
	self checkLineLimit
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   371
    ].
155
claus
parents: 145
diff changeset
   372
    device flush
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   373
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   374
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   375
nextPutAll:something
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   376
    "this allows TextCollectors to be used Stream-wise"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   377
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   378
    ^ self nextPut:something
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   379
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   380
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   381
cr
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   382
    "output a carriage return, finishing the current line"
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   383
131
claus
parents: 130
diff changeset
   384
    access critical:[
claus
parents: 130
diff changeset
   385
	collecting ifTrue:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   386
	    outstandingLine notNil ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   387
		outstandingLines add:outstandingLine.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   388
	    ].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   389
	    outstandingLine := ''.
131
claus
parents: 130
diff changeset
   390
claus
parents: 130
diff changeset
   391
	    flushPending ifFalse:[
claus
parents: 130
diff changeset
   392
		self installDelayedUpdate
claus
parents: 130
diff changeset
   393
	    ]
claus
parents: 130
diff changeset
   394
	] ifFalse:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   395
	    self cursorReturn.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   396
	    self checkLineLimit.
131
claus
parents: 130
diff changeset
   397
	    self cursorToEnd.
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   398
	].
0
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
show:anObject
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   403
    "insert the argument aString at current cursor position"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   404
77
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   405
    |aString|
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   406
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   407
    aString := anObject printString.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   408
    collecting ifTrue:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   409
	access critical:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   410
	    outstandingLine notNil ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   411
		outstandingLine := outstandingLine , aString
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   412
	    ] ifFalse:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   413
		outstandingLine := aString
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   414
	    ].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   415
	].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   416
	flushPending ifFalse:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   417
	    self installDelayedUpdate
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   418
	]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   419
    ] ifFalse:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   420
	access critical:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   421
	    self nextPut:aString.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   422
	].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   423
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   424
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   425
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   426
showCr:aString
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   427
    "insert the argument aString followed by a newline
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   428
     at current cursor position"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   429
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   430
    self show:aString.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   431
    self cr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   432
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   433
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   434
doesNotUnderstand:aMessage
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   435
    "this is funny: all message we do not understand, are passed
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   436
     on to the stream which will send the characters via nextPut:
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   437
     This way, we understand all Stream messages - great isn't it !!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   438
    "
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   439
     ^ entryStream perform:(aMessage selector) withArguments:(aMessage arguments)
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   440
! !