1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00

Coding - Fixing warning for Clang #209

Update CMake flags and override methods for improved compatibility
Enhance build configurations and improve code quality with compiler flags
This commit is contained in:
dpasukhi 2024-12-23 18:28:17 +00:00
parent f7dea47c33
commit 8e4bda3043
12 changed files with 52 additions and 30 deletions

View File

@ -71,7 +71,9 @@ jobs:
-D USE_VTK=ON ` -D USE_VTK=ON `
-D USE_TBB=ON ` -D USE_TBB=ON `
-D USE_RAPIDJSON=ON ` -D USE_RAPIDJSON=ON `
-D USE_OPENGL=ON .. -D USE_OPENGL=ON `
-D CMAKE_CXX_FLAGS="/W4 /WX" `
-D CMAKE_C_FLAGS="/W4 /WX" ..
shell: pwsh shell: pwsh
- name: Build OCCT - name: Build OCCT
@ -141,7 +143,9 @@ jobs:
-D USE_VTK=OFF ` -D USE_VTK=OFF `
-D USE_TBB=ON ` -D USE_TBB=ON `
-D USE_RAPIDJSON=ON ` -D USE_RAPIDJSON=ON `
-D USE_OPENGL=ON .. -D USE_OPENGL=ON `
-D CMAKE_CXX_FLAGS="-Werror -Wall -Wextra -Wno-unknown-warning-option" `
-D CMAKE_C_FLAGS="-Werror -Wall -Wextra -Wno-unknown-warning-option" ..
shell: pwsh shell: pwsh
- name: Build OCCT - name: Build OCCT
@ -193,7 +197,9 @@ jobs:
-D USE_DRACO=ON \ -D USE_DRACO=ON \
-D USE_FREETYPE=ON \ -D USE_FREETYPE=ON \
-D USE_OPENGL=ON \ -D USE_OPENGL=ON \
-D USE_FREEIMAGE=ON .. -D USE_FREEIMAGE=ON \
-D CMAKE_CXX_FLAGS="-Werror -Wall -Wextra" \
-D CMAKE_C_FLAGS="-Werror -Wall -Wextra" ..
- name: Build OCCT - name: Build OCCT
run: | run: |
@ -244,7 +250,9 @@ jobs:
-D USE_DRACO=ON \ -D USE_DRACO=ON \
-D USE_FREETYPE=ON \ -D USE_FREETYPE=ON \
-D USE_OPENGL=ON \ -D USE_OPENGL=ON \
-D USE_FREEIMAGE=ON .. -D USE_FREEIMAGE=ON \
-D CMAKE_CXX_FLAGS="-Werror -Wall -Wextra" \
-D CMAKE_C_FLAGS="-Werror -Wall -Wextra" ..
- name: Build OCCT - name: Build OCCT
run: | run: |
@ -298,7 +306,9 @@ jobs:
-D USE_VTK=ON \ -D USE_VTK=ON \
-D USE_TBB=OFF \ -D USE_TBB=OFF \
-D USE_RAPIDJSON=ON \ -D USE_RAPIDJSON=ON \
-D USE_OPENGL=ON .. -D USE_OPENGL=ON \
-D CMAKE_CXX_FLAGS="-Werror -Wall -Wextra" \
-D CMAKE_C_FLAGS="-Werror -Wall -Wextra" ..
- name: Build OCCT - name: Build OCCT
run: | run: |

View File

