D19696: Add blender thumbnailer

Stefan BrĂ¼ns noreply at phabricator.kde.org
Tue Mar 12 16:12:06 GMT 2019


bruns requested changes to this revision.
bruns added inline comments.
This revision now requires changes to proceed.

INLINE COMMENTS

> blendercreator.cpp:57
> +    QPointer<KCompressionDevice> gzFile;
> +    if(file.peek(2).startsWith("\x1F\x8B")) { // gzip magic (each gzip member starts with ID1(0x1f) and ID2(0x8b))
> +        file.close();

I think this is already done by the calling code - the thumbnailer gets only called when the mimetype matches.

> blendercreator.cpp:62
> +            blendStream.setDevice(gzFile);
> +        }
> +    }

`} else {` ...?

> blendercreator.cpp:73
> +
> +    // Example header: "BLENDER-257"
> +

This is missing the 'v' / 'V'

> blendercreator.cpp:98
> +    }
> +    const qint32 REND = isLittleEndian ? 1145980242 /*python int.from_bytes(b'REND', byteorder='little')*/ : 1380273732;
> +    const qint32 TEST = isLittleEndian ? 1414743380 : 1413829460;

When you write these as hex, it becomes more obvious one is "REND" while the other is "DNER". Although ...

> blendercreator.cpp:101
> +    const bool is64Bit = head[7] == '-';
> +    const int fileBlockHeadSize = is64Bit ? 24 : 20; // sum(1 through 6)
> +    const int remainingHeader = fileBlockHeadSize - 8; // sum(3 through 5)

Does this mean 'size of header fields 1 to 5'?

> blendercreator.cpp:105
> +    while (true) {
> +        blendStream >>  code >> length;
> +        if (code == REND) {

... you can use `readRawData(data, 4)` here and just compare with 'REND'.

Or even always read the whole header, saving you the `skipRawData(remainingHeader)`, and gets rid of `remainingHeader`.

Actually, using `operator>>` on raw data, i.e. anything not written using QDataStream is dangerous. There is **no** guarantee an int is serialized as just 4 bytes.

REPOSITORY
  R320 KIO Extras

REVISION DETAIL
  https://phabricator.kde.org/D19696

To: chinmoyr, #frameworks, bruns
Cc: bruns, ngraham, broulik, ltoscano, kde-frameworks-devel, kfm-devel, alexde, feverfew, michaelh, spoorun, navarromorales, firef, andrebarros, emmanuelp, mikesomov
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/kde-frameworks-devel/attachments/20190312/d8fa5038/attachment-0001.html>


More information about the Kde-frameworks-devel mailing list