Review Request: [PATCH] Make the FTP ioslave emit mime-type of the content before actually reading it

David Faure faure at kde.org
Mon Apr 18 17:51:47 BST 2011



> On April 18, 2011, 12:43 p.m., David Faure wrote:
> > kioslave/ftp/ftp.cpp, line 1766
> > <http://git.reviewboard.kde.org/r/101149/diff/1/?file=14721#file14721line1766>
> >
> >     Maybe this should be "while we haven't read 1024 bytes", but of course the file could be smaller than that so it would have to check for that too.
> >     
> >     What I mean is: I assume peek() doesn't wait, so if the first packet we get is 48 bytes, we have only 48 bytes. Don't know if this is a real problem in practice though, feel free to ignore this comment.
> 
> Dawit Alemayehu wrote:
>     No actually that is a good point. Perhaps a good compromise would be to wait for the 1024 bytes whenever the size of the content to be retrieved is known to be larger than 1024 bytes ? That way for the large enough files, we have a better success of getting a more accurate mime-type and for the others well we do the best we can. :) I will see what I can do about it. For the record, I did test this change with a small enough file, ftp://ftp.kde.org/pub/kde/README_UPLOAD, which happens to be only 404 bytes. Here is the log:
>     
>     kio_ftp(2902) Ftp::copy: ftp "/pub/kde/README_UPLOAD" -> local file "/tmp/kde-dalemayehu/konqueroraj1566"
>     kio_ftp(2902) Ftp::ftpDataMode: want I has ^@
>     kio_ftp(2902) Ftp::ftpSendCmd: send>  TYPE I
>     kio_ftp(2902) Ftp::ftpResponse:     >  200 Switching to Binary mode.
>     kio_ftp(2902) Ftp::ftpResponse: resp>  200 Switching to Binary mode.
>     kio_ftp(2902) Ftp::ftpSendCmd: send>  SIZE /pub/kde/README_UPLOAD
>     kio_ftp(2902) Ftp::ftpResponse:     >  213 404
>     kio_ftp(2902) Ftp::ftpResponse: resp>  213 404
>     kio_ftp(2902) Ftp::ftpDataMode: want I has I
>     kio_ftp(2902) Ftp::ftpSendCmd: send>  PASV
>     kio_ftp(2902) Ftp::ftpResponse:     >  227 Entering Passive Mode (131,220,16,1,22,193).
>     kio_ftp(2902) Ftp::ftpResponse: resp>  227 Entering Passive Mode (131,220,16,1,22,193).
>     kio_ftp(2902) Ftp::ftpOpenPASVDataConnection: Connecting to  "131.220.16.1"  port  5825
>     kio_ftp(2902) Ftp::ftpSendCmd: send>  retr /pub/kde/README_UPLOAD
>     kio_ftp(2902) Ftp::ftpResponse:     >  150 Opening BINARY mode data connection for /pub/kde/README_UPLOAD (404 bytes).
>     kio_ftp(2902) Ftp::ftpResponse: resp>  150 Opening BINARY mode data connection for /pub/kde/README_UPLOAD (404 bytes).
>     kio_ftp(2902) Ftp::ftpOpenCommand: connected with remote.
>     kio_ftp(2902) Ftp::ftpGet: ftpGet: Emitting mimetype  "text/x-readme"
>     kio_ftp(2902) Ftp::ftpGet: ftpGet: starting with offset= 0
>     kio_ftp(2902) Ftp::ftpGet: ftpGet: done
>     
>     I will see what I can do about improving the code as suggested...
>

Yes, but careful with the case where the size is still "unknown" (I suppose it can happen).


- David


-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
http://git.reviewboard.kde.org/r/101149/#review2723
-----------------------------------------------------------


On April 18, 2011, 2:12 a.m., Dawit Alemayehu wrote:
> 
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> http://git.reviewboard.kde.org/r/101149/
> -----------------------------------------------------------
> 
> (Updated April 18, 2011, 2:12 a.m.)
> 
> 
> Review request for kdelibs and David Faure.
> 
> 
> Summary
> -------
> 
> The attached patch changes the ftpGet function such that it emits the mime-type of the content it is about to read, before starting to read it. That way kio_ftp will work correctly if and when it is put on hold to be reused from another application. Note that the patch uses QIODevice::peek to achieve this goal.
> 
> 
> Diffs
> -----
> 
>   kioslave/ftp/ftp.cpp 64f43d8 
> 
> Diff: http://git.reviewboard.kde.org/r/101149/diff
> 
> 
> Testing
> -------
> 
> 
> Thanks,
> 
> Dawit
> 
>

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/kde-core-devel/attachments/20110418/ba5ab03b/attachment.htm>


More information about the kde-core-devel mailing list