2016-08-27 17:56:23 -04:00
|
|
|
#include "retroshare/rsids.h"
|
|
|
|
#include "serialiser/rsbaseserial.h"
|
2016-08-09 09:07:02 -04:00
|
|
|
#include "filelist_io.h"
|
|
|
|
|
2016-08-27 17:56:23 -04:00
|
|
|
template<> bool FileListIO::serialise(unsigned char *buff,uint32_t size,uint32_t& offset,const uint32_t & val) { return setRawUInt32(buff,size,&offset,val) ; }
|
|
|
|
template<> bool FileListIO::serialise(unsigned char *buff,uint32_t size,uint32_t& offset,const size_t & val) { return setRawUInt64(buff,size,&offset,val) ; }
|
|
|
|
template<> bool FileListIO::serialise(unsigned char *buff,uint32_t size,uint32_t& offset,const std::string & val) { return setRawString(buff,size,&offset,val) ; }
|
|
|
|
template<> bool FileListIO::serialise(unsigned char *buff,uint32_t size,uint32_t& offset,const Sha1CheckSum & val) { return val.serialise(buff,size,offset) ; }
|
|
|
|
|
|
|
|
template<> bool FileListIO::deserialise(const unsigned char *buff,uint32_t size,uint32_t& offset,uint32_t & val) { return getRawUInt32(const_cast<uint8_t*>(buff),size,&offset,&val) ; }
|
|
|
|
template<> bool FileListIO::deserialise(const unsigned char *buff,uint32_t size,uint32_t& offset,size_t & val) { return getRawUInt64(const_cast<uint8_t*>(buff),size,&offset,&val) ; }
|
|
|
|
template<> bool FileListIO::deserialise(const unsigned char *buff,uint32_t size,uint32_t& offset,std::string & val) { return getRawString(const_cast<uint8_t*>(buff),size,&offset,val) ; }
|
|
|
|
template<> bool FileListIO::deserialise(const unsigned char *buff,uint32_t size,uint32_t& offset,Sha1CheckSum & val) { return val.deserialise(const_cast<uint8_t*>(buff),size,offset) ; }
|
|
|
|
|
|
|
|
template<> uint32_t FileListIO::serial_size(const uint32_t & ) { return 4 ; }
|
|
|
|
template<> uint32_t FileListIO::serial_size(const size_t & ) { return 8 ; }
|
|
|
|
template<> uint32_t FileListIO::serial_size(const std::string & val) { return getRawStringSize(val) ; }
|
|
|
|
template<> uint32_t FileListIO::serial_size(const Sha1CheckSum & ) { return Sha1CheckSum::serial_size(); }
|
|
|
|
|
2016-08-12 09:20:23 -04:00
|
|
|
bool FileListIO::writeField( unsigned char*&buff,uint32_t& buff_size,uint32_t& offset,uint8_t section_tag,const unsigned char * val,uint32_t size)
|
|
|
|
{
|
|
|
|
if(!checkSectionSize(buff,buff_size,offset,size))
|
|
|
|
return false;
|
|
|
|
|
2016-08-27 17:56:23 -04:00
|
|
|
if(!writeSectionHeader(buff,buff_size,offset,section_tag,size))
|
2016-08-12 09:20:23 -04:00
|
|
|
return false;
|
|
|
|
|
|
|
|
memcpy(&buff[offset],val,size) ;
|
|
|
|
offset += size ;
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool FileListIO::readField (const unsigned char *buff,uint32_t buff_size,uint32_t& offset,uint8_t check_section_tag, unsigned char *& val,uint32_t& size)
|
|
|
|
{
|
2016-08-27 17:56:23 -04:00
|
|
|
if(!readSectionHeader(buff,buff_size,offset,check_section_tag,size))
|
2016-08-12 09:20:23 -04:00
|
|
|
return false;
|
|
|
|
|
|
|
|
val = (unsigned char *)rs_malloc(size) ;
|
|
|
|
|
|
|
|
if(!val)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
memcpy(val,&buff[offset],size);
|
|
|
|
offset += size ;
|
|
|
|
|
|
|
|
return true ;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool FileListIO::write125Size(unsigned char *data,uint32_t data_size,uint32_t& offset,uint32_t S)
|
|
|
|
{
|
|
|
|
if(S < 192)
|
|
|
|
{
|
|
|
|
if(offset+1 > data_size)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
data[offset++] = (uint8_t)S ;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
else if(S < 8384)
|
|
|
|
{
|
|
|
|
if(offset+2 > data_size)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
data[offset++] = (uint8_t)((S >> 8) + 192) ;
|
|
|
|
data[offset++] = (uint8_t)((S & 255) - 192) ;
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if(offset+5 > data_size)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
data[offset++] = 0xff ;
|
|
|
|
data[offset++] = (uint8_t)((S >> 24) & 255) ;
|
|
|
|
data[offset++] = (uint8_t)((S >> 16) & 255) ;
|
|
|
|
data[offset++] = (uint8_t)((S >> 8) & 255) ;
|
|
|
|
data[offset++] = (uint8_t)((S ) & 255) ;
|
|
|
|
|
|
|
|
return true ;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bool FileListIO::read125Size(const unsigned char *data,uint32_t data_size,uint32_t& offset,uint32_t& S)
|
|
|
|
{
|
|
|
|
if(offset + 1 >= data_size) return false;
|
|
|
|
|
|
|
|
uint8_t b1 = data[offset++] ;
|
|
|
|
|
|
|
|
if(b1 < 192)
|
|
|
|
{
|
|
|
|
S = b1;
|
|
|
|
return true ;
|
|
|
|
}
|
|
|
|
if(offset + 1 >= data_size) return false;
|
|
|
|
|
|
|
|
uint8_t b2 = data[offset++] ;
|
|
|
|
|
|
|
|
if(b1 < 224)
|
|
|
|
{
|
|
|
|
S = ((b1-192) << 8) + b2 + 192 ;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(b1 != 0xff)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
if(offset + 3 >= data_size) return false;
|
|
|
|
|
|
|
|
uint8_t b3 = data[offset++];
|
|
|
|
uint8_t b4 = data[offset++];
|
|
|
|
uint8_t b5 = data[offset++];
|
|
|
|
|
|
|
|
S = (b2 << 24) | (b3 << 16) | (b4 << 8) | b5 ;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|