TextColl.st
author claus
Mon, 06 Feb 1995 01:53:30 +0100
changeset 77 565b052f5277
parent 63 f4eaf04d1eaf
child 80 5a878a1eebf2
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
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
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
    16
			      flushBlock flushPending 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
77
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
    26
$Header: /cvs/stx/stx/libwidg/Attic/TextColl.st,v 1.13 1995-02-06 00:53:22 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
"
77
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
    47
$Header: /cvs/stx/stx/libwidg/Attic/TextColl.st,v 1.13 1995-02-06 00:53:22 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
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
    57
    things like trace-windows 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
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
    71
    StyleSheet paramters:
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
60
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   104
    |topView transcript f v fg bg cFg cBg lines cols|
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   105
7
15a9291b9bd0 *** empty log message ***
claus
parents: 5
diff changeset
   106
    topView := StandardSystemView label:'Transcript' minExtent:(100 @ 100).
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   107
60
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   108
    v := HVScrollableView for:self miniScrollerH:true miniScrollerV:false in:topView.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   109
    v origin:(0.0 @ 0.0) corner:(1.0 @ 1.0).
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   110
    transcript := v scrolledView.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   111
    "transcript partialLines:false."
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   112
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   113
    f := transcript font.
60
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   114
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   115
    "
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   116
     should add the height of the frame & scrollbars to be exact ...
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   117
    "
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   118
    cols := self defaultTranscriptSize x.
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   119
    lines := self defaultTranscriptSize y.
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   120
    topView extent:(((f widthOf:'x') * cols) @ (f height * lines)).
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   121
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   122
    Smalltalk at:#Transcript put:transcript.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   123
60
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   124
    "
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   125
     fancy feature: whenever Transcript is closed, reset to StdError
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   126
    "
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   127
    transcript destroyAction:[Smalltalk at:#Transcript put:Stderr].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   128
60
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   129
    fg := StyleSheet colorAt:'transcriptForegroundColor' default:transcript foregroundColor.
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   130
    bg := StyleSheet colorAt:'transcriptBackgroundColor' default:transcript backgroundColor.
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   131
    transcript foregroundColor:fg backgroundColor:bg.
77
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   132
    transcript viewBackground:bg.
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   133
60
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   134
    cFg := StyleSheet colorAt:'transcriptCursorForegroundColor' default:bg.
f3c738c24ce6 mostly style
claus
parents: 59
diff changeset
   135
    cBg := StyleSheet colorAt:'transcriptCursorBackgroundColor' default:fg.
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   136
    transcript cursorForegroundColor:cFg backgroundColor:cBg. 
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   137
22
ac872628ef2d *** empty log message ***
claus
parents: 15
diff changeset
   138
    topView open.
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   139
    "transcript lineLimit:1000. " "or whatever you think makes sense"
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   140
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   141
    ^ transcript
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   142
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   143
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   144
!TextCollector methodsFor:'initialize / release'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   145
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   146
initialize
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   147
    super initialize.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   148
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   149
    outstandingLines := OrderedCollection new.
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   150
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   151
    flushBlock := [self endEntry].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   152
    flushPending := false.
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   153
    collecting := true.
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   154
    timeDelay := self class defaultTimeDelay.
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   155
    access := Semaphore forMutualExclusion.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   156
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   157
    lineLimit := self class defaultLineLimit.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   158
    entryStream := ActorStream new.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   159
    entryStream nextPutBlock:[:something | self nextPut:something].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   160
    entryStream nextPutAllBlock:[:something | self nextPutAll:something]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   161
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   162
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   163
initializeMiddleButtonMenu
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   164
    |idx|
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   165
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   166
    super initializeMiddleButtonMenu.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   167
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   168
    "
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   169
     textcollectors do not support #accept
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   170
     remove it from the menu (and the preceeding separating line)
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   171
    "
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   172
    idx := middleButtonMenu indexOf:#accept.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   173
    idx ~~ 0 ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   174
	middleButtonMenu remove:idx.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   175
	(middleButtonMenu labels at:(idx - 1)) = '-' ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   176
	    middleButtonMenu remove:idx - 1
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   177
	].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   178
    ].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   179
