Review Request 123514: Make it possible to treat non-sequential QIODevice asynchronously
Aleix Pol Gonzalez
aleixpol at kde.org
Wed Apr 29 16:28:03 UTC 2015
-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://git.reviewboard.kde.org/r/123514/
-----------------------------------------------------------
(Updated April 29, 2015, 6:28 p.m.)
Review request for KDE Frameworks and David Faure.
Changes
-------
Further polishing.
* Increase testing: Create 2 tests, one using QNAM and the other using KIO::AccessManager. This way we can check that the output is the same.
* Improve detection of end of stream by using QIODevice::read(char\*, length) instead of ::read(QByteArray). The former returns -1 when the stream ends.
* Use QIODevice::readChannelFinished signal instead of QIODevice::aboutToClose.
Repository: kio
Description
-------
So far, we used to just read whenever some data was required. This works on sequential devices because the data is already available. This is not the case when we have a sequential device, such as a socket, where data arrives when it arrives. This will also prove useful on non-sequential devices as well when we want to keep reading in case new data appears.
This patch takes the AsyncDataEnabled setting on accordinly by:
* only reading from the device when readyRead is available.
* finishes the transfer whenever the device is closed.
Diffs (updated)
-----
src/core/transferjob.h e2fd2e7
src/core/job_p.h 7ec1a69
autotests/jobtest.cpp 327470a
autotests/jobtest.h 5ccd492
autotests/accessmanagertest.cpp 5d52553
autotests/CMakeLists.txt 7bba3ea
src/core/transferjob.cpp 97a724e
src/widgets/accessmanager.cpp b4ec811
Diff: https://git.reviewboard.kde.org/r/123514/diff/
Testing
-------
Tests still pass, new test also passes.
The test is using lambdas to delay write. I don't think it's available.
Can I add some kind of #if HAS_LAMBDA and make the test depend on it?
I don't think adding slots and make the buffer an attribute would be very nice... I can also sub-class the buffer.
Thanks,
Aleix Pol Gonzalez
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/kde-frameworks-devel/attachments/20150429/a0375004/attachment-0001.html>
More information about the Kde-frameworks-devel
mailing list