Skip to content

Commit

Permalink
Merge pull request opencv#7428 from alalek:cmake_fix_compiler_flags_d…
Browse files Browse the repository at this point in the history
…etection
  • Loading branch information
vpisarev committed Oct 12, 2016
2 parents 994815f + 714db4c commit 4acda3f
Show file tree
Hide file tree
Showing 20 changed files with 66 additions and 38 deletions.
2 changes: 2 additions & 0 deletions apps/traincascade/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@ endif()
project(traincascade)
set(the_target opencv_traincascade)

ocv_warnings_disable(CMAKE_CXX_FLAGS -Woverloaded-virtual)

ocv_target_include_directories(${the_target} PRIVATE "${CMAKE_CURRENT_SOURCE_DIR}" "${OpenCV_SOURCE_DIR}/include/opencv")
ocv_target_include_modules_recurse(${the_target} ${OPENCV_TRAINCASCADE_DEPS})

Expand Down
34 changes: 27 additions & 7 deletions cmake/OpenCVUtils.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -199,7 +199,7 @@ set(OCV_COMPILER_FAIL_REGEX
"[Uu]nknown option" # HP
"[Ww]arning: [Oo]ption" # SunPro
"command option .* is not recognized" # XL
"not supported in this configuration; ignored" # AIX
"not supported in this configuration, ignored" # AIX (';' is replaced with ',')
"File with unknown suffix passed to linker" # PGI
"WARNING: unknown flag:" # Open64
)
Expand Down Expand Up @@ -238,19 +238,39 @@ MACRO(ocv_check_compiler_flag LANG FLAG RESULT)
COMPILE_DEFINITIONS "${FLAG}"
OUTPUT_VARIABLE OUTPUT)

FOREACH(_regex ${OCV_COMPILER_FAIL_REGEX})
IF("${OUTPUT}" MATCHES "${_regex}")
SET(${RESULT} 0)
break()
ENDIF()
ENDFOREACH()
if(${RESULT})
string(REPLACE ";" "," OUTPUT_LINES "${OUTPUT}")
string(REPLACE "\n" ";" OUTPUT_LINES "${OUTPUT_LINES}")
foreach(_regex ${OCV_COMPILER_FAIL_REGEX})
if(NOT ${RESULT})
break()
endif()
foreach(_line ${OUTPUT_LINES})
if("${_line}" MATCHES "${_regex}")
file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log
"Build output check failed:\n"
" Regex: '${_regex}'\n"
" Output line: '${_line}'\n")
set(${RESULT} 0)
break()
endif()
endforeach()
endforeach()
endif()

IF(${RESULT})
SET(${RESULT} 1 CACHE INTERNAL "Test ${RESULT}")
MESSAGE(STATUS "Performing Test ${RESULT} - Success")
ELSE(${RESULT})
MESSAGE(STATUS "Performing Test ${RESULT} - Failed")
SET(${RESULT} "" CACHE INTERNAL "Test ${RESULT}")
file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log
"Compilation failed:\n"
" source file: '${_fname}'\n"
" check option: '${FLAG}'\n"
"===== BUILD LOG =====\n"
"${OUTPUT}\n"
"===== END =====\n\n")
ENDIF(${RESULT})
else()
SET(${RESULT} 0)
Expand Down
12 changes: 6 additions & 6 deletions modules/core/test/ocl/test_arithm.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -134,7 +134,7 @@ PARAM_TEST_CASE(ArithmTestBase, MatDepth, Channels, bool)
use_roi = GET_PARAM(2);
}

