diff options
author | Thomas Vigouroux <tomvig38@gmail.com> | 2020-11-04 13:47:39 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-11-04 13:47:39 +0100 |
commit | 8a3a9ffa3d57a5a4c52df13fd1c1f71b7f801196 (patch) | |
tree | 4406a83dac8f72b2fa50dbeeda1c4ce03e3af6fe | |
parent | 9d355b8b0d7b9e548096874c696444a20bbb91f2 (diff) | |
parent | 05cef2f1058980040a9ee5ff12cfb3840b60e544 (diff) | |
download | rneovim-8a3a9ffa3d57a5a4c52df13fd1c1f71b7f801196.tar.gz rneovim-8a3a9ffa3d57a5a4c52df13fd1c1f71b7f801196.tar.bz2 rneovim-8a3a9ffa3d57a5a4c52df13fd1c1f71b7f801196.zip |
Merge pull request #13225 from erw7/fix-build-msvc
third-party: fix build failures in MSVC
-rw-r--r-- | third-party/cmake/BuildTreesitter.cmake | 76 | ||||
-rw-r--r-- | third-party/cmake/TreesitterCMakeLists.txt | 21 |
2 files changed, 78 insertions, 19 deletions
diff --git a/third-party/cmake/BuildTreesitter.cmake b/third-party/cmake/BuildTreesitter.cmake index 3212d6ea08..a55b2e36e8 100644 --- a/third-party/cmake/BuildTreesitter.cmake +++ b/third-party/cmake/BuildTreesitter.cmake @@ -1,22 +1,60 @@ -set(TS_CFLAGS "-O3 -Wall -Wextra") +include(CMakeParseArguments) -ExternalProject_Add(tree-sitter - PREFIX ${DEPS_BUILD_DIR} - URL ${TREESITTER_URL} - DOWNLOAD_DIR ${DEPS_DOWNLOAD_DIR}/tree-sitter - INSTALL_DIR ${DEPS_INSTALL_DIR} - DOWNLOAD_COMMAND ${CMAKE_COMMAND} - -DPREFIX=${DEPS_BUILD_DIR} - -DDOWNLOAD_DIR=${DEPS_DOWNLOAD_DIR}/tree-sitter - -DURL=${TREESITTER_URL} - -DEXPECTED_SHA256=${TREESITTER_SHA256} - -DTARGET=tree-sitter - -DUSE_EXISTING_SRC_DIR=${USE_EXISTING_SRC_DIR} - -P ${CMAKE_CURRENT_SOURCE_DIR}/cmake/DownloadAndExtractFile.cmake - BUILD_IN_SOURCE 1 - PATCH_COMMAND "" - CONFIGURE_COMMAND "" - BUILD_COMMAND ${MAKE_PRG} CC=${DEPS_C_COMPILER} CFLAGS=${TS_CFLAGS} - INSTALL_COMMAND ${MAKE_PRG} CC=${DEPS_C_COMPILER} PREFIX=${DEPS_INSTALL_DIR} install) +# BuildTreeSitter(TARGET targetname CONFIGURE_COMMAND ... BUILD_COMMAND ... INSTALL_COMMAND ...) +function(BuildTreeSitter) + cmake_parse_arguments(_treesitter + "BUILD_IN_SOURCE" + "TARGET" + "CONFIGURE_COMMAND;BUILD_COMMAND;INSTALL_COMMAND" + ${ARGN}) + + if(NOT _treesitter_CONFIGURE_COMMAND AND NOT _treesitter_BUILD_COMMAND + AND NOT _treesitter_INSTALL_COMMAND) + message(FATAL_ERROR "Must pass at least one of CONFIGURE_COMMAND, BUILD_COMMAND, INSTALL_COMMAND") + endif() + if(NOT _treesitter_TARGET) + set(_treesitter_TARGET "tree-sitter") + endif() + + ExternalProject_Add(tree-sitter + PREFIX ${DEPS_BUILD_DIR} + URL ${TREESITTER_URL} + DOWNLOAD_DIR ${DEPS_DOWNLOAD_DIR}/tree-sitter + INSTALL_DIR ${DEPS_INSTALL_DIR} + DOWNLOAD_COMMAND ${CMAKE_COMMAND} + -DPREFIX=${DEPS_BUILD_DIR} + -DDOWNLOAD_DIR=${DEPS_DOWNLOAD_DIR}/tree-sitter + -DURL=${TREESITTER_URL} + -DEXPECTED_SHA256=${TREESITTER_SHA256} + -DTARGET=tree-sitter + -DUSE_EXISTING_SRC_DIR=${USE_EXISTING_SRC_DIR} + -P ${CMAKE_CURRENT_SOURCE_DIR}/cmake/DownloadAndExtractFile.cmake + BUILD_IN_SOURCE ${_treesitter_BUILD_IN_SOURCE} + PATCH_COMMAND "" + CONFIGURE_COMMAND "${_treesitter_CONFIGURE_COMMAND}" + BUILD_COMMAND "${_treesitter_BUILD_COMMAND}" + INSTALL_COMMAND "${_treesitter_INSTALL_COMMAND}") +endfunction() + +if(MSVC) + BuildTreeSitter(BUILD_IN_SOURCE + CONFIGURE_COMMAND ${CMAKE_COMMAND} -E copy + ${CMAKE_CURRENT_SOURCE_DIR}/cmake/TreesitterCMakeLists.txt + ${DEPS_BUILD_DIR}/src/tree-sitter/CMakeLists.txt + COMMAND ${CMAKE_COMMAND} ${DEPS_BUILD_DIR}/src/tree-sitter/CMakeLists.txt + -DCMAKE_C_COMPILER=${CMAKE_C_COMPILER} + -DCMAKE_GENERATOR=${CMAKE_GENERATOR} + -DCMAKE_BUILD_TYPE=${CMAKE_BUILD_TYPE} + -DCMAKE_INSTALL_PREFIX=${DEPS_INSTALL_DIR} + BUILD_COMMAND ${CMAKE_COMMAND} --build . --config ${CMAKE_BUILD_TYPE} + INSTALL_COMMAND ${CMAKE_COMMAND} --build . --target install --config ${CMAKE_BUILD_TYPE} + ) +else() + set(TS_CFLAGS "-O3 -Wall -Wextra") + BuildTreeSitter(BUILD_IN_SOURCE + CONFIGURE_COMMAND "" + BUILD_COMMAND ${MAKE_PRG} CC=${DEPS_C_COMPILER} CFLAGS=${TS_CFLAGS} + INSTALL_COMMAND ${MAKE_PRG} CC=${DEPS_C_COMPILER} PREFIX=${DEPS_INSTALL_DIR} install) +endif() list(APPEND THIRD_PARTY_DEPS tree-sitter) diff --git a/third-party/cmake/TreesitterCMakeLists.txt b/third-party/cmake/TreesitterCMakeLists.txt new file mode 100644 index 0000000000..9e3ba3eeda --- /dev/null +++ b/third-party/cmake/TreesitterCMakeLists.txt @@ -0,0 +1,21 @@ +cmake_minimum_required(VERSION 2.8.12) +project(tree-sitter LANGUAGES C) + +file(GLOB SRC_FILES ${PROJECT_SOURCE_DIR}/lib/src/*.c) +foreach(sfile ${SRC_FILES}) + get_filename_component(f ${sfile} NAME) + if(${f} MATCHES "lib.c$") + list(REMOVE_ITEM SRC_FILES ${sfile}) + endif() +endforeach() +include_directories(${PROJECT_SOURCE_DIR}/lib/include) +add_library(tree-sitter ${SRC_FILES}) + +install(FILES + lib/include/tree_sitter/api.h + lib/include/tree_sitter/parser.h + DESTINATION include/tree_sitter) + +include(GNUInstallDirs) +install(TARGETS tree-sitter + LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}) |