include/vcl/BinaryDataContainer.hxx           |   47 +++------
 include/vcl/filter/PngImageReader.hxx         |    5 
 include/vcl/gfxlink.hxx                       |    2 
 include/vcl/graphicfilter.hxx                 |    5 
 include/vcl/vectorgraphicdata.hxx             |    2 
 sd/source/ui/view/sdview3.cxx                 |    7 -
 svx/source/xoutdev/_xoutbmp.cxx               |    3 
 vcl/inc/pdf/ExternalPDFStreams.hxx            |    6 -
 vcl/qa/cppunit/BinaryDataContainerTest.cxx    |   33 ++----
 vcl/qa/cppunit/svm/svmtest.cxx                |   10 -
 vcl/source/filter/graphicfilter.cxx           |  132 ++++++++------------------
 vcl/source/filter/ieps/ieps.cxx               |   58 ++++-------
 vcl/source/filter/ipdf/pdfcompat.cxx          |    6 -
 vcl/source/filter/png/PngImageReader.cxx      |   31 ++----
 vcl/source/filter/wmf/wmf.cxx                 |    4 
 vcl/source/gdi/TypeSerializer.cxx             |   13 --
 vcl/source/gdi/gfxlink.cxx                    |   10 -
 vcl/source/gdi/impgraph.cxx                   |    9 -
 vcl/source/gdi/vectorgraphicdata.cxx          |   13 --
 vcl/source/graphic/BinaryDataContainer.cxx    |   67 +++++++++++--
 vcl/source/graphic/UnoBinaryDataContainer.cxx |   11 --
 21 files changed, 197 insertions(+), 277 deletions(-)

New commits:
commit 4b0bdda5be8a8c910190dd448a8e9c77f60b7359
Author:     Michael Meeks <michael.me...@collabora.com>
AuthorDate: Sat Apr 1 16:10:33 2023 +0100
Commit:     Michael Meeks <michael.me...@collabora.com>
CommitDate: Sat Apr 1 21:10:04 2023 +0100

    BinaryDataContainer: hand out shared_ptr's to SvStreams.
    
    Hide the SvMemoryStream implementation detail better - this
    could be served from a file in future. Also couple lifecycle
    of the SvMemoryStream to the vector backing it.
    
    Change-Id: Ia9b28b57b8df4ce57286effd4d1753bf345fc10e

diff --git a/include/vcl/BinaryDataContainer.hxx 
b/include/vcl/BinaryDataContainer.hxx
index e91ca82c7728..78cb52d05f8a 100644
--- a/include/vcl/BinaryDataContainer.hxx
+++ b/include/vcl/BinaryDataContainer.hxx
@@ -47,8 +47,10 @@ public:
     const sal_uInt8* getData() const;
     css::uno::Sequence<sal_Int8> getAsSequence() const;
 
-    // Returns the data as a stream open for reading
-    SvMemoryStream getMemoryStream();
+    // Returns the data as a readonly stream open for reading
+    std::shared_ptr<SvStream> getAsStream();
+
+    /// writes the contents to the given stream
     std::size_t writeToStream(SvStream &rStream) const;
 
     size_t calculateHash() const;
