forked from OSchip/llvm-project
libc++ testing: allow to provide a path for `use_system_cxx_lib`
As we're trying to setup testing / bots for all shipping version of libc++ on macOS/iOS, we'll need to be able to pass a path to where to find the dylib for each previous version of the OS. Differential Revision: https://reviews.llvm.org/D31486 llvm-svn: 299053
This commit is contained in:
parent
994e17b815
commit
f029dcdb98
|
@ -273,10 +273,14 @@ class Configuration(object):
|
|||
# the locally built one; the former mode is useful for testing ABI
|
||||
# compatibility between the current headers and a shipping dynamic
|
||||
# library.
|
||||
self.use_system_cxx_lib = self.get_lit_bool('use_system_cxx_lib')
|
||||
if self.use_system_cxx_lib is None:
|
||||
# Default to testing against the locally built libc++ library.
|
||||
self.use_system_cxx_lib = self.get_lit_conf('use_system_cxx_lib')
|
||||
if self.use_system_cxx_lib == 'true':
|
||||
self.use_system_cxx_lib = True
|
||||
elif self.use_system_cxx_lib == 'false':
|
||||
self.use_system_cxx_lib = False
|
||||
else:
|
||||
assert os.path.isdir(self.use_system_cxx_lib)
|
||||
self.lit_config.note(
|
||||
"inferred use_system_cxx_lib as: %r" % self.use_system_cxx_lib)
|
||||
|
||||
|
@ -686,6 +690,13 @@ class Configuration(object):
|
|||
self.cxx_runtime_root]
|
||||
elif self.is_windows and self.link_shared:
|
||||
self.add_path(self.exec_env, self.cxx_runtime_root)
|
||||
elif os.path.isdir(str(self.use_system_cxx_lib)):
|
||||
self.cxx.link_flags += ['-L' + self.use_system_cxx_lib]
|
||||
if not self.is_windows:
|
||||
self.cxx.link_flags += ['-Wl,-rpath,' +
|
||||
self.use_system_cxx_lib]
|
||||
if self.is_windows and self.link_shared:
|
||||
self.add_path(self.cxx.compile_env, self.use_system_cxx_lib)
|
||||
|
||||
def configure_link_flags_abi_library_path(self):
|
||||
# Configure ABI library paths.
|
||||
|
|
|
@ -142,6 +142,8 @@ class DarwinLocalTI(DefaultTargetInfo):
|
|||
library_paths = []
|
||||
# Configure the library path for libc++
|
||||
if self.full_config.use_system_cxx_lib:
|
||||
if (os.path.isdir(str(self.full_config.use_system_cxx_lib))):
|
||||
library_paths += [self.full_config.use_system_cxx_lib]
|
||||
pass
|
||||
elif self.full_config.cxx_runtime_root:
|
||||
library_paths += [self.full_config.cxx_runtime_root]
|
||||
|
|
Loading…
Reference in New Issue