Skip to content

Commit a3ab2c9

Browse files
committed
[clang][cmake] Rearrange top-level CMakeLists.txt for D116492
In that revision, I make LLD match Clang in deprecating `llvm-config`. This patch isn't to worthwhile on its own --- there isn't a sense in which the new order is "better" in isolation --- but by putting the steps that LLD also neeeds to do first, I make the diff between LLD and Clang's top-level `CMakeLists.txt` very legible. Longer term I hope: 1. We can remove calling `llvm-config` altogether, and just go strait to finding the CMake config file. This is what Flang does, at least. 2. Hopefully the diffable part is smaller then --- i.e. there is less duplicated boilerplate. 3. Any duplicate boilerplate that remains can be factored out. I didn't both trying to factor anything out in e.g. the top level common CMake Utility modules because this deprecated-but-not-removed state is a merely transitional. Reviewed By: beanz Differential Revision: https://reviews.llvm.org/D116548
1 parent a44ef99 commit a3ab2c9

File tree

1 file changed

+24
-22
lines changed

1 file changed

+24
-22
lines changed

clang/CMakeLists.txt

+24-22
Original file line numberDiff line numberDiff line change
@@ -2,15 +2,15 @@ cmake_minimum_required(VERSION 3.13.4)
22

33
# If we are not building as a part of LLVM, build Clang as an
44
# standalone project, using LLVM as an external library:
5-
if( CMAKE_SOURCE_DIR STREQUAL CMAKE_CURRENT_SOURCE_DIR )
5+
if(CMAKE_SOURCE_DIR STREQUAL CMAKE_CURRENT_SOURCE_DIR)
66
project(Clang)
77

88
set(CMAKE_CXX_STANDARD 14 CACHE STRING "C++ standard to conform to")
99
set(CMAKE_CXX_STANDARD_REQUIRED YES)
1010
set(CMAKE_CXX_EXTENSIONS NO)
1111

1212
# Rely on llvm-config.
13-
set(CONFIG_OUTPUT)
13+
set(LLVM_CONFIG_OUTPUT)
1414
if(LLVM_CONFIG)
1515
set (LLVM_CONFIG_FOUND 1)
1616
message(STATUS "Found LLVM_CONFIG as ${LLVM_CONFIG}")
@@ -20,35 +20,36 @@ if( CMAKE_SOURCE_DIR STREQUAL CMAKE_CURRENT_SOURCE_DIR )
2020
automatically, but you can also use LLVM_DIR to specify \
2121
the path containing LLVMConfig.cmake.")
2222
set(CONFIG_COMMAND ${LLVM_CONFIG}
23-
"--assertion-mode"
24-
"--bindir"
25-
"--libdir"
2623
"--includedir"
2724
"--prefix"
2825
"--src-root"
29-
"--cmakedir")
26+
"--cmakedir"
27+
"--bindir"
28+
"--libdir"
29+
"--assertion-mode"
30+
)
3031
execute_process(
3132
COMMAND ${CONFIG_COMMAND}
3233
RESULT_VARIABLE HAD_ERROR
33-
OUTPUT_VARIABLE CONFIG_OUTPUT
34+
OUTPUT_VARIABLE LLVM_CONFIG_OUTPUT
3435
)
3536
if(NOT HAD_ERROR)
3637
string(REGEX REPLACE
3738
"[ \t]*[\r\n]+[ \t]*" ";"
38-
CONFIG_OUTPUT ${CONFIG_OUTPUT})
39+
LLVM_CONFIG_OUTPUT ${LLVM_CONFIG_OUTPUT})
3940
else()
4041
string(REPLACE ";" " " CONFIG_COMMAND_STR "${CONFIG_COMMAND}")
4142
message(STATUS "${CONFIG_COMMAND_STR}")
4243
message(FATAL_ERROR "llvm-config failed with status ${HAD_ERROR}")
4344
endif()
4445

