Stream.st
author Claus Gittinger <cg@exept.de>
Fri, 27 Oct 1995 16:56:51 +0100
changeset 451 5aab4706f2fd
parent 427 326b2c263dae
child 530 07d0bce293c9
permissions -rw-r--r--
.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
     3
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
Object subclass:#Stream
a27a279701f8 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    15
       classVariableNames:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    16
       poolDictionaries:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    17
       category:'Streams'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
Stream comment:'
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
    21
COPYRIGHT (c) 1989 by Claus Gittinger
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
    22
	      All Rights Reserved
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    23
427
claus
parents: 384
diff changeset
    24
$Header: /cvs/stx/stx/libbasic/Stream.st,v 1.23 1995-09-10 20:20:06 claus Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    25
'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    26
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    27
!Stream class methodsFor:'documentation'!
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    28
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    29
copyright
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    30
"
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    31
 COPYRIGHT (c) 1989 by Claus Gittinger
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
    32
	      All Rights Reserved
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    33
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    34
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    35
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    36
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    37
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    38
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    39
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    40
"
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    41
!
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    42
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    43
version
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    44
"
427
claus
parents: 384
diff changeset
    45
$Header: /cvs/stx/stx/libbasic/Stream.st,v 1.23 1995-09-10 20:20:06 claus Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    46
"
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    47
!
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    48
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    49
documentation
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    50
"
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    51
    An abstract class defining common behavior for all stream-like objects.
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    52
    See concrete subclasses for more detail.
345
claus
parents: 339
diff changeset
    53
claus
parents: 339
diff changeset
    54
    Subclasses should (at least) implement:
claus
parents: 339
diff changeset
    55
	#next           (if readable)
claus
parents: 339
diff changeset
    56
	#nextPut:       (if writable)
claus
parents: 339
diff changeset
    57
	#contents
claus
parents: 339
diff changeset
    58
	#atEnd
claus
parents: 339
diff changeset
    59
	#isReadable
claus
parents: 339
diff changeset
    60
	#isWritable
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    61
"
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    62
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    63
a27a279701f8 Initial revision
claus
parents:
diff changeset
    64
!Stream class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    65
a27a279701f8 Initial revision
claus
parents:
diff changeset
    66
new
a27a279701f8 Initial revision
claus
parents:
diff changeset
    67
    "report an error - Streams are created using on:-messages"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    68
a27a279701f8 Initial revision
claus
parents:
diff changeset
    69
    ^ self error:'Streams cannot be created with new'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    70
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
    71
a27a279701f8 Initial revision
claus
parents:
diff changeset
    72
!Stream methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    73
a27a279701f8 Initial revision
claus
parents:
diff changeset
    74
contents
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
    75
    "return the entire contents of the stream
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    76
     - we do not know here how to do it, it must be redefined in subclass"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    77
a27a279701f8 Initial revision
claus
parents:
diff changeset
    78
    ^ self subclassResponsibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
    79
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
    80
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
    81
!Stream methodsFor:'reading'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    82
a27a279701f8 Initial revision
claus
parents:
diff changeset
    83
next
a27a279701f8 Initial revision
claus
parents:
diff changeset
    84
    "return the next element of the stream
a27a279701f8 Initial revision
claus
parents:
diff changeset
    85
     - we do not know here how to do it, it must be redefined in subclass"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    86
a27a279701f8 Initial revision
claus
parents:
diff changeset
    87
    ^ self subclassResponsibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
    88
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    89
a27a279701f8 Initial revision
claus
parents:
diff changeset
    90
next:count
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
    91
    "return the next count elements of the stream as a Collection."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    92
329
claus
parents: 308
diff changeset
    93
    |answerStream 
285
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
    94
     cnt  "{ Class: SmallInteger }" |
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    95
329
claus
parents: 308
diff changeset
    96
    answerStream := WriteStream on:(self contentsSpecies new).
285
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
    97
    cnt := count.
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
    98
    1 to:cnt do:[:index |
329
claus
parents: 308
diff changeset
    99
	answerStream nextPut:(self next)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   100
    ].
