CmMemorySerializer.cpp 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. #include "CmMemorySerializer.h"
  2. #include "CmException.h"
  3. #include "CmIReflectable.h"
  4. #include "CmBinarySerializer.h"
  5. using namespace std::placeholders;
  6. namespace CamelotFramework
  7. {
  8. MemorySerializer::MemorySerializer()
  9. { }
  10. MemorySerializer::~MemorySerializer()
  11. { }
  12. UINT8* MemorySerializer::encode(IReflectable* object, UINT32& bytesWritten, std::function<void*(UINT32)> allocator)
  13. {
  14. using namespace std::placeholders;
  15. BinarySerializer bs;
  16. BufferPiece piece;
  17. piece.buffer = (UINT8*)stackAlloc(WRITE_BUFFER_SIZE);
  18. piece.size = 0;
  19. mBufferPieces.push_back(piece);
  20. bs.encode(object, piece.buffer, WRITE_BUFFER_SIZE, (INT32*)&bytesWritten, std::bind(&MemorySerializer::flushBuffer, this, _1, _2, _3));
  21. UINT8* resultBuffer;
  22. if(allocator != nullptr)
  23. resultBuffer = (UINT8*)allocator(bytesWritten);
  24. else
  25. resultBuffer = (UINT8*)cm_alloc(bytesWritten);
  26. UINT32 offset = 0;
  27. for(auto iter = mBufferPieces.begin(); iter != mBufferPieces.end(); ++iter)
  28. {
  29. if(iter->size > 0)
  30. {
  31. memcpy(resultBuffer + offset, iter->buffer, iter->size);
  32. offset += iter->size;
  33. }
  34. }
  35. for(auto iter = mBufferPieces.rbegin(); iter != mBufferPieces.rend(); ++iter)
  36. {
  37. stackDeallocLast(iter->buffer);
  38. }
  39. return resultBuffer;
  40. }
  41. std::shared_ptr<IReflectable> MemorySerializer::decode(UINT8* buffer, UINT32 bufferSize)
  42. {
  43. BinarySerializer bs;
  44. std::shared_ptr<IReflectable> object = bs.decode(buffer, (UINT32)bufferSize);
  45. return object;
  46. }
  47. UINT8* MemorySerializer::flushBuffer(UINT8* bufferStart, int bytesWritten, UINT32& newBufferSize)
  48. {
  49. mBufferPieces.back().size = bytesWritten;
  50. BufferPiece piece;
  51. piece.buffer = (UINT8*)stackAlloc(WRITE_BUFFER_SIZE);
  52. piece.size = 0;
  53. mBufferPieces.push_back(piece);
  54. return piece.buffer;
  55. }
  56. }