input/async: more API documentation

This commit is contained in:
Max Kellermann 2014-07-10 10:33:43 +02:00
parent ccbb5c3e01
commit b123392592

View File

@ -78,14 +78,25 @@ public:
size_t Read(void *ptr, size_t read_size, Error &error) final; size_t Read(void *ptr, size_t read_size, Error &error) final;
protected: protected:
/**
* Pass an tag from the I/O thread to the client thread.
*/
void SetTag(Tag *_tag); void SetTag(Tag *_tag);
void Pause(); void Pause();
/**
* Declare that the underlying stream was closed. We will
* continue feeding Read() calls from the buffer until it runs
* empty.
*/
void SetClosed() { void SetClosed() {
open = false; open = false;
} }
/**
* Pass an error from the I/O thread to the client thread.
*/
void PostponeError(Error &&error); void PostponeError(Error &&error);
bool IsBufferEmpty() const { bool IsBufferEmpty() const {
@ -96,13 +107,24 @@ protected:
return buffer.IsFull(); return buffer.IsFull();
} }
/**
* Determine how many bytes can be added to the buffer.
*/
gcc_pure gcc_pure
size_t GetBufferSpace() const { size_t GetBufferSpace() const {
return buffer.GetSpace(); return buffer.GetSpace();
} }
/**
* Append data to the buffer. The size must fit into the
* buffer; see GetBufferSpace().
*/
void AppendToBuffer(const void *data, size_t append_size); void AppendToBuffer(const void *data, size_t append_size);
/**
* Implement code here that will resume the stream after it
* has been paused due to full input buffer.
*/
virtual void DoResume() = 0; virtual void DoResume() = 0;
/** /**
@ -116,6 +138,10 @@ protected:
return seek_state == SeekState::PENDING; return seek_state == SeekState::PENDING;
} }
/**
* Call this after seeking has finished. It will notify the
* client thread.
*/
void SeekDone(); void SeekDone();
private: private: