summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Kaganski <mike.kaganski@collabora.com>2018-10-20 22:42:29 +0200
committerMike Kaganski <mike.kaganski@collabora.com>2018-10-21 08:02:01 +0200
commit24e4b37987ccd410b6d6672151d84c790cdb7e56 (patch)
tree5036d0571c38d033285d4c41c9cea8b8725efb2e
parent79e837d8e2fb961cd4825566f07aabf031fddb5f (diff)
tdf#120703 (PVS): handle failed realloc
V701 realloc() possible leak: when realloc() fails in allocating memory, original pointer 'm_p' is lost. Consider assigning realloc() to a temporary pointer. Change-Id: Ic298927a266da4d543f3856a1c9f97ba1f6fe941 Reviewed-on: https://gerrit.libreoffice.org/62092 Reviewed-by: Mike Kaganski <mike.kaganski@collabora.com> Tested-by: Mike Kaganski <mike.kaganski@collabora.com>
-rw-r--r--io/source/stm/streamhelper.cxx6
1 files changed, 4 insertions, 2 deletions
diff --git a/io/source/stm/streamhelper.cxx b/io/source/stm/streamhelper.cxx
index 0ef0d3e1f7ae..c382cae96390 100644
--- a/io/source/stm/streamhelper.cxx
+++ b/io/source/stm/streamhelper.cxx
@@ -75,8 +75,10 @@ void MemRingBuffer::resizeBuffer( sal_Int32 nMinSize )
}
if( nNewLen != m_nBufferLen ) {
- m_p = static_cast<sal_Int8 *>(std::realloc( m_p , nNewLen ));
- if( !m_p ) {
+ if (auto p = static_cast<sal_Int8*>(std::realloc(m_p, nNewLen)))
+ m_p = p;
+ else
+ {
throw css::io::BufferSizeExceededException(
"MemRingBuffer::resizeBuffer BufferSizeExceededException");
}