329
claus
parents: 308
diff changeset
   101
    ^ answerStream contents
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   102
275
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   103
    "
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   104
     (ReadStream on:#(1 2 3 4 5)) next:3
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   105
     (ReadStream on:'hello') next:3
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   106
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   107
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   108
285
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   109
nextAvailable:count
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   110
    "return the next count elements of the stream as a Collection.
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   111
     If the stream reaches the end before count elements have been read,
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   112
     return what is available. (i.e. a shorter collection)"
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   113
345
claus
parents: 339
diff changeset
   114
    |answerStream
285
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   115
     cnt  "{ Class: SmallInteger }"|
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   116
329
claus
parents: 308
diff changeset
   117
    answerStream := WriteStream on:(self contentsSpecies new).
285
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   118
    cnt := count.
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   119
    1 to:cnt do:[:index |
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   120
	self atEnd ifTrue:[
329
claus
parents: 308
diff changeset
   121
	    ^ answerStream contents
285
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   122
	].
329
claus
parents: 308
diff changeset
   123
	answerStream nextPut:(self next)
285
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   124
    ].
329
claus
parents: 308
diff changeset
   125
    ^ answerStream contents
285
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   126
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   127
    "
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   128
     (ReadStream on:#(1 2 3 4 5)) nextAvailable:3
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   129
     (ReadStream on:#(1 2 3 4 5)) nextAvailable:10 
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   130
     (ReadStream on:'hello') nextAvailable:3
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   131
     (ReadStream on:'hello') nextAvailable:10 
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   132
    "
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   133
!
ad6dfa61182e *** empty log message ***
claus
parents: 275
diff changeset
   134
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   135
nextMatchFor:anObject
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   136
    "read an element from the receiver, return true if it was equal to
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   137
     the argument, anObject"
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   138
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   139
    ^ (self next = anObject)
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   140
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   141
    "
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   142
     |s|
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   143
     s := ReadStream on:#(1 2 3 4 5 6 7 8).
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   144
     s nextMatchFor:2
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   145
    "
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   146
    "
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   147
     |s|
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   148
     s := ReadStream on:#(1 2 3 4 5 6 7 8).
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   149
     s nextMatchFor:2.
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   150
     s nextMatchFor:2
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   151
    "
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   152
!
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   153
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   154
skip:count 
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   155
    "skip count objects, return the receiver"
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   156
345
claus
parents: 339
diff changeset
   157
    |n "{ Class: SmallInteger }"|
claus
parents: 339
diff changeset
   158
claus
parents: 339
diff changeset
   159
    n := count.
claus
parents: 339
diff changeset
   160
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   161
    "dont know how to unread ..."
345
claus
parents: 339
diff changeset
   162
    n < 0 ifTrue:[
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   163
	^ self error:'stream is not positionable'
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   164
    ].
345
claus
parents: 339
diff changeset
   165
    n timesRepeat:self next
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   166
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   167
    "
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   168
     |s|
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   169
     s := ReadStream on:#(1 2 3 4 5 6 7 8).
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   170
     s skip:4.
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   171
     s next
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   172
    "
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   173
!
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   174
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   175
skipFor:anObject
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   176
    "skip all objects up-to and including anObject; return the element after anObject."
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   177
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   178
    (self skipThrough:anObject) notNil ifTrue:[
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   179
	^ self next
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   180
    ].
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   181
    ^ nil
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   182
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   183
    "
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   184
     |s|
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   185
     s := ReadStream on:#(1 2 3 4 5 6 7 8).
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   186
     s skipFor:4.
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   187
    "
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   188
!
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   189
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   190
skipThrough:anObject
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   191
    "skip all objects up-to and including anObject. Return the receiver if
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   192
     skip was successfull, otherwise (i.e. if not found) return nil.
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   193
     The next read operation will return the element after anObject."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   194
a27a279701f8 Initial revision
claus
parents:
diff changeset
   195
    |nextElement|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   196
a27a279701f8 Initial revision
claus
parents:
diff changeset
   197
    [self atEnd] whileFalse:[
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   198
	nextElement := self next.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   199
	(nextElement = anObject) ifTrue: [ ^ self ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   200
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   201
    ^ nil
2
claus
parents: 1
diff changeset
   202
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   203
    "
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   204
     |s|
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   205
     s := ReadStream on:#(1 2 3 4 5 6 7 8).
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   206
     s skipThrough:4.
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   207
     s next
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   208
    "
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   209
!
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   210
427
claus
parents: 384
diff changeset
   211
upTo:anObject
claus
parents: 384
diff changeset
   212
    "read a collection of all objects up-to anObject and return these
claus
parents: 384
diff changeset
   213
     elements, but excluding anObject. 
claus
parents: 384
diff changeset
   214
     The next read operation will return the element after anObject.
claus
parents: 384
diff changeset
   215
     Compare this with #through: which also reads up to some object
claus
parents: 384
diff changeset
   216
     and also positions behind it, but DOES include it in the returned
claus
parents: 384
diff changeset
   217
     value."
claus
parents: 384
diff changeset
   218
claus
parents: 384
diff changeset
   219
    |answerStream element|
claus
parents: 384
diff changeset
   220
claus
parents: 384
diff changeset
   221
    answerStream := WriteStream on:(self contentsSpecies new).
claus
parents: 384
diff changeset
   222
    [self atEnd] whileFalse:[
claus
parents: 384
diff changeset
   223
	element := self next.
claus
parents: 384
diff changeset
   224
	(element = anObject) ifTrue: [
claus
parents: 384
diff changeset
   225
	    ^ answerStream contents
claus
parents: 384
diff changeset
   226
	].
claus
parents: 384
diff changeset
   227
	answerStream nextPut: element.
claus
parents: 384
diff changeset
   228
    ].
claus
parents: 384
diff changeset
   229
    ^ answerStream contents
claus
parents: 384
diff changeset
   230
claus
parents: 384
diff changeset
   231
    "
claus
parents: 384
diff changeset
   232
     |s|
claus
parents: 384
diff changeset
   233
     s := ReadStream on:#(1 2 3 4 5 6 7 8).
claus
parents: 384
diff changeset
   234
     Transcript showCr:(s upTo:4).  
claus
parents: 384
diff changeset
   235
     Transcript showCr:s next
claus
parents: 384
diff changeset
   236
claus
parents: 384
diff changeset
   237
     |s|
claus
parents: 384
diff changeset
   238
     s := ReadStream on:'hello world'.
claus
parents: 384
diff changeset
   239
     Transcript showCr:(s upTo:Character space).
claus
parents: 384
diff changeset
   240
     Transcript showCr:(s upToEnd)
claus
parents: 384
diff changeset
   241
claus
parents: 384
diff changeset
   242
     (ReadStream on:'12345678905') upTo:$5; upTo:$5 
claus
parents: 384
diff changeset
   243
claus
parents: 384
diff changeset
   244
     (ReadStream on:'123456') upTo:$7     
claus
parents: 384
diff changeset
   245
claus
parents: 384
diff changeset
   246
     (ReadStream on:#(1 2 3 4 5 6)) upTo:4  
claus
parents: 384
diff changeset
   247
claus
parents: 384
diff changeset
   248
     (ReadStream on:'line 1
claus
parents: 384
diff changeset
   249
		     line 2') upTo:Character cr  
claus
parents: 384
diff changeset
   250
claus
parents: 384
diff changeset
   251
     'Makefile' asFilename readStream upTo:Character cr;upTo:Character cr  
claus
parents: 384
diff changeset
   252
    "
claus
parents: 384
diff changeset
   253
!
claus
parents: 384
diff changeset
   254
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   255
upToEnd
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   256
    "return a collection of the elements up-to the end.
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   257
     Return nil if the stream-end is reached before."
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   258
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   259
    |answerStream|
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   260
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   261
    answerStream := WriteStream on:(self contentsSpecies new).
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   262
    [self atEnd] whileFalse:[
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   263
	answerStream nextPut:(self next)
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   264
    ].
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   265
    ^ answerStream contents
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   266
275
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   267
    "
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   268
     (ReadStream on:'1234567890') upToEnd
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   269
     ('123456' readStream) next; next; upToEnd
427
claus
parents: 384
diff changeset
   270
     ('1 23456' readStream) upTo:Character space; upToEnd 
275
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   271
    "
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   272
!
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   273
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   274
through:anObject
427
claus
parents: 384
diff changeset
   275
    "read a collection of all objects up-to anObject and return these
claus
parents: 384
diff changeset
   276
     elements, including anObject. 
claus
parents: 384
diff changeset
   277
     The next read operation will return the element after anObject.
claus
parents: 384
diff changeset
   278
     Compare this with #upTo: which also reads up to some object
claus
parents: 384
diff changeset
   279
     and also positions behind it, but does not include it in the returned
claus
parents: 384
diff changeset
   280
     value."
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   281
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   282
    |answerStream element|
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   283
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   284
    answerStream := WriteStream on:(self contentsSpecies new).
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   285
    [self atEnd] whileFalse:[
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   286
	element := self next.
427
claus
parents: 384
diff changeset
   287
	answerStream nextPut:element.
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   288
	(element = anObject) ifTrue: [
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   289
	    ^ answerStream contents
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   290
	]
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   291
    ].
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   292
    ^ answerStream contents
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   293
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   294
    "
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   295
     |s|
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   296
     s := ReadStream on:#(1 2 3 4 5 6 7 8).
427
claus
parents: 384
diff changeset
   297
     Transcript showCr:(s through:4).  
claus
parents: 384
diff changeset
   298
     Transcript showCr:s next
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   299
    "
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   300
    "
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   301
     |s|
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   302
     s := ReadStream on:'hello world'.
427
claus
parents: 384
diff changeset
   303
     Transcript showCr:(s through:Character space).
claus
parents: 384
diff changeset
   304
     Transcript showCr:(s upToEnd)
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   305
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   306
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   307
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   308
!Stream methodsFor:'writing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   309
339
claus
parents: 335
diff changeset
   310
commit
claus
parents: 335
diff changeset
   311
    "write out all unbuffered data - ignored here, but added
claus
parents: 335
diff changeset
   312
     to make internalStreams protocol compatible with externalStreams"
claus
parents: 335
diff changeset
   313
claus
parents: 335
diff changeset
   314
!
claus
parents: 335
diff changeset
   315
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   316
nextPut:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
   317
    "put the argument, anObject onto the receiver
a27a279701f8 Initial revision
claus
parents:
diff changeset
   318
     - we do not know here how to do it, it must be redefined in subclass"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   319
a27a279701f8 Initial revision
claus
parents:
diff changeset
   320
    ^ self subclassResponsibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
   321
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   322
a27a279701f8 Initial revision
claus
parents:
diff changeset
   323
next:count put:anObject
a27a279701f8 Initial revision
claus
parents:
diff changeset
   324
    "put the argument, anObject count times onto the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   325
345
claus
parents: 339
diff changeset
   326
    |n "{ Class: SmallInteger }"|
claus
parents: 339
diff changeset
   327
claus
parents: 339
diff changeset
   328
    n := count.
claus
parents: 339
diff changeset
   329
    n timesRepeat:[self nextPut:anObject].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   330
    ^ anObject
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   331
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   332
    "
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   333
     |s|
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   334
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   335
     s := WriteStream on:#().
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   336
     s nextPut:1.
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   337
     s next:5 put:2.
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   338
     s nextPut:3.
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   339
     s contents
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   340
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   341
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   342
a27a279701f8 Initial revision
claus
parents:
diff changeset
   343
nextPutAll:aCollection
a27a279701f8 Initial revision
claus
parents:
diff changeset
   344
    "put all elements of the argument, aCollection onto the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   345
a27a279701f8 Initial revision
claus
parents:
diff changeset
   346
    aCollection do:[:element |
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   347
	self nextPut:element
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   348
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   349
    ^ aCollection
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   350
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   351
    "
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   352
     |s|
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   353
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   354
     s := WriteStream on:#().
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   355
     s nextPutAll:(1 to:5).
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   356
     s nextPutAll:#('one' 'two' 'three').
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   357
     s contents
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   358
    "
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   359
    "
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   360
     |s|
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   361
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   362
     s := WriteStream on:(String new).
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   363
     s nextPutAll:($a to:$f).
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   364
     s nextPutAll:'one '; 
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   365
       nextPutAll:'two ';
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   366
       nextPutAll:'three'.
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   367
     s contents
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   368
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   369
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   370
a27a279701f8 Initial revision
claus
parents:
diff changeset
   371
nextPutAll:aCollection startingAt:first to:last
a27a279701f8 Initial revision
claus
parents:
diff changeset
   372
    "put the elements with index from first to last
a27a279701f8 Initial revision
claus
parents:
diff changeset
   373
     of the argument, aCollection onto the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   374
a27a279701f8 Initial revision
claus
parents:
diff changeset
   375
    aCollection from:first to:last do:[:element |
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   376
	self nextPut:element
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   377
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   378
    ^ aCollection
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   379
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   380
    "
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   381
     |s|
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   382
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   383
     s := WriteStream on:#().
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   384
     s nextPutAll:#('one' 'two' 'three' 'four' 'five') startingAt:2 to:4.
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   385
     s contents
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   386
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   387
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   388
2
claus
parents: 1
diff changeset
   389
endEntry
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   390
    "ignored here - for compatibility with Transcript"
2
claus
parents: 1
diff changeset
   391
claus
parents: 1
diff changeset
   392
    ^ self
claus
parents: 1
diff changeset
   393
!
claus
parents: 1
diff changeset
   394
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   395
show:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   396
    "put all elements of the argument, aString onto the receiver;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   397
     this makes streams somewhat compatible to TextCollectors and
a27a279701f8 Initial revision
claus
parents:
diff changeset
   398
     allows you to say: Smalltalk at:#Transcript put:Stdout"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   399
a27a279701f8 Initial revision
claus
parents:
diff changeset
   400
    ^ self nextPutAll:aString printString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   401
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   402
a27a279701f8 Initial revision
claus
parents:
diff changeset
   403
showCr:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   404
    "put all elements of the argument, aString onto the receiver;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   405
     and append a newline.
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   406
     For compatibility with TextCollectors"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   407
a27a279701f8 Initial revision
claus
parents:
diff changeset
   408
    self show:aString.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   409
    self cr
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   410
!
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   411
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   412
print:anObject
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   413
    "append a printed representation of anObject to the receiver.
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   414
     Same as anObject printOn:self; For ST-80 compatibility."
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   415
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   416
    anObject printOn:self
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   417
!
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   418
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   419
store:anObject
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   420
    "append a printed representation of anObject to the receiver,
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   421
     from which the receiver can be reconstructed.
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   422
     Same as anObject storeOn:self; For ST-80 compatibility."
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   423
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   424
    anObject storeOn:self
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   425
!
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   426
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   427
cr
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   428
    "append a carriage-return to the stream"
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   429
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   430
    self nextPut:(Character cr)
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   431
!
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   432
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   433
tab
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   434
    "append a tab-character to the stream"
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   435
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   436
    self nextPut:(Character tab)
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   437
!
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   438
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   439
crTab
345
claus
parents: 339
diff changeset
   440
    "append a carriage-return followed by a tab to the stream.
claus
parents: 339
diff changeset
   441
     Same as crtab for ST/X backward compatibility"
claus
parents: 339
diff changeset
   442
claus
parents: 339
diff changeset
   443
    self obsoleteMethodWarning:'use crTab'.
claus
parents: 339
diff changeset
   444
    self crtab
claus
parents: 339
diff changeset
   445
!
claus
parents: 339
diff changeset
   446
claus
parents: 339
diff changeset
   447
crtab:n
claus
parents: 339
diff changeset
   448
    "append a carriage-return followed by n tabs to the stream."
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   449
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   450
    self nextPut:(Character cr).
345
claus
parents: 339
diff changeset
   451
    self next:n put:(Character tab)
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   452
!
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   453
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   454
crtab
345
claus
parents: 339
diff changeset
   455
    "append a carriage-return followed by a tab to the stream."
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   456
345
claus
parents: 339
diff changeset
   457
    self crtab:1
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   458
!
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   459
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   460
space
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   461
    "append a space character to the receiver-stream"
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   462
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   463
    self nextPut:(Character space)
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   464
!
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   465
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   466
spaces:count
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   467
    "append count space-characters to the receiver-stream"
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   468
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   469
    self next:count put:(Character space)
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   470
!
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   471
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   472
ff
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   473
    "append a form-feed (new-pagee) to the receiver-stream"
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   474
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   475
    self nextPut:(Character ff)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   476
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   477
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   478
!Stream methodsFor:'non homogenous writing'!
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   479
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   480
nextPutWord:aNumber
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   481
    "write the argument, aNumber as a signed short (two bytes);
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   482
     write msb-first for compatibility with other smalltalks.
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   483
     The receiver must support writing of binary bytes.
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   484
     I dont know if it should be named nextPutWord: or nextWordPut:;
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   485
     one of them will vanish ..."
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   486
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   487
    ^ self nextPutShort:aNumber MSB:true
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   488
!
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   489
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   490
nextWordPut:aNumber
308
f04744ef7b5d *** empty log message ***
claus
parents: 285
diff changeset
   491
    "for ST-80 compatibility"
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   492
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   493
    ^ self nextPutShort:aNumber MSB:true
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   494
!
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   495
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   496
nextShortPut:aNumber MSB:msbFlag
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   497
    "for compatibility - this will vanish"
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   498
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   499
    ^ self nextPutShort:aNumber MSB:msbFlag
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   500
!
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   501
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   502
nextPutShort:aNumber MSB:msbFlag
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   503
    "Write the argument, aNumber as a short (two bytes). If msbFlag is
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   504
     true, data is written most-significant byte first; otherwise least
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   505
     first. Returns the receiver on ok, nil on error.
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   506
     The receiver must support writing of binary bytes."
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   507
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   508
    msbFlag ifTrue:[
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   509
	"most significant first"
275
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   510
	self nextPut:(aNumber bitShift:-8).
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   511
	^ self nextPut:(aNumber bitAnd:16rFF).
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   512
    ].
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   513
    "least significant first"
275
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   514
    self nextPut:(aNumber bitAnd:16rFF).
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   515
    self nextPut:(aNumber bitShift:-8).
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   516
!
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   517
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   518
nextPutLong:aNumber MSB:msbFlag
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   519
    "Write the argument, aNumber as a long (four bytes). If msbFlag is
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   520
     true, data is written most-significant byte first; otherwise least
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   521
     first. Returns the receiver on ok, nil on error.
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   522
     The receiver must support writing of binary bytes."
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   523
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   524
    msbFlag ifTrue:[
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   525
	"high word first"
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   526
	self nextShortPut:(aNumber // 16r10000) MSB:true.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   527
	^ self nextShortPut:(aNumber \\ 16r10000) MSB:true
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   528
    ].
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   529
    "low word first"
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   530
    self nextShortPut:(aNumber \\ 16r10000) MSB:false.
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   531
    ^ self nextShortPut:(aNumber // 16r10000) MSB:false.
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   532
!
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   533
308
f04744ef7b5d *** empty log message ***
claus
parents: 285
diff changeset
   534
nextLongPut:aNumber
f04744ef7b5d *** empty log message ***
claus
parents: 285
diff changeset
   535
    "for ST-80 compatibility"
f04744ef7b5d *** empty log message ***
claus
parents: 285
diff changeset
   536
f04744ef7b5d *** empty log message ***
claus
parents: 285
diff changeset
   537
    ^ self nextPutLong:aNumber MSB:true
f04744ef7b5d *** empty log message ***
claus
parents: 285
diff changeset
   538
!
f04744ef7b5d *** empty log message ***
claus
parents: 285
diff changeset
   539
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   540
nextNumber:n put:v 
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   541
    "Append to the receiver the argument, v, which is a positive Integer,
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   542
     as the next n bytes. Bytes are written msb first. 
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   543
     Possibly pad with leading zeros.
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   544
     The receiver must support writing of binary bytes."
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   545
275
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   546
    |vlen i|
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   547
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   548
    "claus: this method is central in binaryStorage -
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   549
     therefore it has been tuned a bit (and needs even more tuning)"
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   550
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   551
    v class == SmallInteger ifTrue:[  "- this is a hint to stc"
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   552
	n == 1 ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   553
	    (v between:0 and:16rFF) ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   554
		self nextPut:v.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   555
		^ self
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   556
	    ].
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   557
	].
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   558
	n == 2 ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   559
	    (v between:0 and:16rFFFF) ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   560
		self nextPut:(v bitShift:-8).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   561
		self nextPut:(v bitAnd:16rFF).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   562
		^ self
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   563
	    ].
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   564
	].
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   565
	n == 3 ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   566
	    (v between:0 and:16rFFFFFF) ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   567
		self nextPut:((v bitShift:-16) bitAnd:16rFF).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   568
		self nextPut:((v bitShift:-8) bitAnd:16rFF).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   569
		self nextPut:(v bitAnd:16rFF).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   570
		^ self
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   571
	    ].
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   572
	].
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   573
	n == 4 ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   574
	    (v >= 0) ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   575
		self nextPut:((v bitShift:-24) bitAnd:16rFF).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   576
		self nextPut:((v bitShift:-16) bitAnd:16rFF).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   577
		self nextPut:((v bitShift:-8) bitAnd:16rFF).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   578
		self nextPut:(v bitAnd:16rFF).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   579
		^ self
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   580
	    ].
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   581
	].
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   582
    ].
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   583
275
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   584
    "
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   585
     arbitrary long
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   586
    "
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   587
    n < (vlen := v digitLength) ifTrue: [
275
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   588
	"
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   589
	 the number is too big to be repesented in n bytes
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   590
	"
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   591
	self error: 'number too big'
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   592
    ].
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   593
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   594
    "pad with leading zeros"
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   595
    i := n.
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   596
    [i > vlen] whileTrue: [
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   597
	self nextPut: 0. 
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   598
	i := i - 1
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   599
    ].
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   600
    i = 1 ifTrue: [
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   601
	^ self nextPut: v
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   602
    ].
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   603
    [i > 0] whileTrue: [
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   604
	self nextPut: (v digitAt: i). 
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   605
	i := i - 1
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   606
    ]
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   607
! !
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   608
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   609
!Stream methodsFor:'non homogenous reading'!
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   610
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   611
nextShortMSB:msbFlag
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   612
    "return a signed short (2 bytes) from the stream.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   613
     The receiver must support reading of binary bytes."
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   614
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   615
    |uval "{ Class: SmallInteger }"|
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   616
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   617
    msbFlag ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   618
	"most significant first"
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   619
	uval := self next bitShift:8.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   620
	uval := uval bitOr:(self next).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   621
    ] ifFalse:[
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   622
	"least significant first"
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   623
	uval := self next.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   624
	uval := uval bitOr:(self next bitShift:8).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   625
    ].
275
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   626
    "change from unsigned 0..FFFF to signed -8000..7FFF"
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   627
    uval >= 16r8000 ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   628
	^ uval - 16r10000 
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   629
    ].
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   630
    ^ uval
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   631
!
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   632
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   633
nextUnsignedShortMSB:msbFlag
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   634
    "return an unsigned short (2 bytes) from the stream.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   635
     The receiver must support reading of binary bytes."
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   636
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   637
    msbFlag ifTrue:[
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   638
	^ (self next bitShift:8) bitOr:(self next)
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   639
    ].
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   640
    ^ (self next) bitOr:(self next bitShift:8)
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   641
!
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   642
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   643
nextLongMSB:msbFlag
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   644
    "return a signed long (4 bytes) from the stream.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   645
     The receiver must support reading of binary bytes."
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   646
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   647
    |high uval "{ Class: SmallInteger }"|
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   648
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   649
    msbFlag ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   650
	"most significant first"
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   651
	high := self next.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   652
	uval := self next bitShift:16.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   653
	uval := uval bitOr:(self next bitShift:8).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   654
	uval := uval bitOr:(self next).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   655
	uval := uval bitOr:(high bitShift:24).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   656
    ] ifFalse:[
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   657
	"least significant first"
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   658
	uval := self next.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   659
	uval := uval bitOr:(self next bitShift:8).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   660
	uval := uval bitOr:(self next bitShift:16).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   661
	uval := uval bitOr:(self next bitShift:24).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   662
    ].