@ -38,6 +38,10 @@ else()
else() else()
add_definitions (-D_CRT_SECURE_NO_WARNINGS -D_CRT_NONSTDC_NO_DEPRECATE) add_definitions (-D_CRT_SECURE_NO_WARNINGS -D_CRT_NONSTDC_NO_DEPRECATE)
endif() endif()
if (APPLE)
set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-deprecated-declarations")
set (CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-deprecated-declarations")
endif()
add_definitions(-DOCC_CONVERT_SIGNALS) add_definitions(-DOCC_CONVERT_SIGNALS)
endif() endif()
@ -152,9 +156,14 @@ elseif (CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_GNUCXX OR (CMAKE_CXX_COMPIL
# Link-Time Code Generation(LTCG) is requared for Whole Program Optimisation(GL) # Link-Time Code Generation(LTCG) is requared for Whole Program Optimisation(GL)
set(CMAKE_EXE_LINKER_FLAGS_RELEASE "${CMAKE_EXE_LINKER_FLAGS_RELEASE} -flto") set(CMAKE_EXE_LINKER_FLAGS_RELEASE "${CMAKE_EXE_LINKER_FLAGS_RELEASE} -flto")
set(CMAKE_SHARED_LINKER_FLAGS_RELEASE "${CMAKE_SHARED_LINKER_FLAGS_RELEASE} -flto -Wl,--gc-sections") set(CMAKE_SHARED_LINKER_FLAGS_RELEASE "${CMAKE_SHARED_LINKER_FLAGS_RELEASE} -flto")
set(CMAKE_STATIC_LINKER_FLAGS_RELEASE "${CMAKE_STATIC_LINKER_FLAGS_RELEASE} -flto -Wl,--gc-sections") set(CMAKE_STATIC_LINKER_FLAGS_RELEASE "${CMAKE_STATIC_LINKER_FLAGS_RELEASE} -flto")
set(CMAKE_MODULE_LINKER_FLAGS_RELEASE "${CMAKE_MODULE_LINKER_FLAGS_RELEASE} -flto -Wl,--gc-sections") set(CMAKE_MODULE_LINKER_FLAGS_RELEASE "${CMAKE_MODULE_LINKER_FLAGS_RELEASE} -flto")
if (NOT WIN32)
set(CMAKE_SHARED_LINKER_FLAGS_RELEASE "${CMAKE_SHARED_LINKER_FLAGS_RELEASE} -Wl,--gc-sections")
set(CMAKE_STATIC_LINKER_FLAGS_RELEASE "${CMAKE_STATIC_LINKER_FLAGS_RELEASE} -Wl,--gc-sections")
set(CMAKE_MODULE_LINKER_FLAGS_RELEASE "${CMAKE_MODULE_LINKER_FLAGS_RELEASE} -Wl,--gc-sections")
endif()
endif() endif()
if (CMAKE_CXX_COMPILER_ID MATCHES "[Cc][Ll][Aa][Nn][Gg]") if (CMAKE_CXX_COMPILER_ID MATCHES "[Cc][Ll][Aa][Nn][Gg]")
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wshorten-64-to-32") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wshorten-64-to-32")
@ -173,8 +182,10 @@ if (CMAKE_CXX_COMPILER_ID MATCHES "[Cc][Ll][Aa][Nn][Gg]")
# CLang can be used with both libstdc++ and libc++, however on OS X libstdc++ is outdated. # CLang can be used with both libstdc++ and libc++, however on OS X libstdc++ is outdated.
set (CMAKE_CXX_FLAGS "-stdlib=libc++ ${CMAKE_CXX_FLAGS}") set (CMAKE_CXX_FLAGS "-stdlib=libc++ ${CMAKE_CXX_FLAGS}")
endif() endif()
# Optimize size of binaries if (NOT WIN32)
set (CMAKE_SHARED_LINKER_FLAGS_RELEASE "-Wl,-s ${CMAKE_SHARED_LINKER_FLAGS_RELEASE}") # Optimize size of binaries
set (CMAKE_SHARED_LINKER_FLAGS_RELEASE "-Wl,-s ${CMAKE_SHARED_LINKER_FLAGS_RELEASE}")
endif()
endif() endif()
if(MINGW) if(MINGW)
add_definitions(-D_WIN32_WINNT=0x0601) add_definitions(-D_WIN32_WINNT=0x0601)
@ -183,7 +194,7 @@ if(MINGW)
# workaround bugs in mingw with vtable export # workaround bugs in mingw with vtable export
set (CMAKE_SHARED_LINKER_FLAGS "-Wl,--export-all-symbols") set (CMAKE_SHARED_LINKER_FLAGS "-Wl,--export-all-symbols")
endif() endif()
if (DEFINED CMAKE_COMPILER_IS_GNUCXX) if (CMAKE_COMPILER_IS_GNUCXX AND NOT APPLE)
# Optimize size of binaries # Optimize size of binaries
set (CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} -s") set (CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} -s")
set (CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} -s") set (CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} -s")

View File

