X-Git-Url: http://wagner.pp.ru/gitweb/?a=blobdiff_plain;f=CMakeLists.txt;h=51eb221ef558f65961c99b1962a1105c55431978;hb=d73884b9ddb11f7d0559171db5bb0732ab3ffff0;hp=dfcd7743bece4f809c894179223b801c1ef2de7f;hpb=b616bb8e764ca37c9e2c45e79e875ca55aab7d37;p=openssl-gost%2Fengine.git diff --git a/CMakeLists.txt b/CMakeLists.txt index dfcd774..51eb221 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,8 +1,18 @@ cmake_minimum_required(VERSION 2.8) -project(ccgost) +project(ccgost C) -set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c98 -O3 -Werror -Wall") -set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -O0 -Werror -ggdb") +find_package(OpenSSL 1.1 REQUIRED) +include_directories(${OPENSSL_INCLUDE_DIR}) + +enable_testing() + +if (CMAKE_C_COMPILER_ID MATCHES "Clang") + message(STATUS "Using Clang and adding -Qunused-arguments flag") + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Qunused-arguments") +endif() + +set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c98 -O3 -Werror -Qunused-arguments -Wno-unused-function -Wno-missing-braces -Wall") +set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -O2 -Werror -Wall -Wno-unused-parameter -Wno-unused-function -Wno-missing-braces -ggdb") include (TestBigEndian) TEST_BIG_ENDIAN(IS_BIG_ENDIAN) @@ -14,23 +24,6 @@ else() set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DL_ENDIAN") endif() -set(GOST_INCLUDE_DIRECTORIES "${OPENSSL_PATH}/include" "${OPENSSL_PATH}/crypto/include") - -set(GOST_LINK_DIRECTORIES "${OPENSSL_PATH}") - -# module linker flags -SET (CMAKE_MODULE_LINKER_FLAGS "-L${OPENSSL_PATH}" "-L${OPENSSL_PATH}/lib" $ENV{LDFLAGS} - CACHE STRING "Flags used by the linker during the creation of modules.") -# exe linker flags -SET (CMAKE_EXE_LINKER_FLAGS ${CMAKE_EXE_LINKER_FLAGS_INIT} $ENV{LDFLAGS} - CACHE STRING "Flags used by the linker during the creation of executables.") -# shared lib linker flags -SET (CMAKE_SHARED_LINKER_FLAGS ${CMAKE_EXE_LINKER_FLAGS_INIT} $ENV{LDFLAGS} - CACHE STRING "Flags used by the linker during the creation of shared libraries.") - - -include_directories("${GOST_INCLUDE_DIRECTORIES}") - set(BIN_DIRECTORY bin) set(OUTPUT_DIRECTORY ${CMAKE_SOURCE_DIR}/${BIN_DIRECTORY}) @@ -105,7 +98,14 @@ set(GOST_ENGINE_SOURCE_FILES gost_md2012.c gost_pmeth.c) -link_directories(${GOST_LINK_DIRECTORIES}) +add_test(NAME engine + COMMAND perl run_tests + WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}/test) + +add_executable(test_grasshopper test_grasshopper.c) +target_link_libraries(test_grasshopper gost_engine gost ${OPENSSL_CRYPTO_LIBRARY}) +add_test(NAME grasshopper + COMMAND test_grasshopper) add_library(gost STATIC ${GOST_LIB_SOURCE_FILES}) set_target_properties(gost PROPERTIES POSITION_INDEPENDENT_CODE ON) @@ -113,7 +113,7 @@ set_target_properties(gost PROPERTIES POSITION_INDEPENDENT_CODE ON) add_library(gost_engine MODULE ${GOST_ENGINE_SOURCE_FILES}) set_target_properties(gost_engine PROPERTIES PREFIX "" OUTPUT_NAME "gost") -target_link_libraries(gost_engine crypto gost) +target_link_libraries(gost_engine ${OPENSSL_CRYPTO_LIBRARY} gost) set(GOST_12_SUM_SOURCE_FILES gost12sum.c @@ -135,6 +135,6 @@ set(GOST_SUM_12_SOURCE_FILES gostsum12.c ) -add_executable(gostsum12 ${GOST_SUM_12_SOURCE_FILES}) - -target_link_libraries(gostsum12 gost) +#add_executable(gostsum12 ${GOST_SUM_12_SOURCE_FILES}) +# +#target_link_libraries(gostsum12 gost)