275
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   663
    "change from unsigned 0..FFFFFFFF to signed -80000000..7FFFFFFF"
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   664
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   665
"sorry- for now, stc cannot compile LargeInteger constants 
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   666
    uval >= 16r80000000 ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   667
	^ uval - 16r100000000 
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   668
    ].
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   669
the following kludges around this"
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   670
    (uval bitShift:-16) >= 16r8000 ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   671
	^ uval - (16r10000000 bitShift:8)
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   672
    ].
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   673
    ^ uval
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   674
!
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   675
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   676
nextUnsignedLongMSB:msbFlag
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   677
    "return an unsigned long (4 bytes) from the stream.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   678
     The receiver must support reading of binary bytes."
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   679
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   680
    |val|
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   681
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   682
    msbFlag ifTrue:[
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   683
	val := self next.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   684
	val := (val bitShift:8) bitOr:(self next).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   685
	val := (val bitShift:8) bitOr:(self next).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   686
	val := (val * 256) + (self next).
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   687
	^ val
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   688
    ].
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   689
    val := self next.
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   690
    ^ (val bitShift:24)
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   691
      + (self next bitShift:16)
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   692
      + (self next bitShift:8)
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   693
      + self next
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   694
!
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   695
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   696
nextNumber:n 
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   697
    "Return the next n bytes as a positive Integer; bytes are taken msb-first."
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   698
345
claus
parents: 339
diff changeset
   699
    |s 
