Jive reference manual
List of all members | Public Member Functions | Protected Member Functions
jem::io::StdinReader Class Reference

#include <jem/io/StdinReader.h>

Inheritance diagram for jem::io::StdinReader:
Inheritance graph

Public Member Functions

 StdinReader ()
 
 StdinReader (const Self &rhs)
 
virtual Ref< Readerdup ()
 
virtual void close ()
 Closes this input stream. More...
 
virtual idx_t poll (const Time &timeout)
 
virtual int read ()
 Extracts the next character from this input stream. More...
 
virtual idx_t read (char *buf, idx_t n)
 
virtual void pushBack (int c)
 Pushes back a previously read character. More...
 
- Public Member Functions inherited from jem::io::Reader
virtual void lock ()
 Locks this input stream. More...
 
virtual void unlock ()
 Unlocks this input stream. More...
 
virtual int poll ()
 Returns the number of characters that can read without blocking. More...
 
virtual int read (char *buf, int n)
 Extracts multiple characters from this input stream. More...
 
virtual int readUntil (char *buf, int n, int delim)
 Reads characters until a specified character. More...
 
virtual void skipUntil (int delim)
 Skips characters until a specified character. More...
 
virtual void skipWhite ()
 Skips over white space. More...
 
virtual int skip (int n)
 Skips over a specified number of characters. More...
 
String readLine ()
 Reads the next line from this input stream. More...
 
virtual byte parseByte ()
 Reads a byte from this input stream. More...
 
virtual bool parseBool ()
 Reads a boolean from this input stream. More...
 
virtual long parseInt ()
 Reads a long integer from this input stream. More...
 
virtual double parseFloat ()
 Reads a double from this input stream. More...
 
- Public Member Functions inherited from jem::Object
virtual ClassgetClass () const
 Returns the Class instance representing the runtime class of this object. More...
 
virtual String toString () const
 Returns a short textual description of this object. More...
 
virtual long hashValue () const
 Returns a hash value for this object. More...
 
virtual bool equals (const Ref< Object > &obj) const
 Tests whether two objects are equal. More...
 
Ref< Objectclone () const
 Returns a copy of this object. More...
 

Protected Member Functions

virtual ~StdinReader ()
 
- Protected Member Functions inherited from jem::Collectable
 Collectable ()
 Creates an empty Collectable. More...
 
 ~Collectable ()
 Frees resources. More...
 
- Protected Member Functions inherited from jem::Interface
virtual ~Interface ()
 Empty destructor. More...
 

Additional Inherited Members

- Static Public Member Functions inherited from jem::Object
static ClassgetType ()
 Returns the Class instance representing the Object class. More...
 

Constructor & Destructor Documentation

jem::io::StdinReader::StdinReader ( )
jem::io::StdinReader::StdinReader ( const Self &  rhs)
virtual jem::io::StdinReader::~StdinReader ( )
protectedvirtual

Member Function Documentation

virtual Ref<Reader> jem::io::StdinReader::dup ( )
virtual
virtual void jem::io::StdinReader::close ( )
virtual

Closes this input stream. After calling this function, one should not attempt to read any more characters from this stream.

The default implementation provided by the Reader class does nothing.

Exceptions
IOException- if an I/O error occurs.

Reimplemented from jem::io::Reader.

virtual idx_t jem::io::StdinReader::poll ( const Time timeout)
virtual
virtual int jem::io::StdinReader::read ( )
virtual

Returns the next character, cast to an int, from this input stream. If the end of the stream has been reached, -1 is returned.

Returns
The next character in the input stream, or -1.
Exceptions
IOException- if an I/O error occurs.

Implements jem::io::TextInput.

virtual idx_t jem::io::StdinReader::read ( char *  buf,
idx_t  n 
)
virtual
virtual void jem::io::StdinReader::pushBack ( int  c)
virtual

Pushes back the character c, cast to an unsigned char, into this input stream. This character must have been previously extracted from the input stream by calling one of the read() member functions. The pushed back character will be the first character to be extracted from the input stream when one of the read() member functions is called.

Characters must be pushed back in the same order as they have been read; one is not allowed to alter the contents of the input stream.

If the character c has a negative value, this function does nothing.

Example:

void skipNumbers ( TextInput& in )
{
int c;
for ( c = in.read(); c >= 0 && isalpha(c); c = in.read() );
in.pushBack( c );
}
Parameters
c- the character to be pushed back.
Postcondition
If c is non-negative, then this->read() == c.
Exceptions
IOException- if an I/O error occurs.

Implements jem::io::TextInput.