@ -1038,14 +1038,12 @@ void Aspect_OpenVRSession::ProcessEvents()
{ {
case Aspect_XRActionType_InputDigital: case Aspect_XRActionType_InputDigital:
{ {
Aspect_XRDigitalActionData aData = GetDigitalActionData (anAction); GetDigitalActionData (anAction);
//if (aData.IsChanged) { std::cout << " " << anAction->Id() << " pressed: " << aData.IsPressed << "\n"; }
break; break;
} }
case Aspect_XRActionType_InputAnalog: case Aspect_XRActionType_InputAnalog:
{ {
Aspect_XRAnalogActionData aData = GetAnalogActionData (anAction); GetAnalogActionData (anAction);
//if (aData.IsChanged()) { std::cout << " " << anAction->Id() << " changed: " << aData.VecXYZ[0] << " " << aData.VecXYZ[1] << " " << aData.VecXYZ[2] << "\n"; }
break; break;
} }
case Aspect_XRActionType_InputPose: case Aspect_XRActionType_InputPose:
@ -1053,6 +1051,8 @@ void Aspect_OpenVRSession::ProcessEvents()
GetPoseActionDataForNextFrame (anAction); GetPoseActionDataForNextFrame (anAction);
break; break;
} }
default:
break;
} }
} }
} }

View File

