Revert "Revert "Merge to upstream r304942.""
This reverts commit 38a0d5af7e.
Test: make checkbuild
Test: ./run_tests.py
Test: ./run_tests.py --bitness 64
This commit is contained in:
@@ -12,6 +12,7 @@ import lit.util # pylint: disable=import-error,no-name-in-module
|
||||
import locale
|
||||
import os
|
||||
import platform
|
||||
import re
|
||||
import sys
|
||||
|
||||
class DefaultTargetInfo(object):
|
||||
@@ -45,37 +46,88 @@ def test_locale(loc):
|
||||
locale.setlocale(locale.LC_ALL, default_locale)
|
||||
|
||||
|
||||
def add_common_locales(features, lit_config):
|
||||
def add_common_locales(features, lit_config, is_windows=False):
|
||||
# A list of locales needed by the test-suite.
|
||||
# The list uses the canonical name for the locale used in the test-suite
|
||||
# TODO: On Linux ISO8859 *may* needs to hyphenated.
|
||||
locales = [
|
||||
'en_US.UTF-8',
|
||||
'fr_FR.UTF-8',
|
||||
'ru_RU.UTF-8',
|
||||
'zh_CN.UTF-8',
|
||||
'fr_CA.ISO8859-1',
|
||||
'cs_CZ.ISO8859-2'
|
||||
('en_US.UTF-8', 'English_United States.1252'),
|
||||
('fr_FR.UTF-8', 'French_France.1252'),
|
||||
('ru_RU.UTF-8', 'Russian_Russia.1251'),
|
||||
('zh_CN.UTF-8', 'Chinese_China.936'),
|
||||
('fr_CA.ISO8859-1', 'French_Canada.1252'),
|
||||
('cs_CZ.ISO8859-2', 'Czech_Czech Republic.1250')
|
||||
]
|
||||
for loc in locales:
|
||||
if test_locale(loc):
|
||||
features.add('locale.{0}'.format(loc))
|
||||
for loc_id, windows_loc_name in locales:
|
||||
loc_name = windows_loc_name if is_windows else loc_id
|
||||
if test_locale(loc_name):
|
||||
features.add('locale.{0}'.format(loc_id))
|
||||
else:
|
||||
lit_config.warning('The locale {0} is not supported by '
|
||||
'your platform. Some tests will be '
|
||||
'unsupported.'.format(loc))
|
||||
'unsupported.'.format(loc_name))
|
||||
|
||||
|
||||
class DarwinLocalTI(DefaultTargetInfo):
|
||||
def __init__(self, full_config):
|
||||
super(DarwinLocalTI, self).__init__(full_config)
|
||||
|
||||
def is_host_macosx(self):
|
||||
name = lit.util.capture(['sw_vers', '-productName']).strip()
|
||||
return name == "Mac OS X"
|
||||
|
||||
def get_macosx_version(self):
|
||||
assert self.is_host_macosx()
|
||||
version = lit.util.capture(['sw_vers', '-productVersion']).strip()
|
||||
version = re.sub(r'([0-9]+\.[0-9]+)(\..*)?', r'\1', version)
|
||||
return version
|
||||
|
||||
def get_sdk_version(self, name):
|
||||
assert self.is_host_macosx()
|
||||
cmd = ['xcrun', '--sdk', name, '--show-sdk-path']
|
||||
try:
|
||||
out = lit.util.capture(cmd).strip()
|
||||
except OSError:
|
||||
pass
|
||||
|
||||
if not out:
|
||||
self.full_config.lit_config.fatal(
|
||||
"cannot infer sdk version with: %r" % cmd)
|
||||
|
||||
return re.sub(r'.*/[^0-9]+([0-9.]+)\.sdk', r'\1', out)
|
||||
|
||||
def get_platform(self):
|
||||
platform = self.full_config.get_lit_conf('platform')
|
||||
if platform:
|
||||
platform = re.sub(r'([^0-9]+)([0-9\.]*)', r'\1-\2', platform)
|
||||
name, version = tuple(platform.split('-', 1))
|
||||
else:
|
||||
name = 'macosx'
|
||||
version = None
|
||||
|
||||
if version:
|
||||
return (False, name, version)
|
||||
|
||||
# Infer the version, either from the SDK or the system itself. For
|
||||
# macosx, ignore the SDK version; what matters is what's at
|
||||
# /usr/lib/libc++.dylib.
|
||||
if name == 'macosx':
|
||||
version = self.get_macosx_version()
|
||||
else:
|
||||
version = self.get_sdk_version(name)
|
||||
return (True, name, version)
|
||||
|
||||
def add_locale_features(self, features):
|
||||
add_common_locales(features, self.full_config.lit_config)
|
||||
|
||||
def add_cxx_compile_flags(self, flags):
|
||||
if self.full_config.use_deployment:
|
||||
_, name, _ = self.full_config.config.deployment
|
||||
cmd = ['xcrun', '--sdk', name, '--show-sdk-path']
|
||||
else:
|
||||
cmd = ['xcrun', '--show-sdk-path']
|
||||
try:
|
||||
out = lit.util.capture(['xcrun', '--show-sdk-path']).strip()
|
||||
out = lit.util.capture(cmd).strip()
|
||||
res = 0
|
||||
except OSError:
|
||||
res = -1
|
||||
@@ -91,6 +143,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]
|
||||
@@ -198,7 +252,8 @@ class WindowsLocalTI(DefaultTargetInfo):
|
||||
super(WindowsLocalTI, self).__init__(full_config)
|
||||
|
||||
def add_locale_features(self, features):
|
||||
add_common_locales(features, self.full_config.lit_config)
|
||||
add_common_locales(features, self.full_config.lit_config,
|
||||
is_windows=True)
|
||||
|
||||
def use_lit_shell_default(self):
|
||||
# Default to the internal shell on Windows, as bash on Windows is
|
||||
|
||||
Reference in New Issue
Block a user