claus
parents: 339
diff changeset
   700
     val "{ Class: SmallInteger }"
claus
parents: 339
diff changeset
   701
     rep "{ Class: SmallInteger }"|
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   702
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   703
    "claus: this method is central in binaryStorage -
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   704
     therefore it has been tuned a bit (and needs even more tuning)"
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   705
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   706
    n == 1 ifTrue:[
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   707
	^ self next
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   708
    ].
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   709
    n == 2 ifTrue:[
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   710
	val := self next.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   711
	val := (val bitShift:8) + self next.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   712
	^ val
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   713
    ].
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   714
    n == 3 ifTrue:[
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   715
	val := self next.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   716
	val := (val bitShift:8) + self next.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   717
	val := (val bitShift:8) + self next.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   718
	^ val
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   719
    ].
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   720
    n == 4 ifTrue:[
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   721
	val := self next.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   722
	val <= 16r3F ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   723
	    val := (val bitShift:8) + self next.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   724
	    val := (val bitShift:8) + self next.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   725
	    val := (val bitShift:8) + self next.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   726
	    ^ val
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   727
	].
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   728
	"sorry, but need a largeInteger"
275
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   729
	s := (val bitShift:8) + self next.
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   730
	s := (s bitShift:8) + self next.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   731
	"the multiplication below is a temporary workaround for the
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   732
	 inability of smallintegers to handle shifts out of the 32bit range ..."
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   733
	s := (s * 256) + self next.
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   734
	^ s
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   735
    ].
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   736
275
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   737
    "
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   738
     arbitrary long