@ -496,7 +496,6 @@ namespace exptocas {
int yylen = 0; int yylen = 0;
// Error handling. // Error handling.
int yynerrs_ = 0;
int yyerrstatus_ = 0; int yyerrstatus_ = 0;
/// The lookahead symbol. /// The lookahead symbol.
@ -933,7 +932,6 @@ namespace exptocas {
// If not already recovering from an error, report this error. // If not already recovering from an error, report this error.
if (!yyerrstatus_) if (!yyerrstatus_)
{ {
++yynerrs_;
std::string msg = YY_("syntax error"); std::string msg = YY_("syntax error");
error (YY_MOVE (msg)); error (YY_MOVE (msg));
} }

View File

@ -49,9 +49,9 @@ public:
vtkTypeMacro (IVtkDraw_Interactor, vtkRenderWindowInteractor) vtkTypeMacro (IVtkDraw_Interactor, vtkRenderWindowInteractor)
virtual void Initialize(); virtual void Initialize() Standard_OVERRIDE;
virtual void Enable(); virtual void Enable() Standard_OVERRIDE;
virtual void Start() { } virtual void Start() Standard_OVERRIDE { }
const PSelector& Selector() const { return mySelector; } const PSelector& Selector() const { return mySelector; }
void SetShapePicker (const PSelector& theSelector); void SetShapePicker (const PSelector& theSelector);
@ -97,7 +97,7 @@ protected:
void OnMouseWheelBackward (HWND wnd, UINT nFlags, Standard_Integer X, Standard_Integer Y); void OnMouseWheelBackward (HWND wnd, UINT nFlags, Standard_Integer X, Standard_Integer Y);
#else #else
static void ProcessEvents (ClientData theData, int); static void ProcessEvents (ClientData theData, int);
void GetMousePosition (Standard_Integer *theX, Standard_Integer *theY); void GetMousePosition (Standard_Integer *theX, Standard_Integer *theY) Standard_OVERRIDE;
#endif #endif
private: private:

View File

@ -35,7 +35,7 @@ public:
vtkTypeMacro(IVtkTools_DisplayModeFilter,IVtkTools_SubPolyDataFilter) vtkTypeMacro(IVtkTools_DisplayModeFilter,IVtkTools_SubPolyDataFilter)
static IVtkTools_DisplayModeFilter *New(); static IVtkTools_DisplayModeFilter *New();
void PrintSelf (std::ostream& os, vtkIndent indent); void PrintSelf (std::ostream& os, vtkIndent indent) Standard_OVERRIDE;
//! Set display mode to define cells types to be passed through this filter. //! Set display mode to define cells types to be passed through this filter.
void SetDisplayMode (const IVtk_DisplayMode aMode); void SetDisplayMode (const IVtk_DisplayMode aMode);

View File

@ -35,7 +35,7 @@ public:
vtkTypeMacro(IVtkTools_SubPolyDataFilter,vtkPolyDataAlgorithm) vtkTypeMacro(IVtkTools_SubPolyDataFilter,vtkPolyDataAlgorithm)
static IVtkTools_SubPolyDataFilter *New(); static IVtkTools_SubPolyDataFilter *New();
void PrintSelf (std::ostream& theOs, vtkIndent theIndent); void PrintSelf (std::ostream& theOs, vtkIndent theIndent) Standard_OVERRIDE;
//! Set ids to be passed through this filter. //! Set ids to be passed through this filter.
void SetData(const IVtk_IdTypeMap theSet); void SetData(const IVtk_IdTypeMap theSet);

View File

@ -2193,13 +2193,18 @@ static Standard_Integer OCC6143 (Draw_Interpretor& di, Standard_Integer argc, co
#elif defined(__GNUC__) #elif defined(__GNUC__)
#pragma GCC diagnostic push #pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Woverflow" #pragma GCC diagnostic ignored "-Woverflow"
#elif defined(_MSC_VER)
#pragma warning(push)
#pragma warning(disable: 4307)
#endif #endif
constexpr Standard_Integer i=IntegerLast(); constexpr Standard_Integer i = IntegerLast();
Standard_Integer res = i + 1; Standard_Integer res = i + 1;
#if defined(__clang__) #if defined(__clang__)
#pragma clang diagnostic pop #pragma clang diagnostic pop
#elif defined(__GNUC__) #elif defined(__GNUC__)
#pragma GCC diagnostic pop #pragma GCC diagnostic pop
#elif defined(_MSC_VER)
#pragma warning(pop)
#endif #endif
di << "Not caught: " << i << " + 1 = " << res << ", still OK\n"; di << "Not caught: " << i << " + 1 = " << res << ", still OK\n";
} }

View File

@ -225,7 +225,7 @@ Standard_Boolean ShapeProcess::Perform(const Handle(ShapeProcess_Context)& theCo
std::vector<std::pair<const char*, Handle(ShapeProcess_Operator)>> ShapeProcess::getOperators(const OperationsFlags& theFlags) std::vector<std::pair<const char*, Handle(ShapeProcess_Operator)>> ShapeProcess::getOperators(const OperationsFlags& theFlags)
{ {
std::vector<std::pair<const char*, Handle(ShapeProcess_Operator)>> aResult; std::vector<std::pair<const char*, Handle(ShapeProcess_Operator)>> aResult;
for (std::underlying_type<Operation>::type anOperation = Operation::First; anOperation < Operation::Count; ++anOperation) for (std::underlying_type<Operation>::type anOperation = Operation::First; anOperation <= Operation::Last; ++anOperation)
{ {
if (theFlags.test(anOperation)) if (theFlags.test(anOperation))
{ {

View File

@ -61,7 +61,7 @@ public:
FixShape, FixShape,
SplitClosedEdges, SplitClosedEdges,
SplitCommonVertex, SplitCommonVertex,
Count // Number of operations. Last = SplitCommonVertex // Last operation index.
}; };
// Bitset of operations. It is used to specify which operations should be performed. // Bitset of operations. It is used to specify which operations should be performed.
@ -70,7 +70,7 @@ public:
// flags.set(ShapeProcess::Operation::DirectFaces); // flags.set(ShapeProcess::Operation::DirectFaces);
// flags.set(ShapeProcess::Operation::SameParameter); // flags.set(ShapeProcess::Operation::SameParameter);
// ShapeProcess::Perform(context, flags); // ShapeProcess::Perform(context, flags);
using OperationsFlags = std::bitset<Operation::Count>; using OperationsFlags = std::bitset<Operation::Last + 1>;
public: public:
//! Registers operator to make it visible for Performer //! Registers operator to make it visible for Performer

View File

@ -1318,7 +1318,7 @@ int yyFlexLexer::LexerInput( char* buf, int max_size )
if ( yyin.bad() ) if ( yyin.bad() )
return -1; return -1;
else else
return yyin.gcount(); return static_cast<int>(yyin.gcount());
#endif #endif
} }

View File

@ -437,7 +437,6 @@ namespace step {
int yylen = 0; int yylen = 0;
// Error handling. // Error handling.
int yynerrs_ = 0;
int yyerrstatus_ = 0; int yyerrstatus_ = 0;
/// The lookahead symbol. /// The lookahead symbol.
@ -681,7 +680,6 @@ namespace step {
// If not already recovering from an error, report this error. // If not already recovering from an error, report this error.
if (!yyerrstatus_) if (!yyerrstatus_)
{ {
++yynerrs_;
context yyctx (*this, yyla); context yyctx (*this, yyla);
std::string msg = yysyntax_error_ (yyctx); std::string msg = yysyntax_error_ (yyctx);
error (YY_MOVE (msg)); error (YY_MOVE (msg));