diff options
| author | cah <cah@ableton.com> | 2022-12-17 00:45:43 +0100 |
|---|---|---|
| committer | cah <cah@ableton.com> | 2022-12-17 00:45:43 +0100 |
| commit | a2bf097a15f69121bbcbc4be25e1ae3c940005b0 (patch) | |
| tree | 371106fc25e3bbbd63149f5ae9b1a0c59a618369 /src/JP2K_Codestream_Parser.cpp | |
| parent | bd5b66350bb7325cc8874fc02dfec5667ade0a24 (diff) | |
Add OpenReadFrame passing some raw memory buffer.
Diffstat (limited to 'src/JP2K_Codestream_Parser.cpp')
| -rwxr-xr-x | src/JP2K_Codestream_Parser.cpp | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/src/JP2K_Codestream_Parser.cpp b/src/JP2K_Codestream_Parser.cpp index d68b52a..cbaf9b8 100755 --- a/src/JP2K_Codestream_Parser.cpp +++ b/src/JP2K_Codestream_Parser.cpp @@ -90,6 +90,26 @@ public: return result; } + + Result_t OpenReadFrame(const void* data, unsigned int size, FrameBuffer& FB) + { + if ( FB.Capacity() < size ) + { + DefaultLogSink().Error("FrameBuf.Capacity: %u frame length: %u\n", FB.Capacity(), (ui32_t)size); + return RESULT_SMALLBUF; + } + + memcpy(FB.Data(), data, size); + FB.Size(size); + + byte_t start_of_data = 0; // out param + const Result_t result = ParseMetadataIntoDesc(FB, m_PDesc, &start_of_data); + + if ( ASDCP_SUCCESS(result) ) + FB.PlaintextOffset(start_of_data); + + return result; + } }; ASDCP::Result_t @@ -271,6 +291,13 @@ ASDCP::JP2K::CodestreamParser::OpenReadFrame(const std::string& filename, FrameB return m_Parser->OpenReadFrame(filename, FB); } +ASDCP::Result_t +ASDCP::JP2K::CodestreamParser::OpenReadFrame(const void* data, int size, FrameBuffer& FB) const +{ + const_cast<ASDCP::JP2K::CodestreamParser*>(this)->m_Parser = new h__CodestreamParser; + return m_Parser->OpenReadFrame(data, size, FB); +} + // ASDCP::Result_t ASDCP::JP2K::CodestreamParser::FillPictureDescriptor(PictureDescriptor& PDesc) const |