a76029ddaa98 *** empty log message ***
claus
parents: 216
diff changeset
   739
    "
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   740
    s := 0.
345
claus
parents: 339
diff changeset
   741
    rep := n.
claus
parents: 339
diff changeset
   742
    rep timesRepeat:[ 
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   743
	s := s * 256 + self next
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   744
    ].
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   745
    ^ s truncated
346
claus
parents: 345
diff changeset
   746
!
claus
parents: 345
diff changeset
   747
claus
parents: 345
diff changeset
   748
nextWord
claus
parents: 345
diff changeset
   749
    ^ self nextAlphaNumericWord
claus
parents: 345
diff changeset
   750
!
claus
parents: 345
diff changeset
   751
claus
parents: 345
diff changeset
   752
nextLine
claus
parents: 345
diff changeset
   753
    "for compatibility with externalStreams"
claus
parents: 345
diff changeset
   754
claus
parents: 345
diff changeset
   755
    ^ self upTo:Character cr.
77
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   756
! !
6c38ca59927f *** empty log message ***
claus
parents: 70
diff changeset
   757
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   758
!Stream methodsFor:'closing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   759
a27a279701f8 Initial revision
claus
parents:
diff changeset
   760
close
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   761
    "close the stream - nothing done here.
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   762
     Added for compatibility with external streams."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   763
