Always call `Done` on the WriteWrap, and ensure that `EncOut` will
consume all data in clear_in_ and invoke queued callbacks.
Fix: https://github.com/iojs/io.js/issues/1075
PR-URL: https://github.com/iojs/io.js/pull/1244
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
MakePending();
// And destroy
- while (WriteItem* wi = pending_write_items_.PopFront())
- delete wi;
+ InvokeQueued(UV_ECANCELED);
ClearError();
}
write_req->Dispatched();
// Ignore errors, this should be already handled in js
- if (err)
+ if (err) {
write_req->Dispose();
- else
+ InvokeQueued(err);
+ } else {
NODE_COUNT_NET_BYTES_SENT(write_size_);
+ }
}
// Commit
NodeBIO::FromBIO(wrap->enc_out_)->Read(nullptr, wrap->write_size_);
+ // Ensure that the progress will be made and `InvokeQueued` will be called.
+ wrap->ClearIn();
+
// Try writing more data
wrap->write_size_ = 0;
wrap->EncOut();