From 55527ad756099385c56618ac200b30b6f30ee654 Mon Sep 17 00:00:00 2001 From: dpasukhi Date: Sat, 12 Oct 2024 16:26:32 +0000 Subject: [PATCH] Coding - GCC13 warning suppressing #96 --- .github/workflows/build-linux-gcc-x64-dynamic.yml | 4 ++-- src/BRepTest/BRepTest_BasicCommands.cxx | 2 +- src/MeshTest/MeshTest.cxx | 6 +++--- src/QANCollection/QANCollection_Handle.cxx | 14 ++++++++++++++ src/STEPCAFControl/STEPCAFControl_Reader.cxx | 2 +- src/TopOpeBRepBuild/TopOpeBRepBuild_GridEE.cxx | 6 +++--- 6 files changed, 24 insertions(+), 10 deletions(-) diff --git a/.github/workflows/build-linux-gcc-x64-dynamic.yml b/.github/workflows/build-linux-gcc-x64-dynamic.yml index d23643ccb5..14b2d1450f 100644 --- a/.github/workflows/build-linux-gcc-x64-dynamic.yml +++ b/.github/workflows/build-linux-gcc-x64-dynamic.yml @@ -33,8 +33,8 @@ jobs: -D CMAKE_CXX_COMPILER=g++ \ -D USE_FREETYPE=OFF \ -D CMAKE_BUILD_TYPE=Release \ - -D CMAKE_C_FLAGS="-Werror" \ - -D CMAKE_CXX_FLAGS="-Werror" .. + -D CMAKE_C_FLAGS="-Werror -Wno-clobbered -Wmaybe-uninitialized -Wodr -Wno-alloc-size-larger-than" \ + -D CMAKE_CXX_FLAGS="-Werror -Wno-clobbered -Wno-dangling-pointer" .. - name: Build OCCT run: | diff --git a/src/BRepTest/BRepTest_BasicCommands.cxx b/src/BRepTest/BRepTest_BasicCommands.cxx index 76019fd643..ad81d7bc90 100644 --- a/src/BRepTest/BRepTest_BasicCommands.cxx +++ b/src/BRepTest/BRepTest_BasicCommands.cxx @@ -961,7 +961,7 @@ static Standard_Integer findplane(Draw_Interpretor& di,Standard_Integer n,const if (a_plane_finder.Found()) { //std::cout << " a plane is found " ; di << " a plane is found \n"; - const Handle(Geom_Geometry)& aSurf = a_plane_finder.Plane(); // to avoid ambiguity + const Handle(Geom_Geometry) aSurf = a_plane_finder.Plane(); // to avoid ambiguity DrawTrSurf::Set(a[2],aSurf) ; } return 0 ; diff --git a/src/MeshTest/MeshTest.cxx b/src/MeshTest/MeshTest.cxx index 02f2997487..731a18653c 100644 --- a/src/MeshTest/MeshTest.cxx +++ b/src/MeshTest/MeshTest.cxx @@ -1042,9 +1042,9 @@ static Standard_Integer veriftriangles(Draw_Interpretor& di, Standard_Integer n, else T->Triangle (i).Get (n1,n2,n3); - const gp_XY& xy1 = T->UVNode (n1).XY(); - const gp_XY& xy2 = T->UVNode (n2).XY(); - const gp_XY& xy3 = T->UVNode (n3).XY(); + const gp_Pnt2d xy1 = T->UVNode (n1); + const gp_Pnt2d xy2 = T->UVNode (n2); + const gp_Pnt2d xy3 = T->UVNode (n3); mi2d1.SetCoord((xy2.X()+xy3.X())*0.5, (xy2.Y()+xy3.Y())*0.5); diff --git a/src/QANCollection/QANCollection_Handle.cxx b/src/QANCollection/QANCollection_Handle.cxx index 89c593e63d..5ebadba24d 100644 --- a/src/QANCollection/QANCollection_Handle.cxx +++ b/src/QANCollection/QANCollection_Handle.cxx @@ -135,8 +135,15 @@ static Standard_Integer QAHandleOps (Draw_Interpretor& theDI, // compiler does not keep temporary object referenced by local variable of base type; // here compiler does not recognize that it should keep the temporary object because handle // classes do not inherit each other and they use hard cast for references to simulate inheritance +#if defined(__GNUC__) && (__GNUC__ > 12) +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wdangling-reference" +#endif const Handle(Geom_Curve)& aTmpRefBase (Handle(Geom_Line)::DownCast (aCurve2)); CHECK(theDI, aTmpRefBase.get() != aCurve2.get(), "local reference to temporary handle object (base type)"); +#if defined(__GNUC__) && (__GNUC__ > 12) +#pragma GCC diagnostic pop +#endif // check operations with Handle_* classes Handle(Geom_Line) hLine = aLine; @@ -174,11 +181,18 @@ static Standard_Integer QAHandleOps (Draw_Interpretor& theDI, Handle_Geom_Line qhLine = cpLine; // constructor from const pointer -- could be made explicit... // check that compiler keeps temporary object referenced by local variable +#if defined(__GNUC__) && (__GNUC__ > 12) +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wdangling-reference" +#endif const Handle_Geom_Line& hTmpRef (Handle(Geom_Line)::DownCast (aCurve2)); CHECK(theDI, hTmpRef.get() == aCurve2.get(), "local reference to temporary object (Handle_)"); // check lifetime of temporary object referenced by local variable (base type) const Handle_Geom_Curve& hTmpRefBase (Handle(Geom_Line)::DownCast (aCurve2)); + #if defined(__GNUC__) && (__GNUC__ > 11) +#pragma GCC diagnostic pop +#endif // here we have different behavior for MSVC 2013+ where Handle_ is a class // (compiler creates temporary object of approprtiate type and keeps it living // until the reference is valid) and other compilers where Handle_ is diff --git a/src/STEPCAFControl/STEPCAFControl_Reader.cxx b/src/STEPCAFControl/STEPCAFControl_Reader.cxx index dd9eef42fb..2034d02ded 100644 --- a/src/STEPCAFControl/STEPCAFControl_Reader.cxx +++ b/src/STEPCAFControl/STEPCAFControl_Reader.cxx @@ -1303,7 +1303,7 @@ static Standard_Boolean IsOverriden(const Interface_Graph& theGraph, return Standard_True; } // for root style returns true only if it is overridden by other root style - const Handle(Standard_Transient)& anItem = anOverRidingStyle->ItemAP242().Value(); + const Handle(Standard_Transient) anItem = anOverRidingStyle->ItemAP242().Value(); if(!anItem.IsNull() && anItem->IsKind(STANDARD_TYPE(StepShape_ShapeRepresentation))) { return Standard_True; diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_GridEE.cxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_GridEE.cxx index d1f6ca0f99..8042556fc4 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_GridEE.cxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_GridEE.cxx @@ -678,7 +678,7 @@ void TopOpeBRepBuild_Builder::GFillPointTopologyPVS(const TopoDS_Shape& E, Handle(TopOpeBRepBuild_Pave) PV = new TopOpeBRepBuild_Pave(VPV,par,vofe); if (hasVSD) { PV->HasSameDomain(Standard_True); - const TopoDS_Shape& VSD = myDataStructure->SameDomain(VPV).Value(); + const TopoDS_Shape& VSD = myDataStructure->DS().ShapeSameDomain(VPV).First(); Standard_Integer iVSD = myDataStructure->Shape(VSD); if (iVSD == iVRE) PV->SameDomain(VIG); else PV->SameDomain(VSD); @@ -712,7 +712,7 @@ void TopOpeBRepBuild_Builder::GFillPointTopologyPVS(const TopoDS_Shape& E, Handle(TopOpeBRepBuild_Pave) PVF = new TopOpeBRepBuild_Pave(VPV,parf,vfofe); if (hasVSD) { PVF->HasSameDomain(Standard_True); - const TopoDS_Shape& VSD = myDataStructure->SameDomain(VPV).Value(); + const TopoDS_Shape& VSD = myDataStructure->DS().ShapeSameDomain(VPV).First(); Standard_Integer iVSD = myDataStructure->Shape(VSD); if (iVSD == iVRE) PVF->SameDomain(VIG); else PVF->SameDomain(VSD); @@ -733,7 +733,7 @@ void TopOpeBRepBuild_Builder::GFillPointTopologyPVS(const TopoDS_Shape& E, Handle(TopOpeBRepBuild_Pave) PVR = new TopOpeBRepBuild_Pave(VPV,parl,vrofe); if (hasVSD) { PVR->HasSameDomain(Standard_True); - const TopoDS_Shape& VSD = myDataStructure->SameDomain(VPV).Value(); + const TopoDS_Shape& VSD = myDataStructure->DS().ShapeSameDomain(VPV).First(); Standard_Integer iVSD = myDataStructure->Shape(VSD); if (iVSD == iVRE) PVR->SameDomain(VIG); else PVR->SameDomain(VSD);