diff --git a/vcl/inc/pdf/ExternalPDFStreams.hxx 
b/vcl/inc/pdf/ExternalPDFStreams.hxx
index e2ddd58b91a5..b2936f01a898 100644
--- a/vcl/inc/pdf/ExternalPDFStreams.hxx
+++ b/vcl/inc/pdf/ExternalPDFStreams.hxx
@@ -38,9 +38,9 @@ struct VCL_DLLPUBLIC ExternalPDFStream
     {
         if (!mpPDFDocument)
         {
-            SvMemoryStream aPDFStream = maDataContainer.getMemoryStream();
+            std::shared_ptr<SvStream> aPDFStream = 
maDataContainer.getAsStream();
             auto pPDFDocument = std::make_shared<filter::PDFDocument>();
-            if (!pPDFDocument->ReadWithPossibleFixup(aPDFStream))
+            if (!pPDFDocument->ReadWithPossibleFixup(*aPDFStream))
             {
                 SAL_WARN("vcl.pdfwriter",
                          "PDFWriterImpl::writeReferenceXObject: reading the 
PDF document failed");
diff --git a/vcl/source/filter/graphicfilter.cxx 
b/vcl/source/filter/graphicfilter.cxx
index 80b9491da6d4..6160493c3ec0 100644
--- a/vcl/source/filter/graphicfilter.cxx
+++ b/vcl/source/filter/graphicfilter.cxx
@@ -914,8 +914,8 @@ Graphic GraphicFilter::ImportUnloadedGraphic(SvStream& 
rIStream, sal_uInt64 size
             Size aLogicSize;
             if (eLinkType == GfxLinkType::NativeGif)
             {
-                SvMemoryStream 
aMemoryStream(aGraphicContent.getMemoryStream());
-                bAnimated = IsGIFAnimated(aMemoryStream, aLogicSize);
+                std::shared_ptr<SvStream> pMemoryStream = 
aGraphicContent.getAsStream();
+                bAnimated = IsGIFAnimated(*pMemoryStream, aLogicSize);
                 if (!pSizeHint && aLogicSize.getWidth() && 
aLogicSize.getHeight())
                 {
                     pSizeHint = &aLogicSize;
@@ -954,8 +954,8 @@ ErrCode GraphicFilter::readPNG(SvStream & rStream, Graphic 
& rGraphic, GfxLinkTy
     if (auto aMSGifChunk = vcl::PngImageReader::getMicrosoftGifChunk(rStream);
         !aMSGifChunk.isEmpty())
     {
-        SvMemoryStream aIStrm(aMSGifChunk.getMemoryStream());
-        ImportGIF(aIStrm, rGraphic);
+        std::shared_ptr<SvStream> pIStrm(aMSGifChunk.getAsStream());
+        ImportGIF(*pIStrm, rGraphic);
         rLinkType = GfxLinkType::NativeGif;
         rpGraphicContent = aMSGifChunk;
         return aReturnCode;
diff --git a/vcl/source/graphic/BinaryDataContainer.cxx 
b/vcl/source/graphic/BinaryDataContainer.cxx
index aa5a10b445a3..c0992421223f 100644
--- a/vcl/source/graphic/BinaryDataContainer.cxx
+++ b/vcl/source/graphic/BinaryDataContainer.cxx
@@ -39,9 +39,24 @@ css::uno::Sequence<sal_Int8> 
BinaryDataContainer::getAsSequence() const
     return aData;
 }
 
-SvMemoryStream BinaryDataContainer::getMemoryStream()
+/*
+ * Hold a reference on the internal state in case we swap out
+ * while someone holds an SvStream pointer.
+ */
+class ReferencedMemoryStream : public SvMemoryStream
+{
+    std::shared_ptr<std::vector<sal_uInt8>> mpData;
+public:
+    ReferencedMemoryStream(const std::shared_ptr<std::vector<sal_uInt8>> 
&rData)
+        : SvMemoryStream(rData ? rData->data() : nullptr, rData->size(), 
StreamMode::READ),
+          mpData(rData)
+    {
+    }
+};
+
+std::shared_ptr<SvStream> BinaryDataContainer::getAsStream()
 {
-    return SvMemoryStream(mpData ? mpData->data() : nullptr, getSize(), 
StreamMode::READ);
+    return std::make_shared<ReferencedMemoryStream>(mpData);
 }
 
 std::size_t BinaryDataContainer::writeToStream(SvStream &rStream) const
commit 16fb9c6d7241e09a269923a1e06e03bb86e3a6b3
Author:     Michael Meeks <michael.me...@collabora.com>
AuthorDate: Sat Apr 1 15:06:30 2023 +0100
Commit:     Michael Meeks <michael.me...@collabora.com>
CommitDate: Sat Apr 1 21:10:04 2023 +0100

    BinaryDataContainer: pure re-factor - encapsulate cbegin/cend
    
    Change-Id: Ic8dbf0afdb96a0f1be210eedfbd12ef6467dd29f

diff --git a/include/vcl/BinaryDataContainer.hxx 
b/include/vcl/BinaryDataContainer.hxx
index fbde5fa846a9..e91ca82c7728 100644
--- a/include/vcl/BinaryDataContainer.hxx
+++ b/include/vcl/BinaryDataContainer.hxx
@@ -12,6 +12,7 @@
 
 #include <sal/config.h>
 
+#include <com/sun/star/uno/Sequence.hxx>
 #include <tools/stream.hxx>
 #include <vcl/dllapi.h>
 
@@ -44,15 +45,13 @@ public:
     size_t getSize() const;
     bool isEmpty() const;
     const sal_uInt8* getData() const;
+    css::uno::Sequence<sal_Int8> getAsSequence() const;
 
     // Returns the data as a stream open for reading
     SvMemoryStream getMemoryStream();
     std::size_t writeToStream(SvStream &rStream) const;
 
     size_t calculateHash() const;
-
-    auto cbegin() const { return mpData->cbegin(); }
-    auto cend() const { return mpData->cend(); }
 };
 
 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/vcl/source/gdi/vectorgraphicdata.cxx 
b/vcl/source/gdi/vectorgraphicdata.cxx
index d2a0aa06a682..1abc1ce097d2 100644
--- a/vcl/source/gdi/vectorgraphicdata.cxx
+++ b/vcl/source/gdi/vectorgraphicdata.cxx
@@ -196,11 +196,9 @@ void VectorGraphicData::ensureSequenceAndRange()
     {
         case VectorGraphicDataType::Svg:
         {
-            css::uno::Sequence<sal_Int8> 
aDataSequence(maDataContainer.getSize());
-            std::copy(maDataContainer.cbegin(), maDataContainer.cend(), 
aDataSequence.getArray());
+            css::uno::Sequence<sal_Int8> aDataSequence = 
maDataContainer.getAsSequence();
             const uno::Reference<io::XInputStream> xInputStream(new 
comphelper::SequenceInputStream(aDataSequence));
 
-
             const uno::Reference< graphic::XSvgParser > xSvgParser = 
graphic::SvgTools::create(xContext);
 
             if (xInputStream.is())
@@ -213,8 +211,7 @@ void VectorGraphicData::ensureSequenceAndRange()
         {
             const uno::Reference< graphic::XEmfParser > xEmfParser = 
graphic::EmfTools::create(xContext);
 
-            css::uno::Sequence<sal_Int8> 
aDataSequence(maDataContainer.getSize());
-            std::copy(maDataContainer.cbegin(), maDataContainer.cend(), 
aDataSequence.getArray());
+            css::uno::Sequence<sal_Int8> aDataSequence = 
maDataContainer.getAsSequence();
             const uno::Reference<io::XInputStream> xInputStream(new 
comphelper::SequenceInputStream(aDataSequence));
 
             if (xInputStream.is())
diff --git a/vcl/source/graphic/BinaryDataContainer.cxx 
b/vcl/source/graphic/BinaryDataContainer.cxx
index 8381d02ff622..aa5a10b445a3 100644
--- a/vcl/source/graphic/BinaryDataContainer.cxx
+++ b/vcl/source/graphic/BinaryDataContainer.cxx
@@ -27,6 +27,18 @@ size_t BinaryDataContainer::calculateHash() const
     return nSeed;
 }
 
+css::uno::Sequence<sal_Int8> BinaryDataContainer::getAsSequence() const
+{
+    if (isEmpty())
+        return css::uno::Sequence<sal_Int8>();
+
+    css::uno::Sequence<sal_Int8> aData(getSize());
+
+    std::copy(mpData->cbegin(), mpData->cend(), aData.getArray());
+
+    return aData;
+}
+
 SvMemoryStream BinaryDataContainer::getMemoryStream()
 {
     return SvMemoryStream(mpData ? mpData->data() : nullptr, getSize(), 
StreamMode::READ);
diff --git a/vcl/source/graphic/UnoBinaryDataContainer.cxx 
b/vcl/source/graphic/UnoBinaryDataContainer.cxx
index 8ee3660be416..fd35ab222172 100644
--- a/vcl/source/graphic/UnoBinaryDataContainer.cxx
+++ b/vcl/source/graphic/UnoBinaryDataContainer.cxx
@@ -19,16 +19,7 @@ UNO3_GETIMPLEMENTATION_IMPL(UnoBinaryDataContainer);
 
 css::uno::Sequence<sal_Int8> SAL_CALL 
UnoBinaryDataContainer::getCopyAsByteSequence()
 {
-    if (maBinaryDataContainer.isEmpty())
-        return css::uno::Sequence<sal_Int8>();
-
-    size_t nSize = maBinaryDataContainer.getSize();
-
-    css::uno::Sequence<sal_Int8> aData(nSize);
-
-    std::copy(maBinaryDataContainer.cbegin(), maBinaryDataContainer.cend(), 
aData.getArray());
-
-    return aData;
+    return maBinaryDataContainer.getAsSequence();
 }
 
 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
commit 82d950239b7e0d346e6c40c27bb35825c362eca6
Author:     Michael Meeks <michael.me...@collabora.com>
AuthorDate: Sat Apr 1 12:40:58 2023 +0100
Commit:     Michael Meeks <michael.me...@collabora.com>
CommitDate: Sat Apr 1 21:10:04 2023 +0100

    BinaryDataContainer: pure re-factor to encapsulate stream copying.
    
    Change-Id: Iab24e8d18bf7badbca672fbdbf455f78d08f41a0

diff --git a/include/vcl/BinaryDataContainer.hxx 
b/include/vcl/BinaryDataContainer.hxx
index e6e13cd340d8..fbde5fa846a9 100644
--- a/include/vcl/BinaryDataContainer.hxx
+++ b/include/vcl/BinaryDataContainer.hxx
@@ -41,16 +41,17 @@ public:
 
     BinaryDataContainer& operator=(BinaryDataContainer&& rBinaryDataContainer) 
noexcept = default;
 
-    size_t getSize() const { return mpData ? mpData->size() : 0; }
-    bool isEmpty() const { return !mpData || mpData->empty(); }
-    const sal_uInt8* getData() const { return mpData ? mpData->data() : 
nullptr; }
+    size_t getSize() const;
+    bool isEmpty() const;
+    const sal_uInt8* getData() const;
+
     // Returns the data as a stream open for reading
     SvMemoryStream getMemoryStream();
+    std::size_t writeToStream(SvStream &rStream) const;
 
     size_t calculateHash() const;
 
     auto cbegin() const { return mpData->cbegin(); }
-
     auto cend() const { return mpData->cend(); }
 };
 
diff --git a/svx/source/xoutdev/_xoutbmp.cxx b/svx/source/xoutdev/_xoutbmp.cxx
index 7241fedfe043..df57f48ce555 100644
--- a/svx/source/xoutdev/_xoutbmp.cxx
+++ b/svx/source/xoutdev/_xoutbmp.cxx
@@ -156,8 +156,7 @@ ErrCode XOutBitmap::WriteGraphic( const Graphic& rGraphic, 
OUString& rFileName,
 
             if (pOStm)
             {
-                auto & rDataContainer = 
rVectorGraphicDataPtr->getBinaryDataContainer();
-                pOStm->WriteBytes(rDataContainer.getData(), 
rDataContainer.getSize());
+                
rVectorGraphicDataPtr->getBinaryDataContainer().writeToStream(*pOStm);
                 aMedium.Commit();
 
                 if (!aMedium.GetError())
diff --git a/vcl/inc/pdf/ExternalPDFStreams.hxx 
b/vcl/inc/pdf/ExternalPDFStreams.hxx
index 45b15f7a74bc..e2ddd58b91a5 100644
--- a/vcl/inc/pdf/ExternalPDFStreams.hxx
+++ b/vcl/inc/pdf/ExternalPDFStreams.hxx
@@ -38,9 +38,7 @@ struct VCL_DLLPUBLIC ExternalPDFStream
     {
         if (!mpPDFDocument)
         {
-            SvMemoryStream aPDFStream;
-            aPDFStream.WriteBytes(maDataContainer.getData(), 
maDataContainer.getSize());
-            aPDFStream.Seek(0);
+            SvMemoryStream aPDFStream = maDataContainer.getMemoryStream();
             auto pPDFDocument = std::make_shared<filter::PDFDocument>();
             if (!pPDFDocument->ReadWithPossibleFixup(aPDFStream))
             {
diff --git a/vcl/source/filter/graphicfilter.cxx 
b/vcl/source/filter/graphicfilter.cxx
index 47aa98853e30..80b9491da6d4 100644
--- a/vcl/source/filter/graphicfilter.cxx
+++ b/vcl/source/filter/graphicfilter.cxx
@@ -1632,9 +1632,7 @@ ErrCode GraphicFilter::ExportGraphic( const Graphic& 
rGraphic, std::u16string_vi
                     && 
!rVectorGraphicDataPtr->getBinaryDataContainer().isEmpty()
                     && !bIsEMF)
                 {
-                    auto & aDataContainer = 
rVectorGraphicDataPtr->getBinaryDataContainer();
-                    rTempStm->WriteBytes(aDataContainer.getData(), 
aDataContainer.getSize());
-
+                    
rVectorGraphicDataPtr->getBinaryDataContainer().writeToStream(*rTempStm);
                     if (rTempStm->GetError())
                     {
                         nStatus = ERRCODE_GRFILTER_IOERROR;
@@ -1673,9 +1671,7 @@ ErrCode GraphicFilter::ExportGraphic( const Graphic& 
rGraphic, std::u16string_vi
                     && rVectorGraphicDataPtr->getType() == 
VectorGraphicDataType::Emf
                     && 
!rVectorGraphicDataPtr->getBinaryDataContainer().isEmpty())
                 {
-                    auto & aDataContainer = 
rVectorGraphicDataPtr->getBinaryDataContainer();
-                    rTempStm->WriteBytes(aDataContainer.getData(), 
aDataContainer.getSize());
-
+                    
rVectorGraphicDataPtr->getBinaryDataContainer().writeToStream(*rTempStm);
                     if (rTempStm->GetError())
                     {
                         nStatus = ERRCODE_GRFILTER_IOERROR;
@@ -1743,9 +1739,7 @@ ErrCode GraphicFilter::ExportGraphic( const Graphic& 
rGraphic, std::u16string_vi
                     && rVectorGraphicDataPtr->getType()  ==  
VectorGraphicDataType::Svg
                     && 
!rVectorGraphicDataPtr->getBinaryDataContainer().isEmpty())
                 {
-                    auto & aDataContainer = 
rVectorGraphicDataPtr->getBinaryDataContainer();
-                    rTempStm->WriteBytes(aDataContainer.getData(), 
aDataContainer.getSize());
-
+                    
rVectorGraphicDataPtr->getBinaryDataContainer().writeToStream(*rTempStm);
                     if( rTempStm->GetError() )
                     {
                         nStatus = ERRCODE_GRFILTER_IOERROR;
diff --git a/vcl/source/gdi/TypeSerializer.cxx 
b/vcl/source/gdi/TypeSerializer.cxx
index 83f77bed1379..0882f97243ad 100644
--- a/vcl/source/gdi/TypeSerializer.cxx
+++ b/vcl/source/gdi/TypeSerializer.cxx
@@ -387,8 +387,8 @@ void TypeSerializer::writeGraphic(const Graphic& rGraphic)
 
                     sal_uInt32 nSize = 
pVectorGraphicData->getBinaryDataContainer().getSize();
                     mrStream.WriteUInt32(nSize);
-                    
mrStream.WriteBytes(pVectorGraphicData->getBinaryDataContainer().getData(),
-                                        nSize);
+                    
pVectorGraphicData->getBinaryDataContainer().writeToStream(mrStream);
+
                     // For backwards compatibility, used to serialize path
                     mrStream.WriteUniOrByteString(u"", 
mrStream.GetStreamCharSet());
                 }
diff --git a/vcl/source/gdi/impgraph.cxx b/vcl/source/gdi/impgraph.cxx
index 79c87720bc2f..a4569f95e200 100644
--- a/vcl/source/gdi/impgraph.cxx
+++ b/vcl/source/gdi/impgraph.cxx
@@ -1230,10 +1230,7 @@ bool ImpGraphic::swapOutGraphic(SvStream& rStream)
                 }
 
                 
rStream.WriteUInt32(maVectorGraphicData->getBinaryDataContainer().getSize());
-
-                rStream.WriteBytes(
-                    maVectorGraphicData->getBinaryDataContainer().getData(),
-                    maVectorGraphicData->getBinaryDataContainer().getSize());
+                
maVectorGraphicData->getBinaryDataContainer().writeToStream(rStream);
             }
             else if (mpAnimation)
             {
diff --git a/vcl/source/graphic/BinaryDataContainer.cxx 
b/vcl/source/graphic/BinaryDataContainer.cxx
index af6e5968911c..8381d02ff622 100644
--- a/vcl/source/graphic/BinaryDataContainer.cxx
+++ b/vcl/source/graphic/BinaryDataContainer.cxx
@@ -32,4 +32,25 @@ SvMemoryStream BinaryDataContainer::getMemoryStream()
     return SvMemoryStream(mpData ? mpData->data() : nullptr, getSize(), 
StreamMode::READ);
 }
 
+std::size_t BinaryDataContainer::writeToStream(SvStream &rStream) const
+{
+    return rStream.WriteBytes(getData(), getSize());
+}
+
+size_t BinaryDataContainer::getSize() const
+{
+    return mpData ? mpData->size() : 0;
+}
+
+bool BinaryDataContainer::isEmpty() const
+{
+    return !mpData || mpData->empty();
+}
+
+const sal_uInt8* BinaryDataContainer::getData() const
+{
+    return mpData ? mpData->data() : nullptr;
+}
+
+
 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
commit 64fac5fb43ad00b57b0849b8d2d62e4daddd4521
Author:     Mike Kaganski <mike.kagan...@collabora.com>
AuthorDate: Wed Mar 8 02:14:11 2023 +0300
Commit:     Michael Meeks <michael.me...@collabora.com>
CommitDate: Sat Apr 1 21:10:04 2023 +0100

    Simplify usage of BinaryDataContainer
    
    It is always used to store data read from streams
    
    Change-Id: I613bc446eaadf98d2b1c012002d38f23d79a40ba
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/148450
    Tested-by: Jenkins
    Reviewed-by: Mike Kaganski <mike.kagan...@collabora.com>

diff --git a/include/vcl/BinaryDataContainer.hxx 
b/include/vcl/BinaryDataContainer.hxx
index b7421e9874c0..e6e13cd340d8 100644
--- a/include/vcl/BinaryDataContainer.hxx
+++ b/include/vcl/BinaryDataContainer.hxx
@@ -10,7 +10,11 @@
 
 #pragma once
 
+#include <sal/config.h>
+
+#include <tools/stream.hxx>
 #include <vcl/dllapi.h>
+
 #include <vector>
 #include <memory>
 
@@ -26,35 +30,22 @@ private:
     std::shared_ptr<std::vector<sal_uInt8>> mpData;
 
 public:
-    BinaryDataContainer();
-    BinaryDataContainer(const sal_uInt8* pData, size_t nSize);
-    BinaryDataContainer(std::unique_ptr<std::vector<sal_uInt8>> rData);
+    BinaryDataContainer() = default;
+    BinaryDataContainer(SvStream& stream, size_t size);
 
-    BinaryDataContainer(const BinaryDataContainer& rBinaryDataContainer)
-        : mpData(rBinaryDataContainer.mpData)
-    {
-    }
+    BinaryDataContainer(const BinaryDataContainer& rBinaryDataContainer) = 
default;
 
-    BinaryDataContainer(BinaryDataContainer&& rBinaryDataContainer) noexcept
-        : mpData(std::move(rBinaryDataContainer.mpData))
-    {
-    }
+    BinaryDataContainer(BinaryDataContainer&& rBinaryDataContainer) noexcept = 
default;
 
-    BinaryDataContainer& operator=(const BinaryDataContainer& 
rBinaryDataContainer)
-    {
-        mpData = rBinaryDataContainer.mpData;
-        return *this;
-    }
+    BinaryDataContainer& operator=(const BinaryDataContainer& 
rBinaryDataContainer) = default;
 
-    BinaryDataContainer& operator=(BinaryDataContainer&& rBinaryDataContainer) 
noexcept
-    {
-        mpData = std::move(rBinaryDataContainer.mpData);
-        return *this;
-    }
+    BinaryDataContainer& operator=(BinaryDataContainer&& rBinaryDataContainer) 
noexcept = default;
 
     size_t getSize() const { return mpData ? mpData->size() : 0; }
     bool isEmpty() const { return !mpData || mpData->empty(); }
     const sal_uInt8* getData() const { return mpData ? mpData->data() : 
nullptr; }
+    // Returns the data as a stream open for reading
+    SvMemoryStream getMemoryStream();
 
     size_t calculateHash() const;
 
diff --git a/include/vcl/filter/PngImageReader.hxx 
b/include/vcl/filter/PngImageReader.hxx
index bbb5b7c8d672..34b8279bc654 100644
--- a/include/vcl/filter/PngImageReader.hxx
+++ b/include/vcl/filter/PngImageReader.hxx
@@ -14,8 +14,10 @@
 #include <sal/config.h>
 
 #include <memory>
+#include <vector>
 
 #include <vcl/dllapi.h>
+#include <vcl/BinaryDataContainer.hxx>
 
 #include <com/sun/star/uno/Reference.hxx>
 
@@ -45,8 +47,7 @@ public:
 
     // Returns the contents of the msOG chunk (containing a Gif image), if it 
exists.
     // Does not change position in the stream.
-    static std::unique_ptr<sal_uInt8[]> getMicrosoftGifChunk(SvStream& rStream,
-                                                             sal_Int32* 
chunkSize = nullptr);
+    static BinaryDataContainer getMicrosoftGifChunk(SvStream& rStream);
 };
 
 } // namespace vcl
diff --git a/include/vcl/gfxlink.hxx b/include/vcl/gfxlink.hxx
index 852f418d7ef7..8c0f5fd32b05 100644
--- a/include/vcl/gfxlink.hxx
+++ b/include/vcl/gfxlink.hxx
@@ -24,7 +24,6 @@
 #include <vcl/dllapi.h>
 #include <vcl/mapmod.hxx>
 #include <vcl/BinaryDataContainer.hxx>
-#include <memory>
 
 class SvStream;
 
@@ -72,7 +71,6 @@ private:
 
 public:
     GfxLink();
-    explicit GfxLink(std::unique_ptr<sal_uInt8[]> pBuf, sal_uInt32 nBufSize, 
GfxLinkType nType);
     explicit GfxLink(BinaryDataContainer aDataConainer, GfxLinkType nType);
 
     bool                operator==( const GfxLink& ) const;
diff --git a/include/vcl/graphicfilter.hxx b/include/vcl/graphicfilter.hxx
index 787439773bc4..fd183b0e0bb3 100644
--- a/include/vcl/graphicfilter.hxx
+++ b/include/vcl/graphicfilter.hxx
@@ -25,6 +25,7 @@
 #include <vcl/graph.hxx>
 #include <comphelper/errcode.hxx>
 #include <o3tl/typed_flags_set.hxx>
+#include <vcl/BinaryDataContainer.hxx>
 #include <vcl/graphic/GraphicMetadata.hxx>
 
 #include <memory>
@@ -306,11 +307,11 @@ public:
 
     static ErrCode readGIF(SvStream& rStream, Graphic& rGraphic, GfxLinkType& 
rLinkType);
     static ErrCode readPNG(SvStream & rStream, Graphic & rGraphic, GfxLinkType 
& rLinkType,
-                    std::unique_ptr<sal_uInt8[]> & rpGraphicContent, 
sal_Int32& rGraphicContentSize);
+                    BinaryDataContainer & rpGraphicContent);
     static ErrCode readJPEG(SvStream & rStream, Graphic & rGraphic, 
GfxLinkType & rLinkType,
                     GraphicFilterImportFlags nImportFlags);
     static ErrCode readSVG(SvStream & rStream, Graphic & rGraphic, GfxLinkType 
& rLinkType,
-                    std::unique_ptr<sal_uInt8[]> & rpGraphicContent, 
sal_Int32& rGraphicContentSize);
+                    BinaryDataContainer & rpGraphicContent);
     static ErrCode readXBM(SvStream & rStream, Graphic & rGraphic);
     static ErrCode readXPM(SvStream & rStream, Graphic & rGraphic);
 
diff --git a/sd/source/ui/view/sdview3.cxx b/sd/source/ui/view/sdview3.cxx
index f96cd774a92a..ab6945aa6476 100644
--- a/sd/source/ui/view/sdview3.cxx
+++ b/sd/source/ui/view/sdview3.cxx
@@ -691,13 +691,10 @@ bool View::InsertData( const TransferableDataHelper& 
rDataHelper,
             Graphic aGraphic;
             if (vcl::ImportPDF(*xStm, aGraphic))
             {
-                std::unique_ptr<sal_uInt8[]> pGraphicContent;
-
                 const sal_Int32 nGraphicContentSize(xStm->Tell());
-                pGraphicContent.reset(new sal_uInt8[nGraphicContentSize]);
                 xStm->Seek(0);
-                xStm->ReadBytes(pGraphicContent.get(), nGraphicContentSize);
-                
aGraphic.SetGfxLink(std::make_shared<GfxLink>(std::move(pGraphicContent), 
nGraphicContentSize, GfxLinkType::NativePdf));
+                BinaryDataContainer aGraphicContent(*xStm, 
nGraphicContentSize);
+                aGraphic.SetGfxLink(std::make_shared<GfxLink>(aGraphicContent, 
GfxLinkType::NativePdf));
 
                 InsertGraphic(aGraphic, mnAction, aInsertPos, nullptr, 
nullptr);
                 bReturn = true;
diff --git a/vcl/qa/cppunit/BinaryDataContainerTest.cxx 
b/vcl/qa/cppunit/BinaryDataContainerTest.cxx
index 09bb036d8602..2f72a9d18214 100644
--- a/vcl/qa/cppunit/BinaryDataContainerTest.cxx
+++ b/vcl/qa/cppunit/BinaryDataContainerTest.cxx
@@ -30,45 +30,34 @@ void BinaryDataContainerTest::testConstruct()
 {
     {
         BinaryDataContainer aContainer;
-        CPPUNIT_ASSERT_EQUAL(true, aContainer.isEmpty());
+        CPPUNIT_ASSERT(aContainer.isEmpty());
         CPPUNIT_ASSERT_EQUAL(size_t(0), aContainer.getSize());
     }
     {
-        std::vector<sal_uInt8> aTestByteArray = { 1, 2, 3, 4 };
-        BinaryDataContainer aContainer(aTestByteArray.data(), 
aTestByteArray.size());
-        CPPUNIT_ASSERT_EQUAL(false, aContainer.isEmpty());
+        // construct a data array
+        sal_uInt8 aTestByteArray[] = { 1, 2, 3, 4 };
+        SvMemoryStream stream(aTestByteArray, std::size(aTestByteArray), 
StreamMode::READ);
+
+        BinaryDataContainer aContainer(stream, std::size(aTestByteArray));
+
+        CPPUNIT_ASSERT(!aContainer.isEmpty());
         CPPUNIT_ASSERT_EQUAL(size_t(4), aContainer.getSize());
 
         // Test Copy
         BinaryDataContainer aCopyOfContainer = aContainer;
-        CPPUNIT_ASSERT_EQUAL(false, aCopyOfContainer.isEmpty());
+        CPPUNIT_ASSERT(!aCopyOfContainer.isEmpty());
         CPPUNIT_ASSERT_EQUAL(size_t(4), aCopyOfContainer.getSize());
         CPPUNIT_ASSERT_EQUAL(aCopyOfContainer.getData(), aContainer.getData());
 
         // Test Move
         BinaryDataContainer aMovedInContainer = std::move(aCopyOfContainer);
-        CPPUNIT_ASSERT_EQUAL(false, aMovedInContainer.isEmpty());
+        CPPUNIT_ASSERT(!aMovedInContainer.isEmpty());
         CPPUNIT_ASSERT_EQUAL(size_t(4), aMovedInContainer.getSize());
         CPPUNIT_ASSERT_EQUAL(aMovedInContainer.getData(), 
aContainer.getData());
 
-        CPPUNIT_ASSERT_EQUAL(true, aCopyOfContainer.isEmpty());
+        CPPUNIT_ASSERT(aCopyOfContainer.isEmpty());
         CPPUNIT_ASSERT_EQUAL(size_t(0), aCopyOfContainer.getSize());
     }
-    {
-        // construct a unique_ptr data array
-        std::vector<sal_uInt8> aTestByteArray = { 1, 2, 3, 4 };
-        auto aConstructionByteArray = 
std::make_unique<std::vector<sal_uInt8>>(aTestByteArray);
-
-        // remember for later to compare
-        const sal_uInt8* pInternal = aConstructionByteArray->data();
-
-        BinaryDataContainer aContainer(std::move(aConstructionByteArray));
-
-        // make sure the unique_ptr was moved into BinaryDataContainer
-        CPPUNIT_ASSERT_EQUAL(false, bool(aConstructionByteArray));
-        // make sure we didn't copy data into BinaryDataContainer (pointers 
match)
-        CPPUNIT_ASSERT_EQUAL(pInternal, aContainer.getData());
-    }
 }
 
 } // namespace
diff --git a/vcl/qa/cppunit/svm/svmtest.cxx b/vcl/qa/cppunit/svm/svmtest.cxx
index 3c92ea3d7d7f..c72ea054401b 100644
--- a/vcl/qa/cppunit/svm/svmtest.cxx
+++ b/vcl/qa/cppunit/svm/svmtest.cxx
@@ -2171,11 +2171,9 @@ void SvmTest::testEPS()
     ScopedVclPtrInstance<VirtualDevice> pVirtualDev;
     setupBaseVirtualDevice(*pVirtualDev, aGDIMetaFile);
 
-    sal_uInt32 nDataSize = 3;
-    std::unique_ptr<sal_uInt8[]> pBuffer (new sal_uInt8[nDataSize]);
-    pBuffer[0] = 'a';
-    pBuffer[1] = 'b';
-    pBuffer[2] = 'c';
+    sal_uInt8 aBuffer[] = { 'a','b','c' };
+    SvMemoryStream stream(aBuffer, std::size(aBuffer), StreamMode::READ);
+    BinaryDataContainer aContainer(stream, std::size(aBuffer));
 
     MapMode aMapMode1(MapUnit::Map100thInch);
     aMapMode1.SetOrigin(Point(0, 1));
@@ -2189,7 +2187,7 @@ void SvmTest::testEPS()
     pVirtualDev1->DrawPixel(Point(1, 8));
     pVirtualDev1->DrawPixel(Point(2, 7));
 
-    GfxLink aGfxLink(std::move(pBuffer), nDataSize, GfxLinkType::EpsBuffer);
+    GfxLink aGfxLink(aContainer, GfxLinkType::EpsBuffer);
     aGfxLink.SetPrefMapMode(aMapMode1);
     aGfxLink.SetUserId(12345);
     aGfxLink.SetPrefSize(Size(3, 6));
diff --git a/vcl/source/filter/graphicfilter.cxx 
b/vcl/source/filter/graphicfilter.cxx
index 321cacb0cc9d..47aa98853e30 100644
--- a/vcl/source/filter/graphicfilter.cxx
+++ b/vcl/source/filter/graphicfilter.cxx
@@ -664,7 +664,7 @@ void GraphicFilter::ImportGraphics(std::vector< 
std::shared_ptr<Graphic> >& rGra
 
         if (rContext.m_nStatus == ERRCODE_NONE && (rContext.m_eLinkType != 
GfxLinkType::NONE) && !rContext.m_pGraphic->GetReaderContext())
         {
-            std::unique_ptr<sal_uInt8[]> pGraphicContent;
+            BinaryDataContainer aGraphicContent;
 
             const sal_uInt64 nStreamEnd = rContext.m_pStream->Tell();
             sal_Int32 nGraphicContentSize = nStreamEnd - 
rContext.m_nStreamBegin;
@@ -673,22 +673,17 @@ void GraphicFilter::ImportGraphics(std::vector< 
std::shared_ptr<Graphic> >& rGra
             {
                 try
                 {
-                    pGraphicContent.reset(new sal_uInt8[nGraphicContentSize]);
+                    rContext.m_pStream->Seek(rContext.m_nStreamBegin);
+                    aGraphicContent = BinaryDataContainer(*rContext.m_pStream, 
nGraphicContentSize);
                 }
                 catch (const std::bad_alloc&)
                 {
                     rContext.m_nStatus = ERRCODE_GRFILTER_TOOBIG;
                 }
-
-                if (rContext.m_nStatus == ERRCODE_NONE)
-                {
-                    rContext.m_pStream->Seek(rContext.m_nStreamBegin);
-                    rContext.m_pStream->ReadBytes(pGraphicContent.get(), 
nGraphicContentSize);
-                }
             }
 
             if (rContext.m_nStatus == ERRCODE_NONE)
-                
rContext.m_pGraphic->SetGfxLink(std::make_shared<GfxLink>(std::move(pGraphicContent),
 nGraphicContentSize, rContext.m_eLinkType));
+                
rContext.m_pGraphic->SetGfxLink(std::make_shared<GfxLink>(aGraphicContent, 
rContext.m_eLinkType));
         }
 
         if (rContext.m_nStatus != ERRCODE_NONE)
@@ -758,8 +753,7 @@ Graphic GraphicFilter::ImportUnloadedGraphic(SvStream& 
rIStream, sal_uInt64 size
 
     OUString aFilterName = pConfig->GetImportFilterName(nFormat);
 
-    std::unique_ptr<sal_uInt8[]> pGraphicContent;
-    sal_Int32 nGraphicContentSize = 0;
+    BinaryDataContainer aGraphicContent;
 
     // read graphic
     {
@@ -770,8 +764,8 @@ Graphic GraphicFilter::ImportUnloadedGraphic(SvStream& 
rIStream, sal_uInt64 size
         else if (aFilterName.equalsIgnoreAsciiCase(IMP_PNG))
         {
             // check if this PNG contains a GIF chunk!
-            pGraphicContent = 
vcl::PngImageReader::getMicrosoftGifChunk(rIStream, &nGraphicContentSize);
-            if( pGraphicContent )
+            aGraphicContent = 
vcl::PngImageReader::getMicrosoftGifChunk(rIStream);
+            if (!aGraphicContent.isEmpty())
                 eLinkType = GfxLinkType::NativeGif;
             else
                 eLinkType = GfxLinkType::NativePng;
@@ -802,20 +796,15 @@ Graphic GraphicFilter::ImportUnloadedGraphic(SvStream& 
rIStream, sal_uInt64 size
 
                     if (!rIStream.GetError() && nMemoryLength >= 0)
                     {
-                        nGraphicContentSize = nMemoryLength;
-                        pGraphicContent.reset(new 
sal_uInt8[nGraphicContentSize]);
-
                         aMemStream.Seek(STREAM_SEEK_TO_BEGIN);
-                        aMemStream.ReadBytes(pGraphicContent.get(), 
nGraphicContentSize);
+                        aGraphicContent = BinaryDataContainer(aMemStream, 
nMemoryLength);
 
                         bOkay = true;
                     }
                 }
                 else
                 {
-                    nGraphicContentSize = nStreamLength;
-                    pGraphicContent.reset(new sal_uInt8[nGraphicContentSize]);
-                    rIStream.ReadBytes(pGraphicContent.get(), nStreamLength);
+                    aGraphicContent = BinaryDataContainer(rIStream, 
nStreamLength);
 
                     bOkay = true;
                 }
@@ -843,8 +832,6 @@ Graphic GraphicFilter::ImportUnloadedGraphic(SvStream& 
rIStream, sal_uInt64 size
                 aFilterName.equalsIgnoreAsciiCase(IMP_WMZ) ||
                 aFilterName.equalsIgnoreAsciiCase(IMP_EMZ))
         {
-            nGraphicContentSize = nStreamLength;
-            pGraphicContent.reset(new sal_uInt8[nGraphicContentSize]);
             rIStream.Seek(nStreamBegin);
             if (ZCodec::IsZCompressed(rIStream))
             {
@@ -857,16 +844,13 @@ Graphic GraphicFilter::ImportUnloadedGraphic(SvStream& 
rIStream, sal_uInt64 size
 
                 if (!rIStream.GetError() && nMemoryLength >= 0)
                 {
-                    nGraphicContentSize = nMemoryLength;
-                    pGraphicContent.reset(new sal_uInt8[nGraphicContentSize]);
-
                     aMemStream.Seek(STREAM_SEEK_TO_BEGIN);
-                    aMemStream.ReadBytes(pGraphicContent.get(), 
nGraphicContentSize);
+                    aGraphicContent = BinaryDataContainer(aMemStream, 
nMemoryLength);
                 }
             }
             else
             {
-                rIStream.ReadBytes(pGraphicContent.get(), nStreamLength);
+                aGraphicContent = BinaryDataContainer(rIStream, nStreamLength);
             }
             if (!rIStream.GetError())
             {
@@ -908,26 +892,19 @@ Graphic GraphicFilter::ImportUnloadedGraphic(SvStream& 
rIStream, sal_uInt64 size
 
     if (nStatus == ERRCODE_NONE && eLinkType != GfxLinkType::NONE)
     {
-        if (!pGraphicContent)
+        if (aGraphicContent.isEmpty())
         {
-            nGraphicContentSize = nStreamLength;
-
-            if (nGraphicContentSize > 0)
+            if (nStreamLength > 0)
             {
                 try
                 {
-                    pGraphicContent.reset(new sal_uInt8[nGraphicContentSize]);
+                    rIStream.Seek(nStreamBegin);
+                    aGraphicContent = BinaryDataContainer(rIStream, 
nStreamLength);
                 }
                 catch (const std::bad_alloc&)
                 {
                     nStatus = ERRCODE_GRFILTER_TOOBIG;
                 }
-
-                if (nStatus == ERRCODE_NONE)
-                {
-                    rIStream.Seek(nStreamBegin);
-                    nGraphicContentSize = 
rIStream.ReadBytes(pGraphicContent.get(), nGraphicContentSize);
-                }
             }
         }
 
@@ -937,14 +914,14 @@ Graphic GraphicFilter::ImportUnloadedGraphic(SvStream& 
rIStream, sal_uInt64 size
             Size aLogicSize;
             if (eLinkType == GfxLinkType::NativeGif)
             {
-                SvMemoryStream aMemoryStream(pGraphicContent.get(), 
nGraphicContentSize, StreamMode::READ);
+                SvMemoryStream 
aMemoryStream(aGraphicContent.getMemoryStream());
                 bAnimated = IsGIFAnimated(aMemoryStream, aLogicSize);
                 if (!pSizeHint && aLogicSize.getWidth() && 
aLogicSize.getHeight())
                 {
                     pSizeHint = &aLogicSize;
                 }
             }
-            
aGraphic.SetGfxLink(std::make_shared<GfxLink>(std::move(pGraphicContent), 
nGraphicContentSize, eLinkType));
+            aGraphic.SetGfxLink(std::make_shared<GfxLink>(aGraphicContent, 
eLinkType));
             aGraphic.ImplGetImpGraphic()->setPrepared(bAnimated, pSizeHint);
         }
     }
@@ -969,18 +946,18 @@ ErrCode GraphicFilter::readGIF(SvStream & rStream, 
Graphic & rGraphic, GfxLinkTy
         return ERRCODE_GRFILTER_FILTERERROR;
 }
 
-ErrCode GraphicFilter::readPNG(SvStream & rStream, Graphic & rGraphic, 
GfxLinkType & rLinkType, std::unique_ptr<sal_uInt8[]> & rpGraphicContent,
-    sal_Int32& rGraphicContentSize)
+ErrCode GraphicFilter::readPNG(SvStream & rStream, Graphic & rGraphic, 
GfxLinkType & rLinkType, BinaryDataContainer& rpGraphicContent)
 {
     ErrCode aReturnCode = ERRCODE_NONE;
 
     // check if this PNG contains a GIF chunk!
-    rpGraphicContent = vcl::PngImageReader::getMicrosoftGifChunk(rStream, 
&rGraphicContentSize);
-    if( rpGraphicContent )
+    if (auto aMSGifChunk = vcl::PngImageReader::getMicrosoftGifChunk(rStream);
+        !aMSGifChunk.isEmpty())
     {
-        SvMemoryStream aIStrm(rpGraphicContent.get(), rGraphicContentSize, 
StreamMode::READ);
+        SvMemoryStream aIStrm(aMSGifChunk.getMemoryStream());
         ImportGIF(aIStrm, rGraphic);
         rLinkType = GfxLinkType::NativeGif;
+        rpGraphicContent = aMSGifChunk;
         return aReturnCode;
     }
 
@@ -1026,8 +1003,7 @@ ErrCode GraphicFilter::readJPEG(SvStream & rStream, 
Graphic & rGraphic, GfxLinkT
     return aReturnCode;
 }
 
-ErrCode GraphicFilter::readSVG(SvStream & rStream, Graphic & rGraphic, 
GfxLinkType & rLinkType, std::unique_ptr<sal_uInt8[]> & rpGraphicContent,
-    sal_Int32& rGraphicContentSize)
+ErrCode GraphicFilter::readSVG(SvStream & rStream, Graphic & rGraphic, 
GfxLinkType & rLinkType, BinaryDataContainer& rpGraphicContent)
 {
     ErrCode aReturnCode = ERRCODE_NONE;
 
@@ -1054,19 +1030,13 @@ ErrCode GraphicFilter::readSVG(SvStream & rStream, 
Graphic & rGraphic, GfxLinkTy
 
             if (!rStream.GetError() && nMemoryLength >= 0)
             {
-                auto aNewData = 
std::make_unique<std::vector<sal_uInt8>>(nMemoryLength);
                 aMemStream.Seek(STREAM_SEEK_TO_BEGIN);
-                aMemStream.ReadBytes(aNewData->data(), aNewData->size());
+                rpGraphicContent = BinaryDataContainer(aMemStream, 
nMemoryLength);
 
                 // Make a uncompressed copy for GfxLink
-                rGraphicContentSize = nMemoryLength;
-                rpGraphicContent.reset(new sal_uInt8[rGraphicContentSize]);
-                std::copy(std::cbegin(*aNewData), std::cend(*aNewData), 
rpGraphicContent.get());
-
                 if (!aMemStream.GetError())
                 {
-                    BinaryDataContainer aDataContainer(std::move(aNewData));
-                    auto aVectorGraphicDataPtr = 
std::make_shared<VectorGraphicData>(aDataContainer, VectorGraphicDataType::Svg);
+                    auto aVectorGraphicDataPtr = 
std::make_shared<VectorGraphicData>(rpGraphicContent, 
VectorGraphicDataType::Svg);
                     rGraphic = Graphic(aVectorGraphicDataPtr);
                     bOkay = true;
                 }
@@ -1074,13 +1044,11 @@ ErrCode GraphicFilter::readSVG(SvStream & rStream, 
Graphic & rGraphic, GfxLinkTy
         }
         else
         {
-            auto aNewData = 
std::make_unique<std::vector<sal_uInt8>>(nStreamLength);
-            rStream.ReadBytes(aNewData->data(), aNewData->size());
+            BinaryDataContainer aNewData(rStream, nStreamLength);
 
             if (!rStream.GetError())
             {
-                BinaryDataContainer aDataContainer(std::move(aNewData));
-                auto aVectorGraphicDataPtr = 
std::make_shared<VectorGraphicData>(aDataContainer, VectorGraphicDataType::Svg);
+                auto aVectorGraphicDataPtr = 
std::make_shared<VectorGraphicData>(aNewData, VectorGraphicDataType::Svg);
                 rGraphic = Graphic(aVectorGraphicDataPtr);
                 bOkay = true;
             }
@@ -1137,14 +1105,10 @@ ErrCode GraphicFilter::readWMF_EMF(SvStream & rStream, 
Graphic & rGraphic, GfxLi
             aNewStream = &aMemStream;
         }
     }
-    auto aNewData = std::make_unique<std::vector<sal_uInt8>>(nStreamLength);
-    aNewStream->ReadBytes(aNewData->data(), aNewData->size());
+    BinaryDataContainer aNewData(*aNewStream, nStreamLength);
     if (!aNewStream->GetError())
     {
-        const VectorGraphicDataType aDataType(eType);
-        BinaryDataContainer aDataContainer(std::move(aNewData));
-
-        auto aVectorGraphicDataPtr = 
std::make_shared<VectorGraphicData>(aDataContainer, aDataType);
+        auto aVectorGraphicDataPtr = 
std::make_shared<VectorGraphicData>(aNewData, eType);
 
         rGraphic = Graphic(aVectorGraphicDataPtr);
         rLinkType = GfxLinkType::NativeWmf;
@@ -1332,8 +1296,7 @@ ErrCode GraphicFilter::ImportGraphic(Graphic& rGraphic, 
std::u16string_view rPat
     GfxLinkType eLinkType = GfxLinkType::NONE;
     const bool bLinkSet = rGraphic.IsGfxLink();
 
-    std::unique_ptr<sal_uInt8[]> pGraphicContent;
-    sal_Int32  nGraphicContentSize = 0;
+    BinaryDataContainer aGraphicContent;
 
     ResetLastError();
 
@@ -1385,7 +1348,7 @@ ErrCode GraphicFilter::ImportGraphic(Graphic& rGraphic, 
std::u16string_view rPat
         }
         else if (aFilterName.equalsIgnoreAsciiCase(IMP_PNG))
         {
-            nStatus = readPNG(rIStream, rGraphic, eLinkType, pGraphicContent, 
nGraphicContentSize);
+            nStatus = readPNG(rIStream, rGraphic, eLinkType, aGraphicContent);
         }
         else if (aFilterName.equalsIgnoreAsciiCase(IMP_JPEG))
         {
@@ -1393,7 +1356,7 @@ ErrCode GraphicFilter::ImportGraphic(Graphic& rGraphic, 
std::u16string_view rPat
         }
         else if (aFilterName.equalsIgnoreAsciiCase(IMP_SVG) || 
aFilterName.equalsIgnoreAsciiCase(IMP_SVGZ))
         {
-            nStatus = readSVG(rIStream, rGraphic, eLinkType, pGraphicContent, 
nGraphicContentSize);
+            nStatus = readSVG(rIStream, rGraphic, eLinkType, aGraphicContent);
         }
         else if( aFilterName.equalsIgnoreAsciiCase( IMP_XBM ) )
         {
@@ -1481,32 +1444,27 @@ ErrCode GraphicFilter::ImportGraphic(Graphic& rGraphic, 
std::u16string_view rPat
 
     if( nStatus == ERRCODE_NONE && ( eLinkType != GfxLinkType::NONE ) && 
!rGraphic.GetReaderContext() && !bLinkSet )
     {
-        if (!pGraphicContent)
+        if (aGraphicContent.isEmpty())
         {
             const sal_uInt64 nStreamEnd = rIStream.Tell();
-            nGraphicContentSize = nStreamEnd - nStreamBegin;
+            const sal_uInt64 nGraphicContentSize = nStreamEnd - nStreamBegin;
 
             if (nGraphicContentSize > 0)
             {
                 try
                 {
-                    pGraphicContent.reset(new sal_uInt8[nGraphicContentSize]);
+                    rIStream.Seek(nStreamBegin);
+                    aGraphicContent = BinaryDataContainer(rIStream, 
nGraphicContentSize);
                 }
                 catch (const std::bad_alloc&)
                 {
                     nStatus = ERRCODE_GRFILTER_TOOBIG;
                 }
-
-                if( nStatus == ERRCODE_NONE )
-                {
-                    rIStream.Seek(nStreamBegin);
-                    rIStream.ReadBytes(pGraphicContent.get(), 
nGraphicContentSize);
-                }
             }
         }
         if( nStatus == ERRCODE_NONE )
         {
-            
rGraphic.SetGfxLink(std::make_shared<GfxLink>(std::move(pGraphicContent), 
nGraphicContentSize, eLinkType));
+            rGraphic.SetGfxLink(std::make_shared<GfxLink>(aGraphicContent, 
eLinkType));
         }
     }
 
diff --git a/vcl/source/filter/ieps/ieps.cxx b/vcl/source/filter/ieps/ieps.cxx
index 57462ccd4dc8..3dbadda9b9bb 100644
--- a/vcl/source/filter/ieps/ieps.cxx
+++ b/vcl/source/filter/ieps/ieps.cxx
@@ -51,7 +51,7 @@ class FilterConfigItem;
 |*
 *************************************************************************/
 
-static sal_uInt8* ImplSearchEntry( sal_uInt8* pSource, sal_uInt8 const * 
pDest, size_t nComp, size_t nSize )
+static const sal_uInt8* ImplSearchEntry( const sal_uInt8* pSource, sal_uInt8 
const * pDest, size_t nComp, size_t nSize )
 {
     while ( nComp-- >= nSize )
     {
@@ -70,7 +70,7 @@ static sal_uInt8* ImplSearchEntry( sal_uInt8* pSource, 
sal_uInt8 const * pDest,
 
 
 // SecurityCount is the buffersize of the buffer in which we will parse for a 
number
-static tools::Long ImplGetNumber(sal_uInt8* &rBuf, sal_uInt32& nSecurityCount)
+static tools::Long ImplGetNumber(const sal_uInt8* &rBuf, sal_uInt32& 
nSecurityCount)
 {
     bool    bValid = true;
     bool    bNegative = false;
@@ -112,7 +112,7 @@ static tools::Long ImplGetNumber(sal_uInt8* &rBuf, 
sal_uInt32& nSecurityCount)
 }
 
 
-static int ImplGetLen( sal_uInt8* pBuf, int nMax )
+static int ImplGetLen(const sal_uInt8* pBuf, int nMax)
 {
     int nLen = 0;
     while( nLen != nMax )
@@ -465,7 +465,7 @@ static void CreateMtfReplacementAction( GDIMetaFile& rMtf, 
SvStream& rStrm, sal_
 }
 
 //there is no preview -> make a red box
-static void MakePreview(sal_uInt8* pBuf, sal_uInt32 nBytesRead,
+static void MakePreview(const sal_uInt8* pBuf, sal_uInt32 nBytesRead,
     tools::Long nWidth, tools::Long nHeight, Graphic &rGraphic)
 {
     GDIMetaFile aMtf;
@@ -487,7 +487,7 @@ static void MakePreview(sal_uInt8* pBuf, sal_uInt32 
nBytesRead,
 
     OUString aString;
     int nLen;
-    sal_uInt8* pDest = ImplSearchEntry( pBuf, reinterpret_cast<sal_uInt8 const 
*>("%%Title:"), nBytesRead - 32, 8 );
+    const sal_uInt8* pDest = ImplSearchEntry( pBuf, reinterpret_cast<sal_uInt8 
const *>("%%Title:"), nBytesRead - 32, 8 );
     sal_uInt32 nRemainingBytes = pDest ? (nBytesRead - (pDest - pBuf)) : 0;
     if (nRemainingBytes >= 8)
     {
@@ -501,13 +501,11 @@ static void MakePreview(sal_uInt8* pBuf, sal_uInt32 
nBytesRead,
         nLen = ImplGetLen(pDest, std::min<sal_uInt32>(nRemainingBytes, 32));
         if (o3tl::make_unsigned(nLen) < nRemainingBytes)
         {
-            sal_uInt8 aOldValue(pDest[ nLen ]); pDest[ nLen ] = 0;
-            if ( strcmp( reinterpret_cast<char*>(pDest), "none" ) != 0 )
+            std::string_view chunk(reinterpret_cast<const char*>(pDest), nLen);
+            if (chunk != "none")
             {
-                const char* pStr = reinterpret_cast<char*>(pDest);
-                aString += " Title:" + OUString(pStr, strlen(pStr), 
RTL_TEXTENCODING_ASCII_US) + "\n";
+                aString += " Title:" + OStringToOUString(chunk, 
RTL_TEXTENCODING_ASCII_US) + "\n";
             }
-            pDest[ nLen ] = aOldValue;
         }
     }
     pDest = ImplSearchEntry( pBuf, reinterpret_cast<sal_uInt8 const 
*>("%%Creator:"), nBytesRead - 32, 10 );
@@ -524,10 +522,8 @@ static void MakePreview(sal_uInt8* pBuf, sal_uInt32 
nBytesRead,
         nLen = ImplGetLen(pDest, std::min<sal_uInt32>(nRemainingBytes, 32));
         if (o3tl::make_unsigned(nLen) < nRemainingBytes)
         {
-            sal_uInt8 aOldValue(pDest[nLen]); pDest[nLen] = 0;
-            const char* pStr = reinterpret_cast<char*>(pDest);
-            aString += " Creator:" + OUString(pStr, strlen(pStr), 
RTL_TEXTENCODING_ASCII_US) + "\n";
-            pDest[nLen] = aOldValue;
+            std::string_view chunk(reinterpret_cast<const char*>(pDest), nLen);
+            aString += " Creator:" + OStringToOUString(chunk, 
RTL_TEXTENCODING_ASCII_US) + "\n";
         }
     }
     pDest = ImplSearchEntry( pBuf, reinterpret_cast<sal_uInt8 const 
*>("%%CreationDate:"), nBytesRead - 32, 15 );
@@ -544,14 +540,11 @@ static void MakePreview(sal_uInt8* pBuf, sal_uInt32 
nBytesRead,
         nLen = ImplGetLen(pDest, std::min<sal_uInt32>(nRemainingBytes, 32));
         if (o3tl::make_unsigned(nLen) < nRemainingBytes)
         {
-            sal_uInt8 aOldValue(pDest[ nLen ]); pDest[ nLen ] = 0;
-            if ( strcmp( reinterpret_cast<char*>(pDest), "none" ) != 0 )
+            std::string_view chunk(reinterpret_cast<const char*>(pDest), nLen);
+            if (chunk != "none")
             {
-                aString += " CreationDate:" + OUString::createFromAscii( 
reinterpret_cast<char*>(pDest) ) + "\n";
-                const char* pStr = reinterpret_cast<char*>(pDest);
-                aString += " CreationDate:" + OUString(pStr, strlen(pStr), 
RTL_TEXTENCODING_ASCII_US) + "\n";
+                aString += " CreationDate:" + OStringToOUString(chunk, 
RTL_TEXTENCODING_ASCII_US) + "\n";
             }
-            pDest[ nLen ] = aOldValue;
         }
     }
     pDest = ImplSearchEntry( pBuf, reinterpret_cast<sal_uInt8 const 
*>("%%LanguageLevel:"), nBytesRead - 4, 16 );
@@ -649,19 +642,18 @@ bool ImportEpsGraphic( SvStream & rStream, Graphic & 
rGraphic)
     }
     if (bOk)
     {
-        std::unique_ptr<sal_uInt8[]> pBuf( new sal_uInt8[ nPSSize ] );
-
         sal_uInt32 nBufStartPos = rStream.Tell();
-        sal_uInt32 nBytesRead = rStream.ReadBytes(pBuf.get(), nPSSize);
-        if ( nBytesRead == nPSSize )
+        BinaryDataContainer aBuf(rStream, nPSSize);
+        if (!aBuf.isEmpty())
         {
+            sal_uInt32 nBytesRead = aBuf.getSize();
             sal_uInt32 nSecurityCount = 32;
             // if there is no tiff/wmf preview, we will parse for a preview in
             // the eps prolog
             if (!bHasPreview && nBytesRead >= nSecurityCount)
             {
-                sal_uInt8* pDest = ImplSearchEntry( pBuf.get(), 
reinterpret_cast<sal_uInt8 const *>("%%BeginPreview:"), nBytesRead - 
nSecurityCount, 15 );
-                sal_uInt32 nRemainingBytes = pDest ? (nBytesRead - (pDest - 
pBuf.get())) : 0;
+                const sal_uInt8* pDest = ImplSearchEntry( aBuf.getData(), 
reinterpret_cast<sal_uInt8 const *>("%%BeginPreview:"), nBytesRead - 
nSecurityCount, 15 );
+                sal_uInt32 nRemainingBytes = pDest ? (nBytesRead - (pDest - 
aBuf.getData())) : 0;
                 if (nRemainingBytes >= 15)
                 {
                     pDest += 15;
@@ -679,7 +671,7 @@ bool ImportEpsGraphic( SvStream & rStream, Graphic & 
rGraphic)
                     }
                     if (bOk)
                     {
-                        rStream.Seek( nBufStartPos + ( pDest - pBuf.get() ) );
+                        rStream.Seek( nBufStartPos + ( pDest - aBuf.getData() 
) );
 
                         vcl::bitmap::RawBitmap aBitmap( Size( nWidth, nHeight 
), 24 );
                         {
@@ -766,8 +758,8 @@ bool ImportEpsGraphic( SvStream & rStream, Graphic & 
rGraphic)
                 }
             }
 
-            sal_uInt8* pDest = ImplSearchEntry( pBuf.get(), 
reinterpret_cast<sal_uInt8 const *>("%%BoundingBox:"), nBytesRead, 14 );
-            sal_uInt32 nRemainingBytes = pDest ? (nBytesRead - (pDest - 
pBuf.get())) : 0;
+            const sal_uInt8* pDest = ImplSearchEntry( aBuf.getData(), 
reinterpret_cast<sal_uInt8 const *>("%%BoundingBox:"), nBytesRead, 14 );
+            sal_uInt32 nRemainingBytes = pDest ? (nBytesRead - (pDest - 
aBuf.getData())) : 0;
             if (nRemainingBytes >= 14)
             {
                 pDest += 14;
@@ -791,19 +783,19 @@ bool ImportEpsGraphic( SvStream & rStream, Graphic & 
rGraphic)
                     // if there is no preview -> try with gs to make one
                     if (!bHasPreview && !utl::ConfigManager::IsFuzzing())
                     {
-                        bHasPreview = RenderAsEMF(pBuf.get(), nBytesRead, 
aGraphic);
+                        bHasPreview = RenderAsEMF(aBuf.getData(), nBytesRead, 
aGraphic);
                         if (!bHasPreview)
-                            bHasPreview = RenderAsBMP(pBuf.get(), nBytesRead, 
aGraphic);
+                            bHasPreview = RenderAsBMP(aBuf.getData(), 
nBytesRead, aGraphic);
                     }
 
                     // if there is no preview -> make a red box
                     if( !bHasPreview )
                     {
-                        MakePreview(pBuf.get(), nBytesRead, nWidth, nHeight,
+                        MakePreview(aBuf.getData(), nBytesRead, nWidth, 
nHeight,
                             aGraphic);
                     }
 
-                    GfxLink     aGfxLink( std::move(pBuf), nPSSize, 
GfxLinkType::EpsBuffer ) ;
+                    GfxLink     aGfxLink( aBuf, GfxLinkType::EpsBuffer ) ;
                     aMtf.AddAction( static_cast<MetaAction*>( new 
MetaEPSAction( Point(), Size( nWidth, nHeight ),
                                                                       
std::move(aGfxLink), aGraphic.GetGDIMetaFile() ) ) );
                     CreateMtfReplacementAction( aMtf, rStream, nOrigPos, 
nPSSize, nPosWMF, nSizeWMF, nPosTIFF, nSizeTIFF );
diff --git a/vcl/source/filter/ipdf/pdfcompat.cxx 
b/vcl/source/filter/ipdf/pdfcompat.cxx
index 62413e585be9..6f431c25130f 100644
--- a/vcl/source/filter/ipdf/pdfcompat.cxx
+++ b/vcl/source/filter/ipdf/pdfcompat.cxx
@@ -99,14 +99,12 @@ BinaryDataContainer createBinaryDataContainer(SvStream& 
rStream)
 
     const sal_uInt32 nStreamLength = aMemoryStream.TellEnd();
 
-    auto aPdfData = std::make_unique<std::vector<sal_uInt8>>(nStreamLength);
-
     aMemoryStream.Seek(STREAM_SEEK_TO_BEGIN);
-    aMemoryStream.ReadBytes(aPdfData->data(), aPdfData->size());
+    BinaryDataContainer aPdfData(aMemoryStream, nStreamLength);
     if (aMemoryStream.GetError())
         return {};
 
-    return { std::move(aPdfData) };
+    return aPdfData;
 }
 
 } // end vcl::filter::ipdf namespace
diff --git a/vcl/source/filter/png/PngImageReader.cxx 
b/vcl/source/filter/png/PngImageReader.cxx
index 6a3053a72e12..5b92c351d8d2 100644
--- a/vcl/source/filter/png/PngImageReader.cxx
+++ b/vcl/source/filter/png/PngImageReader.cxx
@@ -421,12 +421,10 @@ bool reader(SvStream& rStream, BitmapEx& rBitmapEx,
     return true;
 }
 
-std::unique_ptr<sal_uInt8[]> getMsGifChunk(SvStream& rStream, sal_Int32* 
chunkSize)
+BinaryDataContainer getMsGifChunk(SvStream& rStream)
 {
-    if (chunkSize)
-        *chunkSize = 0;
     if (!isPng(rStream))
-        return nullptr;
+        return {};
     // It's easier to read manually the contents and find the chunk than
     // try to get it using libpng.
     // https://en.wikipedia.org/wiki/Portable_Network_Graphics#File_format
@@ -438,7 +436,7 @@ std::unique_ptr<sal_uInt8[]> getMsGifChunk(SvStream& 
rStream, sal_Int32* chunkSi
         rStream.ReadUInt32(length);
         rStream.ReadUInt32(type);
         if (!rStream.good())
-            return nullptr;
+            return {};
         constexpr sal_uInt32 PNGCHUNK_msOG = 0x6d734f47; // Microsoft Office 
Animated GIF
         constexpr sal_uInt64 MSGifHeaderSize = 11; // "MSOFFICE9.0"
         if (type == PNGCHUNK_msOG && length > MSGifHeaderSize)
@@ -451,32 +449,30 @@ std::unique_ptr<sal_uInt8[]> getMsGifChunk(SvStream& 
rStream, sal_Int32* chunkSi
             sal_uInt32 computedCrc = rtl_crc32(0, &typeForCrc, 4);
             const sal_uInt64 pos = rStream.Tell();
             if (pos + length >= rStream.TellEnd())
-                return nullptr; // broken PNG
+                return {}; // broken PNG
 
             char msHeader[MSGifHeaderSize];
             if (rStream.ReadBytes(msHeader, MSGifHeaderSize) != 
MSGifHeaderSize)
-                return nullptr;
+                return {};
             computedCrc = rtl_crc32(computedCrc, msHeader, MSGifHeaderSize);
             length -= MSGifHeaderSize;
 
-            std::unique_ptr<sal_uInt8[]> chunk(new sal_uInt8[length]);
-            if (rStream.ReadBytes(chunk.get(), length) != length)
-                return nullptr;
-            computedCrc = rtl_crc32(computedCrc, chunk.get(), length);
+            BinaryDataContainer chunk(rStream, length);
+            if (chunk.isEmpty())
+                return {};
+            computedCrc = rtl_crc32(computedCrc, chunk.getData(), 
chunk.getSize());
             rStream.ReadUInt32(crc);
             if (!ignoreCrc && crc != computedCrc)
                 continue; // invalid chunk, ignore
-            if (chunkSize)
-                *chunkSize = length;
             return chunk;
         }
         if (rStream.remainingSize() < length)
-            return nullptr;
+            return {};
         rStream.SeekRel(length);
         rStream.ReadUInt32(crc);
         constexpr sal_uInt32 PNGCHUNK_IEND = 0x49454e44;
         if (type == PNGCHUNK_IEND)
-            return nullptr;
+            return {};
     }
 }
 #if defined __GNUC__ && __GNUC__ == 8 && !defined __clang__
@@ -501,13 +497,12 @@ BitmapEx PngImageReader::read()
     return bitmap;
 }
 
-std::unique_ptr<sal_uInt8[]> PngImageReader::getMicrosoftGifChunk(SvStream& 
rStream,
-                                                                  sal_Int32* 
chunkSize)
+BinaryDataContainer PngImageReader::getMicrosoftGifChunk(SvStream& rStream)
 {
     sal_uInt64 originalPosition = rStream.Tell();
     SvStreamEndian originalEndian = rStream.GetEndian();
     rStream.SetEndian(SvStreamEndian::BIG);
-    std::unique_ptr<sal_uInt8[]> chunk = getMsGifChunk(rStream, chunkSize);
+    auto chunk = getMsGifChunk(rStream);
     rStream.SetEndian(originalEndian);
     rStream.Seek(originalPosition);
     return chunk;
diff --git a/vcl/source/filter/wmf/wmf.cxx b/vcl/source/filter/wmf/wmf.cxx
index bf91502b426e..c8e4e7d7d9cb 100644
--- a/vcl/source/filter/wmf/wmf.cxx
+++ b/vcl/source/filter/wmf/wmf.cxx
@@ -42,9 +42,7 @@ bool ReadWindowMetafile( SvStream& rStream, GDIMetaFile& rMTF 
)
 
     // Read binary data to mem array
     const sal_uInt32 nStreamLength(nStreamEnd - nStreamStart);
-    auto rData = std::make_unique<std::vector<sal_uInt8>>(nStreamLength);
-    rStream.ReadBytes(rData->data(), rData->size());
-    BinaryDataContainer aDataContainer(std::move(rData));
+    BinaryDataContainer aDataContainer(rStream, nStreamLength);
     rStream.Seek(nStreamStart);
 
     if (rStream.good())
diff --git a/vcl/source/gdi/TypeSerializer.cxx 
b/vcl/source/gdi/TypeSerializer.cxx
index 0c7b68b8eb1b..83f77bed1379 100644
--- a/vcl/source/gdi/TypeSerializer.cxx
+++ b/vcl/source/gdi/TypeSerializer.cxx
@@ -124,10 +124,7 @@ void TypeSerializer::readGfxLink(GfxLink& rGfxLink)
         nDataSize = nRemainingData;
     }
 
-    std::unique_ptr<sal_uInt8[]> pBuffer(new sal_uInt8[nDataSize]);
-    mrStream.ReadBytes(pBuffer.get(), nDataSize);
-
-    rGfxLink = GfxLink(std::move(pBuffer), nDataSize, 
static_cast<GfxLinkType>(nType));
+    rGfxLink = GfxLink(BinaryDataContainer(mrStream, nDataSize), 
static_cast<GfxLinkType>(nType));
     rGfxLink.SetUserId(nUserId);
 
     if (bMapAndSizeValid)
@@ -282,9 +279,7 @@ void TypeSerializer::readGraphic(Graphic& rGraphic)
 
                     if (nLength)
                     {
-                        auto rData = 
std::make_unique<std::vector<sal_uInt8>>(nLength);
-                        mrStream.ReadBytes(rData->data(), rData->size());
-                        BinaryDataContainer aDataContainer(std::move(rData));
+                        BinaryDataContainer aDataContainer(mrStream, nLength);
 
                         if (!mrStream.GetError())
                         {
diff --git a/vcl/source/gdi/gfxlink.cxx b/vcl/source/gdi/gfxlink.cxx
index 39467b25dc69..c6ca4678b007 100644
--- a/vcl/source/gdi/gfxlink.cxx
+++ b/vcl/source/gdi/gfxlink.cxx
@@ -36,16 +36,6 @@ GfxLink::GfxLink()
 {
 }
 
-GfxLink::GfxLink(std::unique_ptr<sal_uInt8[]> pBuf, sal_uInt32 nSize, 
GfxLinkType nType)
-    : meType(nType)
-    , mnUserId(0)
-    , maDataContainer(pBuf.get(), nSize)
-    , maHash(0)
-    , mbPrefMapModeValid(false)
-    , mbPrefSizeValid(false)
-{
-}
-
 GfxLink::GfxLink(BinaryDataContainer aDataConainer, GfxLinkType nType)
     : meType(nType)
     , mnUserId(0)
diff --git a/vcl/source/gdi/impgraph.cxx b/vcl/source/gdi/impgraph.cxx
index 3b8029b362de..79c87720bc2f 100644
--- a/vcl/source/gdi/impgraph.cxx
+++ b/vcl/source/gdi/impgraph.cxx
@@ -1661,9 +1661,7 @@ bool ImpGraphic::swapInGraphic(SvStream& rStream)
 
                     if (nVectorGraphicDataSize)
                     {
-                        auto rData = 
std::make_unique<std::vector<sal_uInt8>>(nVectorGraphicDataSize);
-                        rStream.ReadBytes(rData->data(), 
nVectorGraphicDataSize);
-                        BinaryDataContainer aDataContainer(std::move(rData));
+                        BinaryDataContainer aDataContainer(rStream, 
nVectorGraphicDataSize);
 
                         if (rStream.GetError())
                             return false;
diff --git a/vcl/source/gdi/vectorgraphicdata.cxx 
b/vcl/source/gdi/vectorgraphicdata.cxx
index e55cd14784e0..d2a0aa06a682 100644
--- a/vcl/source/gdi/vectorgraphicdata.cxx
+++ b/vcl/source/gdi/vectorgraphicdata.cxx
@@ -319,12 +319,11 @@ VectorGraphicData::VectorGraphicData(
     const sal_uInt32 nStmLen(rIStm.remainingSize());
     if (nStmLen)
     {
-        auto pData = std::make_unique<std::vector<sal_uInt8>>(nStmLen);
-        rIStm.ReadBytes(pData->data(), pData->size());
+        BinaryDataContainer aData(rIStm, nStmLen);
 
         if (!rIStm.GetError())
         {
-            maDataContainer = BinaryDataContainer(std::move(pData));
+            maDataContainer = aData;
         }
     }
 }
diff --git a/vcl/source/graphic/BinaryDataContainer.cxx 
b/vcl/source/graphic/BinaryDataContainer.cxx
index 339d28d601d0..af6e5968911c 100644
--- a/vcl/source/graphic/BinaryDataContainer.cxx
+++ b/vcl/source/graphic/BinaryDataContainer.cxx
@@ -11,17 +11,11 @@
 #include <vcl/BinaryDataContainer.hxx>
 #include <o3tl/hash_combine.hxx>
 
-BinaryDataContainer::BinaryDataContainer() = default;
-
-BinaryDataContainer::BinaryDataContainer(const sal_uInt8* pData, size_t nSize)
-    : mpData(std::make_shared<std::vector<sal_uInt8>>(nSize))
-{
-    std::copy(pData, pData + nSize, mpData->data());
-}
-
-BinaryDataContainer::BinaryDataContainer(std::unique_ptr<std::vector<sal_uInt8>>
 aData)
-    : mpData(std::shared_ptr<std::vector<sal_uInt8>>(aData.release(), 
aData.get_deleter()))
+BinaryDataContainer::BinaryDataContainer(SvStream& stream, size_t size)
 {
+    auto pBuffer = std::make_shared<std::vector<sal_uInt8>>(size);
+    if (stream.ReadBytes(pBuffer->data(), pBuffer->size()) == size)
+        mpData = std::move(pBuffer);
 }
 
 size_t BinaryDataContainer::calculateHash() const
@@ -33,4 +27,9 @@ size_t BinaryDataContainer::calculateHash() const
     return nSeed;
 }
 
+SvMemoryStream BinaryDataContainer::getMemoryStream()
+{
+    return SvMemoryStream(mpData ? mpData->data() : nullptr, getSize(), 
StreamMode::READ);
+}
+
 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
commit b3e0bb1200bc9746b5082e78a96d711b64dff10b
Author:     Mike Kaganski <mike.kagan...@collabora.com>
AuthorDate: Tue Mar 7 09:50:11 2023 +0300
Commit:     Michael Meeks <michael.me...@collabora.com>
CommitDate: Sat Apr 1 21:10:04 2023 +0100

    Drop VectorGraphicDataArray
    
    Change-Id: If444317edf35d0627c6bc3a8c36ba973a8a0af8d
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/148371
    Reviewed-by: Noel Grandin <noel.gran...@collabora.co.uk>
    Tested-by: Jenkins

diff --git a/include/vcl/vectorgraphicdata.hxx 
b/include/vcl/vectorgraphicdata.hxx
index 0e9f9fec20e7..bfa30b7af3bc 100644
--- a/include/vcl/vectorgraphicdata.hxx
+++ b/include/vcl/vectorgraphicdata.hxx
@@ -32,8 +32,6 @@
 
 namespace com::sun::star::graphic { class XPrimitive2D; }
 
-typedef css::uno::Sequence<sal_Int8> VectorGraphicDataArray;
-
 
 // helper to convert any Primitive2DSequence to a good quality BitmapEx,
 // using default parameters and graphic::XPrimitive2DRenderer
diff --git a/vcl/source/filter/graphicfilter.cxx 
b/vcl/source/filter/graphicfilter.cxx
index 83ce6d4bed15..321cacb0cc9d 100644
--- a/vcl/source/filter/graphicfilter.cxx
+++ b/vcl/source/filter/graphicfilter.cxx
@@ -1054,18 +1054,18 @@ ErrCode GraphicFilter::readSVG(SvStream & rStream, 
Graphic & rGraphic, GfxLinkTy
 
             if (!rStream.GetError() && nMemoryLength >= 0)
             {
-                VectorGraphicDataArray aNewData(nMemoryLength);
+                auto aNewData = 
std::make_unique<std::vector<sal_uInt8>>(nMemoryLength);
                 aMemStream.Seek(STREAM_SEEK_TO_BEGIN);
-                aMemStream.ReadBytes(aNewData.getArray(), nMemoryLength);
+                aMemStream.ReadBytes(aNewData->data(), aNewData->size());
 
                 // Make a uncompressed copy for GfxLink
                 rGraphicContentSize = nMemoryLength;
                 rpGraphicContent.reset(new sal_uInt8[rGraphicContentSize]);
-                std::copy(std::cbegin(aNewData), std::cend(aNewData), 
rpGraphicContent.get());
+                std::copy(std::cbegin(*aNewData), std::cend(*aNewData), 
rpGraphicContent.get());
 
                 if (!aMemStream.GetError())
                 {
-                    BinaryDataContainer aDataContainer(reinterpret_cast<const 
sal_uInt8*>(aNewData.getConstArray()), aNewData.getLength());
+                    BinaryDataContainer aDataContainer(std::move(aNewData));
                     auto aVectorGraphicDataPtr = 
std::make_shared<VectorGraphicData>(aDataContainer, VectorGraphicDataType::Svg);
                     rGraphic = Graphic(aVectorGraphicDataPtr);
                     bOkay = true;
@@ -1074,12 +1074,12 @@ ErrCode GraphicFilter::readSVG(SvStream & rStream, 
Graphic & rGraphic, GfxLinkTy
         }
         else
         {
-            VectorGraphicDataArray aNewData(nStreamLength);
-            rStream.ReadBytes(aNewData.getArray(), nStreamLength);
+            auto aNewData = 
std::make_unique<std::vector<sal_uInt8>>(nStreamLength);
+            rStream.ReadBytes(aNewData->data(), aNewData->size());
 
             if (!rStream.GetError())
             {
-                BinaryDataContainer aDataContainer(reinterpret_cast<const 
sal_uInt8*>(aNewData.getConstArray()), aNewData.getLength());
+                BinaryDataContainer aDataContainer(std::move(aNewData));
                 auto aVectorGraphicDataPtr = 
std::make_shared<VectorGraphicData>(aDataContainer, VectorGraphicDataType::Svg);
                 rGraphic = Graphic(aVectorGraphicDataPtr);
                 bOkay = true;
@@ -1137,12 +1137,12 @@ ErrCode GraphicFilter::readWMF_EMF(SvStream & rStream, 
Graphic & rGraphic, GfxLi
             aNewStream = &aMemStream;
         }
     }
-    VectorGraphicDataArray aNewData(nStreamLength);
-    aNewStream->ReadBytes(aNewData.getArray(), nStreamLength);
+    auto aNewData = std::make_unique<std::vector<sal_uInt8>>(nStreamLength);
+    aNewStream->ReadBytes(aNewData->data(), aNewData->size());
     if (!aNewStream->GetError())
     {
         const VectorGraphicDataType aDataType(eType);
-        BinaryDataContainer aDataContainer(reinterpret_cast<const 
sal_uInt8*>(aNewData.getConstArray()), aNewData.getLength());
+        BinaryDataContainer aDataContainer(std::move(aNewData));
 
         auto aVectorGraphicDataPtr = 
std::make_shared<VectorGraphicData>(aDataContainer, aDataType);
 
diff --git a/vcl/source/gdi/vectorgraphicdata.cxx 
b/vcl/source/gdi/vectorgraphicdata.cxx
index 27479f3b0c34..e55cd14784e0 100644
--- a/vcl/source/gdi/vectorgraphicdata.cxx
+++ b/vcl/source/gdi/vectorgraphicdata.cxx
@@ -319,13 +319,12 @@ VectorGraphicData::VectorGraphicData(
     const sal_uInt32 nStmLen(rIStm.remainingSize());
     if (nStmLen)
     {
-        VectorGraphicDataArray aVectorGraphicDataArray(nStmLen);
-        auto pData = aVectorGraphicDataArray.getArray();
-        rIStm.ReadBytes(pData, nStmLen);
+        auto pData = std::make_unique<std::vector<sal_uInt8>>(nStmLen);
+        rIStm.ReadBytes(pData->data(), pData->size());
 
         if (!rIStm.GetError())
         {
-            maDataContainer = BinaryDataContainer(reinterpret_cast<const 
sal_uInt8*>(pData), nStmLen);
+            maDataContainer = BinaryDataContainer(std::move(pData));
         }
     }
 }

Reply via email to