diff --git a/CMakeLists.txt b/CMakeLists.txt index 1fe14701..337fcfac 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -54,6 +54,7 @@ add_subdirectory(games) add_subdirectory(sorting) add_subdirectory(geometry) add_subdirectory(graphics) +add_subdirectory(leetcode) add_subdirectory(searching) add_subdirectory(conversions) add_subdirectory(client_server) diff --git a/leetcode/CMakeLists.txt b/leetcode/CMakeLists.txt new file mode 100644 index 00000000..49ed1c16 --- /dev/null +++ b/leetcode/CMakeLists.txt @@ -0,0 +1,24 @@ +# If necessary, use the RELATIVE flag, otherwise each source file may be listed +# with full pathname. RELATIVE may makes it easier to extract an executable name +# automatically. +file( GLOB_RECURSE APP_SOURCES RELATIVE ${CMAKE_CURRENT_SOURCE_DIR} *.c ) +# file( GLOB APP_SOURCES ${CMAKE_SOURCE_DIR}/*.c ) +# AUX_SOURCE_DIRECTORY(${CMAKE_CURRENT_SOURCE_DIR} APP_SOURCES) +foreach( testsourcefile ${APP_SOURCES} ) + # I used a simple string replace, to cut off .cpp. + string( REPLACE ".c" "" testname ${testsourcefile} ) + string( REPLACE "/" "-" testname ${testname} ) + string( REPLACE "\\" "-" testname ${testname} ) + string( REPLACE " " "_" testname ${testname} ) + add_executable( ${testname} ${testsourcefile} ) + + if(OpenMP_C_FOUND) + target_link_libraries(${testname} OpenMP::OpenMP_C) + endif() + + if(MATH_LIBRARY) + target_link_libraries(${testname} ${MATH_LIBRARY}) + endif() + install(TARGETS ${testname} DESTINATION "bin/leetcode") + +endforeach( testsourcefile ${APP_SOURCES} )