1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-05 18:16:23 +03:00

0031048: Visualization - runtime error reported by Clang undefined behavior sanitizer in Image_AlienPixMap::Save()

Image_PixMapData - use unsigned math (uintptr_t) instead of signed math with pointers for defining negative stride.
This commit is contained in:
kgv 2019-10-11 14:56:03 +03:00 committed by abv
parent c275673dbf
commit 8ba3d978db

View File

@ -74,27 +74,27 @@ public:
//! @return data pointer to requested row (first column). //! @return data pointer to requested row (first column).
inline const Standard_Byte* Row (const Standard_Size theRow) const inline const Standard_Byte* Row (const Standard_Size theRow) const
{ {
return myTopRowPtr + SizeRowBytes * theRow * TopToDown; return myTopRowPtr + ptrdiff_t(SizeRowBytes * theRow * TopToDown);
} }
//! @return data pointer to requested row (first column). //! @return data pointer to requested row (first column).
inline Standard_Byte* ChangeRow (const Standard_Size theRow) inline Standard_Byte* ChangeRow (const Standard_Size theRow)
{ {
return myTopRowPtr + SizeRowBytes * theRow * TopToDown; return myTopRowPtr + ptrdiff_t(SizeRowBytes * theRow * TopToDown);
} }
//! @return data pointer to requested position. //! @return data pointer to requested position.
inline const Standard_Byte* Value (const Standard_Size theRow, inline const Standard_Byte* Value (const Standard_Size theRow,
const Standard_Size theCol) const const Standard_Size theCol) const
{ {
return myTopRowPtr + SizeRowBytes * theRow * TopToDown + SizeBPP * theCol; return myTopRowPtr + ptrdiff_t(SizeRowBytes * theRow * TopToDown) + SizeBPP * theCol;
} }
//! @return data pointer to requested position. //! @return data pointer to requested position.
inline Standard_Byte* ChangeValue (const Standard_Size theRow, inline Standard_Byte* ChangeValue (const Standard_Size theRow,
const Standard_Size theCol) const Standard_Size theCol)
{ {
return myTopRowPtr + SizeRowBytes * theRow * TopToDown + SizeBPP * theCol; return myTopRowPtr + ptrdiff_t(SizeRowBytes * theRow * TopToDown) + SizeBPP * theCol;
} }
//! Compute the maximal row alignment for current row size. //! Compute the maximal row alignment for current row size.