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