!
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   180
36
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   181
reinitialize
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   182
    "recreate access-semaphore; image could have been save (theoretically)
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   183
     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
   184
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   185
    flushPending := false.
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   186
    access := Semaphore forMutualExclusion.
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   187
    super reinitialize.
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   188
!
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   189
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   190
mapped
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   191
    "view became visible - show collected lines (if any)"
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   192
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   193
    super mapped.
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   194
    self endEntry
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   195
!
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   196
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   197
destroy
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   198
    destroyAction notNil ifTrue:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   199
	destroyAction value
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   200
    ].
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   201
    Processor removeTimedBlock:flushBlock.
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   202
    flushBlock := nil.
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   203
    outstandingLines := OrderedCollection new.
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   204
    outstandingLine := ''.
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   205
    super destroy
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   206
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   207
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   208
!TextCollector methodsFor:'accessing'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   209
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   210
collect:aBoolean
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   211
    "turn on/off collecting - if on, do not output immediately
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   212
     but collect text and output en-bloque after some time delta"
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   213
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   214
    collecting := aBoolean
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   215
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   216
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   217
lineLimit:aNumber
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   218
    "define the number of text-lines I am supposed to hold"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   219
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   220
    lineLimit := aNumber
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   221
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   222
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   223
destroyAction:aBlock
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   224
    "define the action to be performed when I get destroyed.
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   225
     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
   226
     when closed. (see TextCollectorclass>>newTranscript)"
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   227
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   228
    destroyAction := aBlock
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   229
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   230
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   231
endEntry
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   232
    "flush collected output"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   233
36
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   234
    |nLines lines|
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   235
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   236
    shown ifFalse:[^ self].
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   237
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   238
    Processor removeTimedBlock:flushBlock.
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   239
    flushPending ifFalse:[^ self].
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   240
77
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   241
    access wouldBlock ifTrue:[
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   242
	Processor activeProcessIsSystemProcess ifTrue:[
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   243
	    "/ Stderr nextPutAll:'Blocking in Transcript avoided: ' , aString.
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   244
	    ^ self
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   245
	]
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   246
    ].
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   247
52
e69fade0aa8e mutual exclusion when updating contents
claus
parents: 36
diff changeset
   248
    access critical:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   249
	flushPending := false.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   250
	outstandingLines size ~~ 0 ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   251
	    "insert the bunch of lines - if any"
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   252
	    lines := outstandingLines.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   253
	    outstandingLines := OrderedCollection new.
36
641fe12489b2 prevent deadlock on access-semaphore in image-restart
claus
parents: 34
diff changeset
   254
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   255
	    nLines := lines size.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   256
	    (nLines ~~ 0) ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   257
		self insertLines:lines withCr:true.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   258
		self withCursorOffDo:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   259
		    (cursorLine >= (firstLineShown + nFullLinesShown)) ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   260
			self scrollDown:nLines
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   261
		    ]
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   262
		].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   263
	    ].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   264
	].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   265
	"and the last partial line - if any"
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   266
	outstandingLine notNil ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   267
	    self insertStringAtCursor:outstandingLine.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   268
	    outstandingLine := ''.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   269
	].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   270
	self checkLineLimit
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   271
    ]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   272
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   273
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   274
!TextCollector methodsFor:'private'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   275
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   276
checkLineLimit
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   277
    "this method checks if the text has become too large (> lineLimit)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   278
     and cuts off some lines at the top if so; it must be called whenever lines
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   279
     have been added to the bottom"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   280
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   281
    |nDel|
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   282
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   283
    lineLimit notNil ifTrue:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   284
	(cursorLine > lineLimit) ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   285
	    nDel := list size - lineLimit.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   286
	    list removeFromIndex:1 toIndex:nDel.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   287
	    cursorLine := cursorLine - nDel.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   288
	    firstLineShown := firstLineShown - nDel.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   289
	    (firstLineShown < 1) ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   290
		cursorLine := cursorLine - firstLineShown + 1.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   291
		firstLineShown := 1
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   292
	    ].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   293
	    self contentsChanged
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   294
	]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   295
    ]
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   296
!
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   297
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   298
installDelayedUpdate
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   299
    "arrange for collecting input for some time,
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   300
     and output all buffered strings at once after a while.
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   301
     This makes output to the transcript much faster on systems
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   302
     with poor scrolling performance (i.e. dump vga cards ...)."
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   303
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   304
    |wg p|
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   305
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   306
    flushPending ifFalse:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   307
	flushPending := true.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   308
	"
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   309
	 we could run under a process, which dies in the meantime;
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   310
	 therefore, we have to arrange for the transcript process to
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   311
	 be interrupted and do the update.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   312
	"
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   313
	wg := self windowGroup.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   314
	wg isNil ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   315
	    p := Processor activeProcess
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   316
	] ifFalse:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   317
	    p := wg process
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   318
	].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   319
	Processor addTimedBlock:flushBlock for:p afterSeconds:timeDelay.
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   320
    ]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   321