a27a279701f8 Initial revision
claus
parents:
diff changeset
   764
    ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   765
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   766
a27a279701f8 Initial revision
claus
parents:
diff changeset
   767
!Stream methodsFor:'testing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   768
a27a279701f8 Initial revision
claus
parents:
diff changeset
   769
atEnd
a27a279701f8 Initial revision
claus
parents:
diff changeset
   770
    "return true if the end of the stream has been reached;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   771
     - we do not know here how to do it, it must be redefined in subclass"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   772
a27a279701f8 Initial revision
claus
parents:
diff changeset
   773
    ^ self subclassResponsibility
a27a279701f8 Initial revision
claus
parents:
diff changeset
   774
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   775
a27a279701f8 Initial revision
claus
parents:
diff changeset
   776
!Stream methodsFor:'enumerating'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   777
a27a279701f8 Initial revision
claus
parents:
diff changeset
   778
do:aBlock
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   779
    "evaluate the argument, aBlock for all remaining elements,
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   780
     up to the end of the stream"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   781
a27a279701f8 Initial revision
claus
parents:
diff changeset
   782
    [self atEnd] whileFalse:[
216
a8abff749575 *** empty log message ***
claus
parents: 95
diff changeset
   783
	aBlock value:(self next)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   784
    ]
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   785
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   786
    "
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   787
     |s|
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   788
     s := ReadStream on:#(1 2 3 4 5 6 7 8 9).
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   789
     s next.
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   790
     s next.
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   791
     s do:[:element | Transcript showCr:element]
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   792
    "
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   793
! !
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   794
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   795
!Stream methodsFor:'private'!
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   796
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   797
contentsSpecies
70
73055652dd21 *** empty log message ***
claus
parents: 62
diff changeset
   798
    "this should return the class of which an instance is
