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