diff options
author | Thiago de Arruda <tpadilha84@gmail.com> | 2015-07-18 09:35:07 -0300 |
---|---|---|
committer | Felipe Morales <hel.sheep@gmail.com> | 2015-07-21 07:00:38 -0300 |
commit | 23cdebd55988a87b9f716ca39e2141c44d10854e (patch) | |
tree | d713a66e5362c6297d96968372784ac3c20d2e47 /src | |
parent | fd740a383ae0839b6b50c21639fceae6bc375066 (diff) | |
download | rneovim-23cdebd55988a87b9f716ca39e2141c44d10854e.tar.gz rneovim-23cdebd55988a87b9f716ca39e2141c44d10854e.tar.bz2 rneovim-23cdebd55988a87b9f716ca39e2141c44d10854e.zip |
rstream: Fix read_cb invocation
- Add missing call when the stream is a file
- NULL check because it is possible to call rstream_start with the callback set
to NULL.
Diffstat (limited to 'src')
-rw-r--r-- | src/nvim/event/rstream.c | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/src/nvim/event/rstream.c b/src/nvim/event/rstream.c index 78c044347f..9d2439ac2b 100644 --- a/src/nvim/event/rstream.c +++ b/src/nvim/event/rstream.c @@ -112,7 +112,7 @@ static void read_cb(uv_stream_t *uvstream, ssize_t cnt, const uv_buf_t *buf) // Read error or EOF, either way stop the stream and invoke the callback // with eof == true uv_read_stop(uvstream); - stream->read_cb(stream, stream->buffer, stream->data, true); + invoke_read_cb(stream, true); } return; } @@ -122,7 +122,7 @@ static void read_cb(uv_stream_t *uvstream, ssize_t cnt, const uv_buf_t *buf) // Data was already written, so all we need is to update 'wpos' to reflect // the space actually used in the buffer. rbuffer_produced(stream->buffer, nread); - stream->read_cb(stream, stream->buffer, stream->data, false); + invoke_read_cb(stream, false); } // Called by the by the 'idle' handle to emulate a reading event @@ -156,7 +156,7 @@ static void fread_idle_cb(uv_idle_t *handle) if (req.result <= 0) { uv_idle_stop(&stream->uv.idle); - stream->read_cb(stream, stream->buffer, stream->data, true); + invoke_read_cb(stream, true); return; } @@ -164,4 +164,12 @@ static void fread_idle_cb(uv_idle_t *handle) size_t nread = (size_t) req.result; rbuffer_produced(stream->buffer, nread); stream->fpos += nread; + invoke_read_cb(stream, false); +} + +static void invoke_read_cb(Stream *stream, bool eof) +{ + if (stream->read_cb) { + stream->read_cb(stream, stream->buffer, stream->data, eof); + } } |