73055652dd21 *** empty log message ***
claus
parents: 62
diff changeset
   799
     returned by the #contents method. It is redefinable in subclasses"
62
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   800
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   801
    "return Array here - since the abstract Stream has no idea
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   802
     of the underlying collection class"
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   803
e1b4369c61fb *** empty log message ***
claus
parents: 50
diff changeset
   804
    ^ Array
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   805
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   806
335
claus
parents: 329
diff changeset
   807
!Stream methodsFor:'misc'!
claus
parents: 329
diff changeset
   808
claus
parents: 329
diff changeset
   809
binary
claus
parents: 329
diff changeset
   810
    "switch to binary mode. ignored here, but added to make
claus
parents: 329
diff changeset
   811
     internalStreams protocol compatible with externStreams."
claus
parents: 329
diff changeset
   812
claus
parents: 329
diff changeset
   813
! !
claus
parents: 329
diff changeset
   814
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   815
!Stream methodsFor:'queries'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   816
339
claus
parents: 335
diff changeset
   817
isBinary
claus
parents: 335
diff changeset
   818
    "return true, if in binary mode. Returns false here,
claus
parents: 335
diff changeset
   819
     to make internalStreams protocol compatible with externStreams."
claus
parents: 335
diff changeset
   820
claus
parents: 335
diff changeset
   821
    ^ false
