ReadWriteStream.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Mon, 26 Apr 2010 19:26:38 +0100
branchjv
changeset 17761 b0e5971141bc
parent 17728 bbc5fa73dfab
child 17845 7e0cfaac936d
permissions -rw-r--r--
Added Lookup and BuiltinLookup classes

"
 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.
"
"{ Package: 'stx:libbasic' }"

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

!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.
"
!

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 ...

    [author:]
        Claus Gittinger
"
!

examples
"
    |s|

    s := ReadWriteStream with:'abcd'.
    s reset.
    s nextPut:$A.
    s contents       
"
! !

!ReadWriteStream methodsFor:'access-reading'!

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

    |element|

    ((position-ZeroPosition+1) > readLimit) ifTrue:[^ self pastEndRead].
    element := collection at:(position-ZeroPosition+1).
    position := position + 1.
    ^ element

    "Modified: 5.2.1996 / 21:57:40 / stefan"
!

nextByte
    "return the next element; advance read pointer.
     return nil, if there is no next element"

    ^ self next asInteger
!

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

    ((position-ZeroPosition+1) > readLimit) ifTrue:[^ self pastEndRead].
    ^ collection at:(position-ZeroPosition+1)

    "Modified: 5.2.1996 / 21:57:47 / stefan"
! !

!ReadWriteStream methodsFor:'accessing'!

contents
    "return the contents as written so far;
     redefined to prevent confusion resulting due to 
     my superclasses optimization. (see WriteStream contents).
     ST80 users if RWStream expect the contents array to remain
     unchanged."

    readLimit := (readLimit ? 0) max:position-ZeroPosition.
    ^ collection copyFrom:1 to:readLimit

    "Created: / 30.10.1997 / 16:25:22 / cg"
    "Modified: / 30.10.1997 / 18:37:09 / cg"
!

reset
    "set the read position to the beginning of the collection"

    self resetPosition

! !

!ReadWriteStream methodsFor:'converting'!

readStream
    "return the receiver as a readStream - thats myself"

    ^ self

    "Created: 29.11.1995 / 22:04:23 / stefan"
!

readStreamOrNil
    "return a readStream from the receiver. Since this is already
     a readStream, return self.

     This method has been defined for protocol copmatibility with Filename"

    ^ self
! !

!ReadWriteStream methodsFor:'initialization'!

with:initialCollection
    "redefined from WriteStream, to position to the beginning of the stream"

    super with:initialCollection.
    position := ZeroPosition.
! !

!ReadWriteStream methodsFor:'queries'!

isReadable 
    "return true if the receiver supports reading - thats true"

    ^ true
!

size
    "return the number of elements in the streamed collection."

    ^ (readLimit ? 0) max:(position ? ZeroPosition)-ZeroPosition.
! !

!ReadWriteStream class methodsFor:'documentation'!

version
    ^ '$Id: ReadWriteStream.st 10517 2010-04-26 18:26:38Z vranyj1 $'
!

version_SVN
    ^ '$Id: ReadWriteStream.st 10517 2010-04-26 18:26:38Z vranyj1 $'
! !