virtual void generateTestData(bool with_val_in_range = false)
void generateTestData(bool with_val_in_range = false)
{
const int type = CV_MAKE_TYPE(depth, cn);

Expand Down Expand Up @@ -897,7 +897,7 @@ struct RepeatTestCase :
{
int nx, ny;

virtual void generateTestData()
void generateTestData()
{
const int type = CV_MAKE_TYPE(depth, cn);

Expand Down Expand Up @@ -1495,7 +1495,7 @@ PARAM_TEST_CASE(InRange, MatDepth, Channels, bool /*Scalar or not*/, bool /*Roi*
use_roi = GET_PARAM(3);
}

virtual void generateTestData()
void generateTestData()
{
const int type = CV_MAKE_TYPE(depth, cn);

Expand Down Expand Up @@ -1574,7 +1574,7 @@ PARAM_TEST_CASE(ConvertScaleAbs, MatDepth, Channels, bool)
use_roi = GET_PARAM(2);
}

virtual void generateTestData()
void generateTestData()
{
const int stype = CV_MAKE_TYPE(depth, cn);
const int dtype = CV_MAKE_TYPE(CV_8U, cn);
Expand Down Expand Up @@ -1647,7 +1647,7 @@ PARAM_TEST_CASE(PatchNaNs, Channels, bool)
use_roi = GET_PARAM(1);
}

virtual void generateTestData()
void generateTestData()
{
const int type = CV_MAKE_TYPE(CV_32F, cn);

Expand Down Expand Up @@ -1727,7 +1727,7 @@ PARAM_TEST_CASE(Reduce, std::pair<MatDepth, MatDepth>, Channels, int, bool)
use_roi = GET_PARAM(3);
}

virtual void generateTestData()
void generateTestData()
{
const int stype = CV_MAKE_TYPE(sdepth, cn);
dtype = CV_MAKE_TYPE(ddepth, cn);
Expand Down
2 changes: 1 addition & 1 deletion modules/core/test/ocl/test_matrix_operation.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@ PARAM_TEST_CASE(ConvertTo, MatDepth, MatDepth, Channels, bool)
use_roi = GET_PARAM(3);
}

virtual void generateTestData()
void generateTestData()
{
Size roiSize = randomSize(1, MAX_VALUE);
Border srcBorder = randomBorder(0, use_roi ? MAX_VALUE : 0);
Expand Down
4 changes: 2 additions & 2 deletions modules/core/test/test_ippasync.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ PARAM_TEST_CASE(IPPAsync, MatDepth, Channels, hppAccelType)
accelType = GET_PARAM(2);
}

virtual void generateTestData()
void generateTestData()
{
Size matrix_Size = randomSize(2, 100);
const double upValue = 100;
Expand Down Expand Up @@ -102,7 +102,7 @@ PARAM_TEST_CASE(IPPAsyncShared, Channels, hppAccelType)
type=CV_MAKE_TYPE(CV_8U, GET_PARAM(0));
}

virtual void generateTestData()
void generateTestData()
{
Size matrix_Size = randomSize(2, 100);
hpp32u pitch, size;
Expand Down
4 changes: 2 additions & 2 deletions modules/imgproc/test/ocl/test_histogram.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,7 @@ PARAM_TEST_CASE(CalcBackProject, MatDepth, int, bool)
uimages_roi.resize(N);
}

virtual void random_roi()
void random_roi()
{
Size roiSize = randomSize(1, MAX_VALUE);

Expand Down Expand Up @@ -233,7 +233,7 @@ PARAM_TEST_CASE(CalcHist, bool)
useRoi = GET_PARAM(0);
}

virtual void random_roi()
void random_roi()
{
Size roiSize = randomSize(1, MAX_VALUE);

Expand Down
10 changes: 5 additions & 5 deletions modules/imgproc/test/ocl/test_houghlines.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ PARAM_TEST_CASE(HoughLines, double, double, int)
threshold = GET_PARAM(2);
}

virtual void generateTestData()
void generateTestData()
{
src_size = randomSize(500, 1920);
src.create(src_size, CV_8UC1);
Expand All @@ -55,15 +55,15 @@ PARAM_TEST_CASE(HoughLines, double, double, int)
src.copyTo(usrc);
}

virtual void readRealTestData()
void readRealTestData()
{
Mat img = readImage("shared/pic5.png", IMREAD_GRAYSCALE);
Canny(img, src, 100, 150, 3);

src.copyTo(usrc);
}

virtual void Near(double eps = 0.)
void Near(double eps = 0.)
{
EXPECT_EQ(dst.size(), udst.size());

Expand Down Expand Up @@ -124,15 +124,15 @@ PARAM_TEST_CASE(HoughLinesP, int, double, double)
maxGap = GET_PARAM(2);
}

virtual void readRealTestData()
void readRealTestData()
{
Mat img = readImage("shared/pic5.png", IMREAD_GRAYSCALE);
Canny(img, src, 50, 200, 3);

src.copyTo(usrc);
}

virtual void Near(double eps = 0.)
void Near(double eps = 0.)
{
Mat lines_gpu = udst.getMat(ACCESS_READ);

Expand Down
6 changes: 3 additions & 3 deletions modules/imgproc/test/ocl/test_imgproc.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,7 @@ PARAM_TEST_CASE(ImgprocTestBase, MatType,
useRoi = GET_PARAM(3);
}

virtual void random_roi()
void random_roi()
{
Size roiSize = randomSize(1, MAX_VALUE);
Border srcBorder = randomBorder(0, useRoi ? MAX_VALUE : 0);
Expand Down Expand Up @@ -193,7 +193,7 @@ OCL_TEST_P(EqualizeHist, Mat)
struct CornerTestBase :
public ImgprocTestBase
{
virtual void random_roi()
void random_roi()
{
Mat image = readImageType("../gpu/stereobm/aloe-L.png", type);
ASSERT_FALSE(image.empty());
Expand Down Expand Up @@ -296,7 +296,7 @@ struct Integral :
useRoi = GET_PARAM(3);
}

virtual void random_roi()
void random_roi()
{
ASSERT_EQ(CV_MAT_CN(type), 1);

Expand Down
2 changes: 1 addition & 1 deletion modules/imgproc/test/ocl/test_match_template.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ PARAM_TEST_CASE(MatchTemplate, MatDepth, Channels, MatchTemplType, bool)
use_roi = GET_PARAM(3);
}

virtual void generateTestData()
void generateTestData()
{
Size image_roiSize = randomSize(2, 100);
Size templ_roiSize = Size(randomInt(1, image_roiSize.width), randomInt(1, image_roiSize.height));
Expand Down
2 changes: 1 addition & 1 deletion modules/imgproc/test/ocl/test_medianfilter.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ PARAM_TEST_CASE(MedianFilter, MatDepth, Channels, int, bool)
use_roi = GET_PARAM(3);
}

virtual void generateTestData()
void generateTestData()
{
Size roiSize = randomSize(1, MAX_VALUE);
Border srcBorder = randomBorder(0, use_roi ? MAX_VALUE : 0);
Expand Down
1 change: 1 addition & 0 deletions modules/java/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -349,6 +349,7 @@ endif(ANDROID)

# workarounding lack of `__attribute__ ((visibility("default")))` in jni_md.h/JNIEXPORT
string(REPLACE "-fvisibility=hidden" "" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}")
ocv_warnings_disable(CMAKE_CXX_FLAGS -Wunused-const-variable)

ocv_add_library(${the_module} SHARED ${handwritten_h_sources} ${handwritten_cpp_sources} ${generated_cpp_sources}
${copied_files}
Expand Down
2 changes: 1 addition & 1 deletion modules/java/generator/gen_java.py
Original file line number Diff line number Diff line change
Expand Up @@ -996,7 +996,7 @@ def add_class(self, decl):
type_dict["Ptr_"+name] = \
{ "j_type" : name,
"jn_type" : "long", "jn_args" : (("__int64", ".nativeObj"),),
"jni_name" : "Ptr<"+name+">(("+classinfo.fullName(isCPP=True)+"*)%(n)s_nativeObj)", "jni_type" : "jlong",
"jni_name" : "Ptr<"+classinfo.fullName(isCPP=True)+">(("+classinfo.fullName(isCPP=True)+"*)%(n)s_nativeObj)", "jni_type" : "jlong",
"suffix" : "J" }
logging.info('ok: class %s, name: %s, base: %s', classinfo, name, classinfo.base)

Expand Down
2 changes: 1 addition & 1 deletion modules/photo/test/ocl/test_denoising.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ PARAM_TEST_CASE(FastNlMeansDenoisingTestBase, Channels, int, bool, bool)
h[i] = 3.0f + 0.5f*i;
}

virtual void generateTestData()
void generateTestData()
{
const int type = CV_8UC(cn);
Mat image;
Expand Down
2 changes: 2 additions & 0 deletions modules/python/common.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,8 @@ if(MSVC AND NOT ENABLE_NOISY_WARNINGS)
string(REPLACE "/W4" "/W3" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}")
endif()

ocv_warnings_disable(CMAKE_CXX_FLAGS -Woverloaded-virtual -Wunused-private-field)

if(MSVC AND NOT BUILD_SHARED_LIBS)
set_target_properties(${the_module} PROPERTIES LINK_FLAGS "/NODEFAULTLIB:atlthunk.lib /NODEFAULTLIB:atlsd.lib /DEBUG")
endif()
Expand Down
2 changes: 1 addition & 1 deletion modules/stitching/test/ocl/test_warpers.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ struct WarperTestBase :
UMat usrc, udst, uxmap, uymap;
Mat K, R;

virtual void generateTestData()
void generateTestData()
{
Size size = randomSize(1, MAX_VALUE);

Expand Down
4 changes: 2 additions & 2 deletions modules/ts/include/opencv2/ts/ts_perf.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -121,7 +121,7 @@ class MatType
} \
private: int val_; \
}; \
inline void PrintTo(const class_name& t, std::ostream* os) { t.PrintTo(os); } }
static inline void PrintTo(const class_name& t, std::ostream* os) { t.PrintTo(os); } }

#define CV_FLAGS(class_name, ...) \
namespace { \
Expand Down Expand Up @@ -150,7 +150,7 @@ class MatType
} \
private: int val_; \
}; \
inline void PrintTo(const class_name& t, std::ostream* os) { t.PrintTo(os); } }
static inline void PrintTo(const class_name& t, std::ostream* os) { t.PrintTo(os); } }

CV_ENUM(MatDepth, CV_8U, CV_8S, CV_16U, CV_16S, CV_32S, CV_32F, CV_64F, CV_USRTYPE1)

Expand Down
4 changes: 2 additions & 2 deletions modules/ts/src/ts_gtest.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -7954,7 +7954,7 @@ namespace internal {
// of them.
const char kPathSeparator = '\\';
const char kAlternatePathSeparator = '/';
const char kPathSeparatorString[] = "\\";
//const char kPathSeparatorString[] = "\\";
const char kAlternatePathSeparatorString[] = "/";
# if GTEST_OS_WINDOWS_MOBILE
// Windows CE doesn't have a current directory. You should not use
Expand All @@ -7968,7 +7968,7 @@ const char kCurrentDirectoryString[] = ".\\";
# endif // GTEST_OS_WINDOWS_MOBILE
#else
const char kPathSeparator = '/';
const char kPathSeparatorString[] = "/";
//const char kPathSeparatorString[] = "/";
const char kCurrentDirectoryString[] = "./";
#endif // GTEST_OS_WINDOWS

Expand Down
3 changes: 0 additions & 3 deletions modules/video/perf/opencl/perf_optflow_pyrlk.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -54,9 +54,6 @@ using std::tr1::make_tuple;
namespace cvtest {
namespace ocl {

///////////// FarnebackOpticalFlow ////////////////////////
CV_ENUM(farneFlagType, 0, OPTFLOW_FARNEBACK_GAUSSIAN)

typedef tuple< int > PyrLKOpticalFlowParams;
typedef TestBaseWithParam<PyrLKOpticalFlowParams> PyrLKOpticalFlowFixture;

Expand Down
2 changes: 2 additions & 0 deletions samples/cpp/detect_mser.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -97,8 +97,10 @@ static String Legende(MSERParams &pAct)
}


#ifdef HAVE_OPENGL
const int win_width = 800;
const int win_height = 640;
#endif
bool rotateEnable=true;
bool keyPressed=false;

Expand Down
4 changes: 4 additions & 0 deletions samples/cpp/videostab.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -224,6 +224,8 @@ class MotionEstimatorRansacL2Builder : public IMotionEstimatorBuilder
kbest->setOutlierRejector(outlierRejector);
return kbest;
}
#else
CV_Assert(gpu == false && "CUDA modules are not available");
#endif

Ptr<KeypointBasedMotionEstimator> kbest = makePtr<KeypointBasedMotionEstimator>(est);
Expand Down Expand Up @@ -265,6 +267,8 @@ class MotionEstimatorL1Builder : public IMotionEstimatorBuilder
kbest->setOutlierRejector(outlierRejector);
return kbest;
}
#else
CV_Assert(gpu == false && "CUDA modules are not available");
#endif

Ptr<KeypointBasedMotionEstimator> kbest = makePtr<KeypointBasedMotionEstimator>(est);
Expand Down

0 comments on commit 4acda3f

Please sign in to comment.