| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 | // Definitions for the Interchange File Format (IFF)// Alexander Gessler, 2006// Adapted to Assimp August 2008#ifndef AI_IFF_H_INCLUDED#define AI_IFF_H_INCLUDED#include <assimp/ByteSwapper.h>namespace Assimp    {namespace IFF       {///////////////////////////////////////////////////////////////////////////////////! Describes an IFF chunk header/////////////////////////////////////////////////////////////////////////////////struct ChunkHeader{    //! Type of the chunk header - FourCC    uint32_t type;    //! Length of the chunk data, in bytes    uint32_t length;};///////////////////////////////////////////////////////////////////////////////////! Describes an IFF sub chunk header/////////////////////////////////////////////////////////////////////////////////struct SubChunkHeader{    //! Type of the chunk header - FourCC    uint32_t type;    //! Length of the chunk data, in bytes    uint16_t length;};#define AI_IFF_FOURCC(a,b,c,d) ((uint32_t) (((uint8_t)a << 24u) | \    ((uint8_t)b << 16u) | ((uint8_t)c << 8u) | ((uint8_t)d)))#define AI_IFF_FOURCC_FORM AI_IFF_FOURCC('F','O','R','M')///////////////////////////////////////////////////////////////////////////////////! Load a chunk header//! @param outFile Pointer to the file data - points to the chunk data afterwards//! @return Copy of the chunk header/////////////////////////////////////////////////////////////////////////////////inline ChunkHeader LoadChunk(uint8_t*& outFile){    ChunkHeader head;    ::memcpy(&head.type, outFile, 4);    outFile += 4;    ::memcpy(&head.length, outFile, 4);    outFile += 4;    AI_LSWAP4(head.length);    AI_LSWAP4(head.type);    return head;}///////////////////////////////////////////////////////////////////////////////////! Load a sub chunk header//! @param outFile Pointer to the file data - points to the chunk data afterwards//! @return Copy of the sub chunk header/////////////////////////////////////////////////////////////////////////////////inline SubChunkHeader LoadSubChunk(uint8_t*& outFile){    SubChunkHeader head;    ::memcpy(&head.type, outFile, 4);    outFile += 4;    ::memcpy(&head.length, outFile, 2);    outFile += 2;    AI_LSWAP2(head.length);    AI_LSWAP4(head.type);    return head;}///////////////////////////////////////////////////////////////////////////////////! Read the file header and return the type of the file and its size//! @param outFile Pointer to the file data. The buffer must at//!   least be 12 bytes large.//! @param fileType Receives the type of the file//! @return 0 if everything was OK, otherwise an error message/////////////////////////////////////////////////////////////////////////////////inline const char* ReadHeader(uint8_t* outFile, uint32_t& fileType){    ChunkHeader head = LoadChunk(outFile);    if(AI_IFF_FOURCC_FORM != head.type)    {        return "The file is not an IFF file: FORM chunk is missing";    }    ::memcpy(&fileType, outFile, 4);    AI_LSWAP4(fileType);    return 0;}}}#endif // !! AI_IFF_H_INCLUDED
 |