45-
list(GET CONFIG_OUTPUT 0 ENABLE_ASSERTIONS)
46-
list(GET CONFIG_OUTPUT 1 TOOLS_BINARY_DIR)
47-
list(GET CONFIG_OUTPUT 2 LIBRARY_DIR)
48-
list(GET CONFIG_OUTPUT 3 INCLUDE_DIR)
49-
list(GET CONFIG_OUTPUT 4 LLVM_OBJ_ROOT)
50-
list(GET CONFIG_OUTPUT 5 MAIN_SRC_DIR)
51-
list(GET CONFIG_OUTPUT 6 LLVM_CONFIG_CMAKE_DIR)
46+
list(GET LLVM_CONFIG_OUTPUT 0 MAIN_INCLUDE_DIR)
47+
list(GET LLVM_CONFIG_OUTPUT 1 LLVM_OBJ_ROOT)
48+
list(GET LLVM_CONFIG_OUTPUT 2 MAIN_SRC_DIR)
49+
list(GET LLVM_CONFIG_OUTPUT 3 LLVM_CONFIG_CMAKE_DIR)
50+
list(GET LLVM_CONFIG_OUTPUT 4 TOOLS_BINARY_DIR)
51+
list(GET LLVM_CONFIG_OUTPUT 5 LIBRARY_DIR)
52+
list(GET LLVM_CONFIG_OUTPUT 6 ENABLE_ASSERTIONS)
5253

5354
# Normalize LLVM_CMAKE_DIR. --cmakedir might contain backslashes.
5455
# CMake assumes slashes as PATH.
@@ -71,17 +72,17 @@ if( CMAKE_SOURCE_DIR STREQUAL CMAKE_CURRENT_SOURCE_DIR )
7172
if (NOT LLVM_CONFIG_FOUND)
7273
# Pull values from LLVMConfig.cmake. We can drop this once the llvm-config
7374
# path is removed.
75+
set(MAIN_INCLUDE_DIR ${LLVM_INCLUDE_DIR})
76+
set(LLVM_OBJ_DIR ${LLVM_BINARY_DIR})
7477
set(TOOLS_BINARY_DIR ${LLVM_TOOLS_BINARY_DIR})
7578
set(LIBRARY_DIR ${LLVM_LIBRARY_DIR})
76-
set(INCLUDE_DIR ${LLVM_INCLUDE_DIR})
77-
set(LLVM_OBJ_DIR ${LLVM_BINARY_DIR})
7879
endif()
7980

80-
set(LLVM_TOOLS_BINARY_DIR ${TOOLS_BINARY_DIR} CACHE PATH "Path to llvm/bin")
81-
set(LLVM_LIBRARY_DIR ${LIBRARY_DIR} CACHE PATH "Path to llvm/lib")
82-
set(LLVM_MAIN_INCLUDE_DIR ${INCLUDE_DIR} CACHE PATH "Path to llvm/include")
81+
set(LLVM_MAIN_INCLUDE_DIR ${MAIN_INCLUDE_DIR} CACHE PATH "Path to llvm/include")
8382
set(LLVM_BINARY_DIR ${LLVM_OBJ_ROOT} CACHE PATH "Path to LLVM build tree")
8483
set(LLVM_MAIN_SRC_DIR ${MAIN_SRC_DIR} CACHE PATH "Path to LLVM source tree")
84+
set(LLVM_TOOLS_BINARY_DIR ${TOOLS_BINARY_DIR} CACHE PATH "Path to llvm/bin")
85+
set(LLVM_LIBRARY_DIR ${LIBRARY_DIR} CACHE PATH "Path to llvm/lib")
8586

8687
find_program(LLVM_TABLEGEN_EXE "llvm-tblgen" ${LLVM_TOOLS_BINARY_DIR}
8788
NO_DEFAULT_PATH)
@@ -184,11 +185,12 @@ if( CMAKE_SOURCE_DIR STREQUAL CMAKE_CURRENT_SOURCE_DIR )
184185
endif()
185186
endif()
186187

187-
set( CLANG_BUILT_STANDALONE 1 )
188+
set(CLANG_BUILT_STANDALONE TRUE)
189+
188190
set(BACKEND_PACKAGE_STRING "LLVM ${LLVM_PACKAGE_VERSION}")
189191
else()
190192
set(BACKEND_PACKAGE_STRING "${PACKAGE_STRING}")
191-
endif()
193+
endif() # standalone
192194

193195
# Make sure that our source directory is on the current cmake module path so that
194196
# we can include cmake files from this directory.

0 commit comments

Comments
 (0)