! !
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   322
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   323
!TextCollector methodsFor:'stream messages'!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   324
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   325
lineLength
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   326
    ^ width // (font width)
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   327
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   328
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   329
nextPut:something
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   330
    "this allows TextCollectors to be used Stream-wise"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   331
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   332
    flushPending ifTrue:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   333
	self endEntry
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   334
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   335
    (something isMemberOf:Character) ifTrue:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   336
	((something == Character cr) or:[something == Character nl]) ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   337
	    ^ self cr
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   338
	].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   339
	self insertCharAtCursor:something
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   340
    ] ifFalse:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   341
	self insertStringAtCursor:(something printString).
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   342
	self checkLineLimit
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   343
    ].
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   344
    device synchronizeOutput
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   345
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   346
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   347
nextPutAll:something
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   348
    "this allows TextCollectors to be used Stream-wise"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   349
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   350
    ^ self nextPut:something
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   351
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   352
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   353
cr
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   354
    "output a carriage return, finishing the current line"
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   355
77
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   356
    access wouldBlock ifTrue:[
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   357
	Processor activeProcessIsSystemProcess ifTrue:[
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   358
	    Stderr cr.
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   359
	    ^ self
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   360
	]
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   361
    ].
34
c4b386a8cc57 critical-lock; allows show:/showCr: from multiple processes
claus
parents: 22
diff changeset
   362
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   363
    collecting ifTrue:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   364
	access critical:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   365
	    outstandingLine notNil ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   366
		outstandingLines add:outstandingLine.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   367
	    ].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   368
	    outstandingLine := ''.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   369
	].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   370
	flushPending ifFalse:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   371
	    self installDelayedUpdate
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   372
	]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   373
    ] ifFalse:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   374
	access critical:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   375
	    self cursorReturn.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   376
	    self checkLineLimit.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   377
	].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   378
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   379
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   380
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   381
show:anObject
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   382
    "insert the argument aString at current cursor position"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   383
77
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   384
    |aString|
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   385
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   386
    aString := anObject printString.
77
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   387
    access wouldBlock ifTrue:[
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   388
	Processor activeProcessIsSystemProcess ifTrue:[
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   389
	    Stderr nextPutAll:'Blocking in Transcript avoided: ' , aString.
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   390
	    ^ self
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   391
	]
565b052f5277 *** empty log message ***
claus
parents: 63
diff changeset
   392
    ].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   393
    collecting ifTrue:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   394
	access critical:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   395
	    outstandingLine notNil ifTrue:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   396
		outstandingLine := outstandingLine , aString
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   397
	    ] ifFalse:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   398
		outstandingLine := aString
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   399
	    ].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   400
	].
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   401
	flushPending ifFalse:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   402
	    self installDelayedUpdate
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   403
	]
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   404
    ] ifFalse:[
59
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   405
	access critical:[
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   406
	    self nextPut:aString.
450ce95a72a4 *** empty log message ***
claus
parents: 52
diff changeset
   407
	].
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   408
    ]
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   409
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   410
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   411
showCr:aString
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   412
    "insert the argument aString followed by a newline
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   413
     at current cursor position"
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   414
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   415
    self show:aString.
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   416
    self cr
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   417
!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   418
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   419
doesNotUnderstand:aMessage
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   420
    "this is funny: all message we do not understand, are passed
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   421
     on to the stream which will send the characters via nextPut:
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   422
     This way, we understand all Stream messages - great isn't it !!
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   423
    "
15
0dbce35d3c69 *** empty log message ***
claus
parents: 7
diff changeset
   424
     ^ entryStream perform:(aMessage selector) withArguments:(aMessage arguments)
0
e6a541c1c0eb Initial revision
claus
parents:
diff changeset
   425
! !