claus
parents: 335
diff changeset
   822
!
claus
parents: 335
diff changeset
   823
360
claus
parents: 346
diff changeset
   824
isPositionable
claus
parents: 346
diff changeset
   825
    "return true, if the stream supports positioning (some do not)"
claus
parents: 346
diff changeset
   826
claus
parents: 346
diff changeset
   827
    ^ false
claus
parents: 346
diff changeset
   828
!
claus
parents: 346
diff changeset
   829
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   830
isStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   831
    "return true, if the receiver is some kind of Stream."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   832
a27a279701f8 Initial revision
claus
parents:
diff changeset
   833
    ^ true
a27a279701f8 Initial revision
claus
parents:
diff changeset
   834
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   835
345
claus
parents: 339
diff changeset
   836
isReadable
claus
parents: 339
diff changeset
   837
    "return true, if reading is supported by the recevier.
claus
parents: 339
diff changeset
   838
     Assume yes here."
claus
parents: 339
diff changeset
   839
claus
parents: 339
diff changeset
   840
    ^ self subclassResponsibility
claus
parents: 339
diff changeset
   841
!
claus
parents: 339
diff changeset
   842
claus
parents: 339
diff changeset
   843
isWritable
claus
parents: 339
diff changeset
   844
    "return true, if writing is supported by the recevier.
claus
parents: 339
diff changeset
   845
     Assume yes here."
claus
parents: 339
diff changeset
   846
claus
parents: 339
diff changeset
   847
    ^ self subclassResponsibility
claus
parents: 339
diff changeset
   848
!
claus
parents: 339
diff changeset
   849
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   850
lineLength
a27a279701f8 Initial revision
claus
parents:
diff changeset
   851
    "this is just a layout hint for prettyprinting functions
a27a279701f8 Initial revision
claus
parents:
diff changeset
   852
     - for compatibility with TextCollectors"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   853
a27a279701f8 Initial revision
claus
parents:
diff changeset
   854
    ^ 80
a27a279701f8 Initial revision
claus
parents:
diff changeset
   855
! !