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:
parent
f7dea47c33
commit
8e4bda3043
@ -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: |
|
||||||
|
@ -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")
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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));
|
||||||
}
|
}
|
||||||
|
@ -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:
|
||||||
|
@ -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);
|
||||||
|
@ -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);
|
||||||
|
@ -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";
|
||||||
}
|
}
|
||||||
|
@ -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))
|
||||||
{
|
{
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user