Hi, Please find the latest report on new defect(s) introduced to LibreOffice found with Coverity Scan. 3 new defect(s) introduced to LibreOffice found with Coverity Scan. New defect(s) Reported-by: Coverity Scan Showing 3 of 3 defect(s) ** CID 1467667: Incorrect expression (DIVIDE_BY_ZERO) /oox/source/drawingml/diagram/diagramlayoutatoms.cxx: 323 in oox::drawingml::SnakeAlg::layoutShapeChildren(const std::map<int, int, std::less<int>, std::allocator<std::pair<const int, int>>> &, const std::shared_ptr<oox::drawingml::Shape> &, const std::vector<oox::drawingml::Constraint, std::allocator<oox::drawingml::Constraint>> &)() ________________________________________________________________________________________________________ *** CID 1467667: Incorrect expression (DIVIDE_BY_ZERO) /oox/source/drawingml/diagram/diagramlayoutatoms.cxx: 323 in oox::drawingml::SnakeAlg::layoutShapeChildren(const std::map<int, int, std::less<int>, std::allocator<std::pair<const int, int>>> &, const std::shared_ptr<oox::drawingml::Shape> &, const std::vector<oox::drawingml::Constraint, std::allocator<oox::drawingml::Constraint>> &)() 317 for (auto& aCurrShape : rShape->getChildren()) 318 { 319 aCurrShape->setPosition(aCurrPos); 320 awt::Size aCurrSize(aChildSize); 321 // aShapeWidths items are a portion of nMaxRowWidth. We want the same ratio, 322 // based on the original parent width, ignoring the aspect ratio request. >>> CID 1467667: Incorrect expression (DIVIDE_BY_ZERO) >>> In expression "static_cast<double>(aShapeWidths[index]) / nMaxRowWidth", division by expression "nMaxRowWidth" which may be zero has undefined behavior. 323 double fWidthFactor = static_cast<double>(aShapeWidths[index]) / nMaxRowWidth; 324 bool bWidthsFromConstraints 325 = nCount >= 2 && rShape->getChildren()[1]->getDataNodeType() == XML_sibTrans; 326 if (bWidthsFromConstraints) 327 { 328 // We can only work from constraints if spacing is represented by a real ** CID 1467666: Error handling issues (CHECKED_RETURN) /sw/source/uibase/utlui/content.cxx: 3232 in SwContentTree::UpdateTracking()() ________________________________________________________________________________________________________ *** CID 1467666: Error handling issues (CHECKED_RETURN) /sw/source/uibase/utlui/content.cxx: 3232 in SwContentTree::UpdateTracking()() 3226 if (!((m_bIsRoot && m_nRootType != ContentTypeId::OUTLINE) || 3227 m_nOutlineTracking == 3 || nActPos == SwOutlineNodes::npos)) 3228 { 3229 // assure outline content type is expanded 3230 // this assumes outline content type is first in treeview 3231 std::unique_ptr<weld::TreeIter> xFirstEntry(m_xTreeView->make_iterator()); >>> CID 1467666: Error handling issues (CHECKED_RETURN) >>> Calling "get_iter_first" without checking return value (as is done elsewhere 101 out of 107 times). 3232 m_xTreeView->get_iter_first(*xFirstEntry); 3233 m_xTreeView->expand_row(*xFirstEntry); 3234 3235 m_xTreeView->all_foreach([this, nActPos](weld::TreeIter& rEntry){ 3236 bool bRet = false; 3237 if (lcl_IsContent(rEntry, *m_xTreeView) && reinterpret_cast<SwContent*>( ** CID 1467665: Incorrect expression (DIVIDE_BY_ZERO) /oox/source/drawingml/diagram/diagramlayoutatoms.cxx: 255 in oox::drawingml::SnakeAlg::layoutShapeChildren(const std::map<int, int, std::less<int>, std::allocator<std::pair<const int, int>>> &, const std::shared_ptr<oox::drawingml::Shape> &, const std::vector<oox::drawingml::Constraint, std::allocator<oox::drawingml::Constraint>> &)() ________________________________________________________________________________________________________ *** CID 1467665: Incorrect expression (DIVIDE_BY_ZERO) /oox/source/drawingml/diagram/diagramlayoutatoms.cxx: 255 in oox::drawingml::SnakeAlg::layoutShapeChildren(const std::map<int, int, std::less<int>, std::allocator<std::pair<const int, int>>> &, const std::shared_ptr<oox::drawingml::Shape> &, const std::vector<oox::drawingml::Constraint, std::allocator<oox::drawingml::Constraint>> &)() 249 { 250 break; 251 } 252 253 nRowWidth += aShapeWidths[i]; 254 } >>> CID 1467665: Incorrect expression (DIVIDE_BY_ZERO) >>> In expression "fShapeHeight * nRow / nRowWidth", division by expression "nRowWidth" which may be zero has undefined behavior. 255 if ((fShapeHeight * nRow) / nRowWidth >= fAspectRatio) 256 { 257 if (nRowWidth > nMaxRowWidth) 258 { 259 nMaxRowWidth = nRowWidth; 260 } ________________________________________________________________________________________________________ To view the defects in Coverity Scan visit, https://u15810271.ct.sendgrid.net/ls/click?upn=HRESupC-2F2Czv4BOaCWWCy7my0P0qcxCbhZ31OYv50ypSs1kiFPuCn2xFdlMIFBirii0zZ9j2-2F9F2XPBcBm2BNgi9duPy3v-2FzgFDd2LJ-2BDKI-3Dv-9t_OTq2XUZbbipYjyLSo6GRo-2FpVxQ9OzkDINu9UTS-2FQhSdO0F0jQniitrGlNxDIzPJi1ILeDWj8f8NKMEDaRBGWYhmIIAMMJCYiTZSwZ1M9a4y9-2BU9BizEY1B7pDuRiy5H2HSYY37EzcNDM1jQ1DGGev-2F8wzqcYnfv-2FafJOsLj2XH2ej-2BwDTwHnQRDoWUfLVfJ-2FHCALNOPwZeYWX0rH-2BXO6oGgUfG1lJJNvhKKkmg8KqSbqLBL3M4fNlzl7QSEqS8P0 _______________________________________________ LibreOffice mailing list LibreOffice@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/libreoffice