RWStream.st
author claus
Sat, 02 Sep 1995 18:08:30 +0200
changeset 420 081f7b2bb3b3
parent 384 cc3d110ea879
child 530 07d0bce293c9
permissions -rw-r--r--
Initial revision

"
 COPYRIGHT (c) 1989 by Claus Gittinger
	      All Rights Reserved

 This software is furnished under a license and may be used
 only in accordance with the terms of that license and with the
 inclusion of the above copyright notice.   This software may not
 be provided or otherwise made available to, or used by, any
 other person.  No title to or ownership of the software is
 hereby transferred.
"

WriteStream subclass:#ReadWriteStream
       instanceVariableNames:''
       classVariableNames:''
       poolDictionaries:''
       category:'Streams'
!

ReadWriteStream comment:'
COPYRIGHT (c) 1989 by Claus Gittinger
	      All Rights Reserved

$Header: /cvs/stx/stx/libbasic/Attic/RWStream.st,v 1.11 1995-08-11 03:03:12 claus Exp $
'!

!ReadWriteStream class methodsFor: 'documentation'!

copyright
"
 COPYRIGHT (c) 1989 by Claus Gittinger
	      All Rights Reserved

 This software is furnished under a license and may be used
 only in accordance with the terms of that license and with the
 inclusion of the above copyright notice.   This software may not
 be provided or otherwise made available to, or used by, any
 other person.  No title to or ownership of the software is
 hereby transferred.
"
!

version
"
$Header: /cvs/stx/stx/libbasic/Attic/RWStream.st,v 1.11 1995-08-11 03:03:12 claus Exp $
"
!

documentation
"
    ReadWriteStreams allow both read- and write-access to some collection.
    To allow this, they reenable some methods blocked in WriteStream.
    (being one of the seldom places, where multiple inheritance could be
     of good use in smalltalk).

    Claus:
	I personally find the ReadStream - WriteStream - ReadWriteStream
	organization brain-damaged. It would be better to have an attribute
	(such as readOnly / writeOnly / readWrite) in an InternalStream subclass 
	of Stream ...
"
! !

!ReadWriteStream methodsFor:'queries'!

isReadable 
    ^ true
! !

!ReadWriteStream methodsFor:'positioning'!

reset
    "re-redefine to not clobber the collection"

    position := "0" 1
! !

!ReadWriteStream methodsFor:'access-reading'!

peek
    "return the element to be read next without advancing read position.
     If there are no more elements, nil is returned."

    (position > readLimit) ifTrue:[^ nil].
    ^ collection at:position
!

next
    "return the next element; advance read position.
     If there are no more elements, nil is returned."

    |element|

    (position > readLimit) ifTrue:[^ nil].
    element := collection at:position.
    position := position + 1.
    ^ element
! !