I'm not sure anyone else uses the standalone build, so as long as the
changes you're making are confined to LLDBStandalone, it should be fine
On Sat, Apr 30, 2016 at 6:41 PM Kamil Rytarowski <n...@gmx.com> wrote:

> krytarowski added a comment.
>
> If the change should go to LLDBStandalone.cmake -- can I just put there in
> one go all the bits for standalone builds?
>
>   --- cmake/modules/LLDBStandalone.cmake.orig     2016-04-27
> 00:55:49.000000000 +0000
>   +++ cmake/modules/LLDBStandalone.cmake
>   @@ -2,61 +2,82 @@
>    # standalone project, using LLVM as an external library:
>    if (CMAKE_SOURCE_DIR STREQUAL CMAKE_CURRENT_SOURCE_DIR)
>      project(lldb)
>   -  cmake_minimum_required(VERSION 2.8)
>   +  cmake_minimum_required(VERSION 2.8.12.2)
>
>      option(LLVM_INSTALL_TOOLCHAIN_ONLY "Only include toolchain files in
> the 'install' target." OFF)
>
>   -  set(LLDB_PATH_TO_LLVM_SOURCE "" CACHE PATH
>   -    "Path to LLVM source code. Not necessary if using an installed
> LLVM.")
>   -  set(LLDB_PATH_TO_LLVM_BUILD "" CACHE PATH
>   -    "Path to the directory where LLVM was built or installed.")
>   -
>   -  set(LLDB_PATH_TO_CLANG_SOURCE "" CACHE PATH
>   -    "Path to Clang source code. Not necessary if using an installed
> Clang.")
>   -  set(LLDB_PATH_TO_CLANG_BUILD "" CACHE PATH
>   -    "Path to the directory where Clang was built or installed.")
>   -
>   -  if (LLDB_PATH_TO_LLVM_SOURCE)
>   -    if (NOT EXISTS "${LLDB_PATH_TO_LLVM_SOURCE}/cmake/config-ix.cmake")
>   -      message(FATAL_ERROR "Please set LLDB_PATH_TO_LLVM_SOURCE to the
> root "
>   -              "directory of LLVM source code.")
>   +  # Rely on llvm-config.
>   +  set(CONFIG_OUTPUT)
>   +  find_program(LLVM_CONFIG "llvm-config")
>   +  if(LLVM_CONFIG)
>   +    message(STATUS "Found LLVM_CONFIG as ${LLVM_CONFIG}")
>   +    set(CONFIG_COMMAND ${LLVM_CONFIG}
>   +      "--assertion-mode"
>   +      "--bindir"
>   +      "--libdir"
>   +      "--includedir"
>   +      "--prefix"
>   +      "--src-root")
>   +    execute_process(
>   +      COMMAND ${CONFIG_COMMAND}
>   +      RESULT_VARIABLE HAD_ERROR
>   +      OUTPUT_VARIABLE CONFIG_OUTPUT
>   +    )
>   +    if(NOT HAD_ERROR)
>   +      string(REGEX REPLACE
>   +        "[ \t]*[\r\n]+[ \t]*" ";"
>   +        CONFIG_OUTPUT ${CONFIG_OUTPUT})
>   +
>        else()
>   -      get_filename_component(LLVM_MAIN_SRC_DIR
> ${LLDB_PATH_TO_LLVM_SOURCE}
>   -                             ABSOLUTE)
>   -      set(LLVM_MAIN_INCLUDE_DIR "${LLVM_MAIN_SRC_DIR}/include")
>   -      list(APPEND CMAKE_MODULE_PATH
> "${LLVM_MAIN_SRC_DIR}/cmake/modules")
>   +      string(REPLACE ";" " " CONFIG_COMMAND_STR "${CONFIG_COMMAND}")
>   +      message(STATUS "${CONFIG_COMMAND_STR}")
>   +      message(FATAL_ERROR "llvm-config failed with status ${HAD_ERROR}")
>        endif()
>   -  endif()
>   -
>   -  if (LLDB_PATH_TO_CLANG_SOURCE)
>   -      get_filename_component(CLANG_MAIN_SRC_DIR
> ${LLDB_PATH_TO_CLANG_SOURCE}
>   -                             ABSOLUTE)
>   -      set(CLANG_MAIN_INCLUDE_DIR "${CLANG_MAIN_SRC_DIR}/include")
>   -  endif()
>   -
>   -  list(APPEND CMAKE_MODULE_PATH
> "${LLDB_PATH_TO_LLVM_BUILD}/lib${LLVM_LIBDIR_SUFFIX}/cmake/llvm")
>   -
>   -  if (LLDB_PATH_TO_LLVM_BUILD)
>   -    get_filename_component(PATH_TO_LLVM_BUILD ${LLDB_PATH_TO_LLVM_BUILD}
>   -                           ABSOLUTE)
>      else()
>   -    message(FATAL_ERROR "Please set LLDB_PATH_TO_LLVM_BUILD to the root
> "
>   -            "directory of LLVM build or install site.")
>   +    message(FATAL_ERROR "llvm-config not found -- ${LLVM_CONFIG}")
>      endif()
>
>   -  if (LLDB_PATH_TO_CLANG_BUILD)
>   -    get_filename_component(PATH_TO_CLANG_BUILD
> ${LLDB_PATH_TO_CLANG_BUILD}
>   -                           ABSOLUTE)
>   +  list(GET CONFIG_OUTPUT 0 ENABLE_ASSERTIONS)
>   +  list(GET CONFIG_OUTPUT 1 TOOLS_BINARY_DIR)
>   +  list(GET CONFIG_OUTPUT 2 LIBRARY_DIR)
>   +  list(GET CONFIG_OUTPUT 3 INCLUDE_DIR)
>   +  list(GET CONFIG_OUTPUT 4 LLVM_OBJ_ROOT)
>   +  list(GET CONFIG_OUTPUT 5 MAIN_SRC_DIR)
>   +
>   +  if(NOT MSVC_IDE)
>   +    set(LLVM_ENABLE_ASSERTIONS ${ENABLE_ASSERTIONS}
>   +      CACHE BOOL "Enable assertions")
>   +    # Assertions should follow llvm-config's.
>   +    mark_as_advanced(LLVM_ENABLE_ASSERTIONS)
>   +  endif()
>   +
>   +  set(LLVM_TOOLS_BINARY_DIR ${TOOLS_BINARY_DIR} CACHE PATH "Path to
> llvm/bin")
>   +  set(LLVM_LIBRARY_DIR ${LIBRARY_DIR} CACHE PATH "Path to llvm/lib")
>   +  set(LLVM_MAIN_INCLUDE_DIR ${INCLUDE_DIR} CACHE PATH "Path to
> llvm/include")
>   +  set(LLVM_BINARY_DIR ${LLVM_OBJ_ROOT} CACHE PATH "Path to LLVM build
> tree")
>   +  set(LLVM_MAIN_SRC_DIR ${MAIN_SRC_DIR} CACHE PATH "Path to LLVM source
> tree")
>   +
>   +  find_program(LLVM_TABLEGEN_EXE "llvm-tblgen" ${LLVM_TOOLS_BINARY_DIR}
>   +    NO_DEFAULT_PATH)
>   +
>   +  set(LLVM_CMAKE_PATH
> "${LLVM_BINARY_DIR}/lib${LLVM_LIBDIR_SUFFIX}/cmake/llvm")
>   +  set(LLVMCONFIG_FILE "${LLVM_CMAKE_PATH}/LLVMConfig.cmake")
>   +  if(EXISTS ${LLVMCONFIG_FILE})
>   +    list(APPEND CMAKE_MODULE_PATH "${LLVM_CMAKE_PATH}")
>   +    include(${LLVMCONFIG_FILE})
>      else()
>   -    message(FATAL_ERROR "Please set LLDB_PATH_TO_CLANG_BUILD to the
> root "
>   -            "directory of Clang build or install site.")
>   +    message(FATAL_ERROR "Not found: ${LLVMCONFIG_FILE}")
>      endif()
>
>   -
>   -  # These variables are used by add_llvm_library.
>   +  # They are used as destination of target generators.
>      set(LLVM_RUNTIME_OUTPUT_INTDIR
> ${CMAKE_BINARY_DIR}/${CMAKE_CFG_INTDIR}/bin)
>      set(LLVM_LIBRARY_OUTPUT_INTDIR
> ${CMAKE_BINARY_DIR}/${CMAKE_CFG_INTDIR}/lib${LLVM_LIBDIR_SUFFIX})
>   -  set(LLVM_LIBRARY_DIR ${LLVM_LIBRARY_OUTPUT_INTDIR})
>   +  if(WIN32 OR CYGWIN)
>   +    # DLL platform -- put DLLs into bin.
>   +    set(LLVM_SHLIB_OUTPUT_INTDIR ${LLVM_RUNTIME_OUTPUT_INTDIR})
>   +  else()
>   +    set(LLVM_SHLIB_OUTPUT_INTDIR ${LLVM_LIBRARY_OUTPUT_INTDIR})
>   +  endif()
>
>      include(AddLLVM)
>      include(HandleLLVMOptions)
>   @@ -73,23 +94,16 @@ if (CMAKE_SOURCE_DIR STREQUAL CMAKE_CURR
>        message("-- Found PythonInterp: ${PYTHON_EXECUTABLE}")
>      endif()
>      # Import CMake library targets from LLVM and Clang.
>   -
> include("${LLDB_PATH_TO_LLVM_BUILD}/lib${LLVM_LIBDIR_SUFFIX}/cmake/llvm/LLVMConfig.cmake")
>   -  if (EXISTS
> "${LLDB_PATH_TO_CLANG_BUILD}/lib${LLVM_LIBDIR_SUFFIX}/cmake/clang/ClangConfig.cmake")
>   -
> include("${LLDB_PATH_TO_CLANG_BUILD}/lib${LLVM_LIBDIR_SUFFIX}/cmake/clang/ClangConfig.cmake")
>   -  endif()
>   +
> include("${LLVM_OBJ_ROOT}/lib${LLVM_LIBDIR_SUFFIX}/cmake/llvm/LLVMConfig.cmake")
>   +
> include("${LLVM_OBJ_ROOT}/lib${LLVM_LIBDIR_SUFFIX}/cmake/clang/ClangConfig.cmake")
>
>      set(PACKAGE_VERSION "${LLVM_PACKAGE_VERSION}")
>
>      set(LLVM_BINARY_DIR ${CMAKE_BINARY_DIR})
>
>      set(CMAKE_INCLUDE_CURRENT_DIR ON)
>   -  include_directories("${PATH_TO_LLVM_BUILD}/include"
>   -                      "${LLVM_MAIN_INCLUDE_DIR}"
>   -                      "${PATH_TO_CLANG_BUILD}/include"
>   -                      "${CLANG_MAIN_INCLUDE_DIR}"
>   -                      "${CMAKE_CURRENT_SOURCE_DIR}/source")
>   -  link_directories("${PATH_TO_LLVM_BUILD}/lib${LLVM_LIBDIR_SUFFIX}"
>   -                   "${PATH_TO_CLANG_BUILD}/lib${LLVM_LIBDIR_SUFFIX}")
>   +  include_directories("${LLVM_BINARY_DIR}/include"
> "${LLVM_MAIN_INCLUDE_DIR}")
>   +  link_directories("${LLVM_LIBRARY_DIR}")
>
>      set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin)
>      set(CMAKE_LIBRARY_OUTPUT_DIRECTORY
> ${CMAKE_BINARY_DIR}/lib${LLVM_LIBDIR_SUFFIX})
>
> This patch is anyway cherry-picked from NetBSD by vendors like Red Hat or
> Mageia.
>
> There is only need to fix pending regex support - for now I'm using the
> hack from http://reviews.llvm.org/D15067 locally, and once I will get
> more subsystems to build and test I will be able to finish it cleanly.
>
>
> Repository:
>   rL LLVM
>
> http://reviews.llvm.org/D19772
>
>
>
>
_______________________________________________
lldb-commits mailing list
lldb-commits@lists.llvm.org
http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits

Reply via email to