2018-06-12 03:10:02 +00:00
|
|
|
set(files
|
|
|
|
__bit_reference
|
|
|
|
__bsd_locale_defaults.h
|
|
|
|
__bsd_locale_fallbacks.h
|
2018-07-03 04:01:44 +00:00
|
|
|
__errc
|
2018-06-12 03:10:02 +00:00
|
|
|
__debug
|
|
|
|
__functional_03
|
|
|
|
__functional_base
|
|
|
|
__functional_base_03
|
|
|
|
__hash_table
|
|
|
|
__libcpp_version
|
|
|
|
__locale
|
|
|
|
__mutex_base
|
2018-08-01 01:33:38 +00:00
|
|
|
__node_handle
|
2018-06-12 03:10:02 +00:00
|
|
|
__nullptr
|
|
|
|
__split_buffer
|
|
|
|
__sso_allocator
|
|
|
|
__std_stream
|
|
|
|
__string
|
|
|
|
__threading_support
|
|
|
|
__tree
|
|
|
|
__tuple
|
|
|
|
__undef_macros
|
|
|
|
algorithm
|
|
|
|
any
|
|
|
|
array
|
|
|
|
atomic
|
2020-02-18 09:58:34 -05:00
|
|
|
barrier
|
2018-08-17 16:07:48 +00:00
|
|
|
bit
|
2018-06-12 03:10:02 +00:00
|
|
|
bitset
|
|
|
|
cassert
|
|
|
|
ccomplex
|
|
|
|
cctype
|
|
|
|
cerrno
|
|
|
|
cfenv
|
|
|
|
cfloat
|
2018-08-01 02:38:30 +00:00
|
|
|
charconv
|
2018-06-12 03:10:02 +00:00
|
|
|
chrono
|
|
|
|
cinttypes
|
|
|
|
ciso646
|
|
|
|
climits
|
|
|
|
clocale
|
|
|
|
cmath
|
|
|
|
codecvt
|
|
|
|
compare
|
|
|
|
complex
|
|
|
|
complex.h
|
2020-04-08 18:00:13 -04:00
|
|
|
concepts
|
2018-06-12 03:10:02 +00:00
|
|
|
condition_variable
|
|
|
|
csetjmp
|
|
|
|
csignal
|
|
|
|
cstdarg
|
|
|
|
cstdbool
|
|
|
|
cstddef
|
|
|
|
cstdint
|
|
|
|
cstdio
|
|
|
|
cstdlib
|
|
|
|
cstring
|
|
|
|
ctgmath
|
|
|
|
ctime
|
|
|
|
ctype.h
|
|
|
|
cwchar
|
|
|
|
cwctype
|
|
|
|
deque
|
|
|
|
errno.h
|
|
|
|
exception
|
2019-08-05 18:29:14 +00:00
|
|
|
execution
|
2018-06-12 03:10:02 +00:00
|
|
|
experimental/__config
|
|
|
|
experimental/__memory
|
|
|
|
experimental/algorithm
|
|
|
|
experimental/coroutine
|
|
|
|
experimental/deque
|
|
|
|
experimental/filesystem
|
|
|
|
experimental/forward_list
|
|
|
|
experimental/functional
|
|
|
|
experimental/iterator
|
|
|
|
experimental/list
|
|
|
|
experimental/map
|
|
|
|
experimental/memory_resource
|
|
|
|
experimental/propagate_const
|
|
|
|
experimental/regex
|
|
|
|
experimental/set
|
|
|
|
experimental/simd
|
|
|
|
experimental/string
|
|
|
|
experimental/type_traits
|
|
|
|
experimental/unordered_map
|
|
|
|
experimental/unordered_set
|
|
|
|
experimental/utility
|
|
|
|
experimental/vector
|
|
|
|
ext/__hash
|
|
|
|
ext/hash_map
|
|
|
|
ext/hash_set
|
2019-02-11 23:47:19 +00:00
|
|
|
fenv.h
|
2018-07-27 03:42:58 +00:00
|
|
|
filesystem
|
2018-06-12 03:10:02 +00:00
|
|
|
float.h
|
|
|
|
forward_list
|
|
|
|
fstream
|
|
|
|
functional
|
|
|
|
future
|
|
|
|
initializer_list
|
|
|
|
inttypes.h
|
|
|
|
iomanip
|
|
|
|
ios
|
|
|
|
iosfwd
|
|
|
|
iostream
|
|
|
|
istream
|
|
|
|
iterator
|
2020-02-18 09:58:34 -05:00
|
|
|
latch
|
2018-06-12 03:10:02 +00:00
|
|
|
limits
|
|
|
|
limits.h
|
|
|
|
list
|
|
|
|
locale
|
|
|
|
locale.h
|
|
|
|
map
|
|
|
|
math.h
|
|
|
|
memory
|
|
|
|
module.modulemap
|
|
|
|
mutex
|
|
|
|
new
|
2020-06-19 12:43:33 +05:30
|
|
|
numbers
|
2018-06-12 03:10:02 +00:00
|
|
|
numeric
|
|
|
|
optional
|
|
|
|
ostream
|
|
|
|
queue
|
|
|
|
random
|
|
|
|
ratio
|
|
|
|
regex
|
|
|
|
scoped_allocator
|
2020-02-18 09:58:34 -05:00
|
|
|
semaphore
|
2018-06-12 03:10:02 +00:00
|
|
|
set
|
|
|
|
setjmp.h
|
|
|
|
shared_mutex
|
2018-07-24 03:01:02 +00:00
|
|
|
span
|
2018-06-12 03:10:02 +00:00
|
|
|
sstream
|
|
|
|
stack
|
|
|
|
stdbool.h
|
|
|
|
stddef.h
|
|
|
|
stdexcept
|
|
|
|
stdint.h
|
|
|
|
stdio.h
|
|
|
|
stdlib.h
|
|
|
|
streambuf
|
|
|
|
string
|
|
|
|
string.h
|
|
|
|
string_view
|
|
|
|
strstream
|
|
|
|
system_error
|
|
|
|
tgmath.h
|
|
|
|
thread
|
|
|
|
tuple
|
|
|
|
type_traits
|
|
|
|
typeindex
|
|
|
|
typeinfo
|
|
|
|
unordered_map
|
|
|
|
unordered_set
|
|
|
|
utility
|
|
|
|
valarray
|
|
|
|
variant
|
|
|
|
vector
|
|
|
|
version
|
|
|
|
wchar.h
|
|
|
|
wctype.h
|
|
|
|
)
|
|
|
|
|
|
|
|
if(LIBCXX_INSTALL_SUPPORT_HEADERS)
|
|
|
|
set(files
|
|
|
|
${files}
|
|
|
|
support/android/locale_bionic.h
|
|
|
|
support/fuchsia/xlocale.h
|
|
|
|
support/ibm/limits.h
|
|
|
|
support/ibm/locale_mgmt_aix.h
|
|
|
|
support/ibm/support.h
|
|
|
|
support/ibm/xlocale.h
|
|
|
|
support/musl/xlocale.h
|
|
|
|
support/newlib/xlocale.h
|
|
|
|
support/solaris/floatingpoint.h
|
|
|
|
support/solaris/wchar.h
|
|
|
|
support/solaris/xlocale.h
|
|
|
|
support/win32/limits_msvc_win32.h
|
|
|
|
support/win32/locale_win32.h
|
|
|
|
support/xlocale/__nop_locale_mgmt.h
|
|
|
|
support/xlocale/__posix_l_fallback.h
|
|
|
|
support/xlocale/__strtonum_fallback.h
|
|
|
|
)
|
2013-11-15 18:34:43 +00:00
|
|
|
endif()
|
[libcxx] Capture configuration information when installing the libc++ headers
Summary:
Hi all,
This patch is a successor to D11963. However it has changed dramatically and I felt it would be best to start a new review thread.
Please read the design documentation added in this patch for a description of how it works.
Reviewers: mclow.lists, danalbert, jroelofs, EricWF
Subscribers: vkalintiris, rnk, ed, espositofulvio, asl, eugenis, cfe-commits
Differential Revision: http://reviews.llvm.org/D13407
llvm-svn: 250235
2015-10-13 22:12:02 +00:00
|
|
|
|
2020-06-26 01:23:43 -04:00
|
|
|
configure_file("__config_site.in"
|
|
|
|
"${LIBCXX_BINARY_DIR}/__config_site"
|
|
|
|
@ONLY)
|
|
|
|
|
[libc++] Always generate a __config_site header
Before this patch, the __config_site header was only generated when at
least one __config_site macro needed to be defined. This lead to two
different code paths in how libc++ is configured, depending on whether
a __config_site header was generated or not. After this patch, the
__config_site is always generated, but it can be empty in case there
are no macros to define in it.
More context on why this change is important
--------------------------------------------
In addition to being confusing, this double-code-path situation lead to
broken code being checked in undetected in 2405bd689815, which introduced
the LIBCXX_HAS_MERGED_TYPEINFO_NAMES_DEFAULT CMake setting. Specifically,
the _LIBCPP_HAS_MERGED_TYPEINFO_NAMES_DEFAULT <__config_site> macro was
supposed NOT to be defined unless LIBCXX_HAS_MERGED_TYPEINFO_NAMES_DEFAULT
was specified explicitly on the CMake command line. Instead, what happened
is that it was defined to 0 if it wasn't specified explicitly and a
<__config_site> header was generated. And defining that macro to 0 had
the important effect of using the non-unique RTTI comparison implementation,
which changes the ABI.
This change in behavior wasn't noticed because the <__config_site> header
is not generated by default. However, the Apple configuration does cause
a <__config_site> header to be generated, which lead to the wrong RTTI
implementation being used, and to https://llvm.org/PR45549. We came close
to an ABI break in the dylib, but were saved due to a downstream-only
change that overrode the decision of the <__config_site> for the purpose
of RTTI comparisons in libc++abi. This is an incredible luck that we should
not rely on ever again.
While the problem itself was fixed with 2464d8135e2a by setting
LIBCXX_HAS_MERGED_TYPEINFO_NAMES_DEFAULT explicitly in the Apple
CMake cache and then in d0fcdcd28f95 by making the setting less
brittle, the point still is that we should have had a single code
path from the beginning. Unlike most normal libraries, the macros
that configure libc++ are really complex, there's a lot of them and
they control important properties of the C++ runtime. There must be
a single code path for that, and it must be simple and robust.
Differential Revision: https://reviews.llvm.org/D80927
2020-05-15 14:54:27 -04:00
|
|
|
# Generate a custom __config header. The new header is created
|
|
|
|
# by prepending __config_site to the current __config header.
|
|
|
|
add_custom_command(OUTPUT ${LIBCXX_BINARY_DIR}/__generated_config
|
|
|
|
COMMAND ${Python3_EXECUTABLE} ${LIBCXX_SOURCE_DIR}/utils/cat_files.py
|
|
|
|
${LIBCXX_BINARY_DIR}/__config_site
|
|
|
|
${LIBCXX_SOURCE_DIR}/include/__config
|
|
|
|
-o ${LIBCXX_BINARY_DIR}/__generated_config
|
|
|
|
DEPENDS ${LIBCXX_SOURCE_DIR}/include/__config
|
|
|
|
${LIBCXX_BINARY_DIR}/__config_site
|
|
|
|
)
|
|
|
|
# Add a target that executes the generation commands.
|
|
|
|
add_custom_target(cxx-generated-config ALL
|
|
|
|
DEPENDS ${LIBCXX_BINARY_DIR}/__generated_config)
|
2018-03-10 01:20:11 +00:00
|
|
|
|
2019-10-21 23:38:32 +00:00
|
|
|
# In some build configurations (like bootstrapping clang), we need to be able to
|
|
|
|
# install the libcxx headers before the CMake configuration for libcxx runs. Making
|
2019-05-23 17:06:46 +00:00
|
|
|
# the name of this target configurable allows LLVM/runtimes/CMakeLists.txt to
|
|
|
|
# add this subdirectory to the LLVM build to put libcxx's headers in place
|
|
|
|
# before libcxx's build configuration is run.
|
|
|
|
if (NOT CXX_HEADER_TARGET)
|
|
|
|
set(CXX_HEADER_TARGET cxx-headers)
|
|
|
|
endif()
|
2020-06-26 15:05:46 -04:00
|
|
|
if(LIBCXX_HEADER_DIR)
|
2018-06-28 03:11:52 +00:00
|
|
|
set(output_dir ${LIBCXX_HEADER_DIR}/include/c++/v1)
|
2018-06-12 03:10:02 +00:00
|
|
|
|
|
|
|
set(out_files)
|
|
|
|
foreach(f ${files})
|
|
|
|
set(src ${CMAKE_CURRENT_SOURCE_DIR}/${f})
|
|
|
|
set(dst ${output_dir}/${f})
|
|
|
|
add_custom_command(OUTPUT ${dst}
|
|
|
|
DEPENDS ${src}
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E copy_if_different ${src} ${dst}
|
|
|
|
COMMENT "Copying CXX header ${f}")
|
|
|
|
list(APPEND out_files ${dst})
|
|
|
|
endforeach()
|
2018-03-10 01:20:11 +00:00
|
|
|
|
[libc++] Always generate a __config_site header
Before this patch, the __config_site header was only generated when at
least one __config_site macro needed to be defined. This lead to two
different code paths in how libc++ is configured, depending on whether
a __config_site header was generated or not. After this patch, the
__config_site is always generated, but it can be empty in case there
are no macros to define in it.
More context on why this change is important
--------------------------------------------
In addition to being confusing, this double-code-path situation lead to
broken code being checked in undetected in 2405bd689815, which introduced
the LIBCXX_HAS_MERGED_TYPEINFO_NAMES_DEFAULT CMake setting. Specifically,
the _LIBCPP_HAS_MERGED_TYPEINFO_NAMES_DEFAULT <__config_site> macro was
supposed NOT to be defined unless LIBCXX_HAS_MERGED_TYPEINFO_NAMES_DEFAULT
was specified explicitly on the CMake command line. Instead, what happened
is that it was defined to 0 if it wasn't specified explicitly and a
<__config_site> header was generated. And defining that macro to 0 had
the important effect of using the non-unique RTTI comparison implementation,
which changes the ABI.
This change in behavior wasn't noticed because the <__config_site> header
is not generated by default. However, the Apple configuration does cause
a <__config_site> header to be generated, which lead to the wrong RTTI
implementation being used, and to https://llvm.org/PR45549. We came close
to an ABI break in the dylib, but were saved due to a downstream-only
change that overrode the decision of the <__config_site> for the purpose
of RTTI comparisons in libc++abi. This is an incredible luck that we should
not rely on ever again.
While the problem itself was fixed with 2464d8135e2a by setting
LIBCXX_HAS_MERGED_TYPEINFO_NAMES_DEFAULT explicitly in the Apple
CMake cache and then in d0fcdcd28f95 by making the setting less
brittle, the point still is that we should have had a single code
path from the beginning. Unlike most normal libraries, the macros
that configure libc++ are really complex, there's a lot of them and
they control important properties of the C++ runtime. There must be
a single code path for that, and it must be simple and robust.
Differential Revision: https://reviews.llvm.org/D80927
2020-05-15 14:54:27 -04:00
|
|
|
# Copy the generated header as __config into build directory.
|
|
|
|
set(src ${LIBCXX_BINARY_DIR}/__generated_config)
|
|
|
|
set(dst ${output_dir}/__config)
|
|
|
|
add_custom_command(OUTPUT ${dst}
|
2020-06-26 16:05:55 -04:00
|
|
|
DEPENDS ${src} cxx-generated-config
|
[libc++] Always generate a __config_site header
Before this patch, the __config_site header was only generated when at
least one __config_site macro needed to be defined. This lead to two
different code paths in how libc++ is configured, depending on whether
a __config_site header was generated or not. After this patch, the
__config_site is always generated, but it can be empty in case there
are no macros to define in it.
More context on why this change is important
--------------------------------------------
In addition to being confusing, this double-code-path situation lead to
broken code being checked in undetected in 2405bd689815, which introduced
the LIBCXX_HAS_MERGED_TYPEINFO_NAMES_DEFAULT CMake setting. Specifically,
the _LIBCPP_HAS_MERGED_TYPEINFO_NAMES_DEFAULT <__config_site> macro was
supposed NOT to be defined unless LIBCXX_HAS_MERGED_TYPEINFO_NAMES_DEFAULT
was specified explicitly on the CMake command line. Instead, what happened
is that it was defined to 0 if it wasn't specified explicitly and a
<__config_site> header was generated. And defining that macro to 0 had
the important effect of using the non-unique RTTI comparison implementation,
which changes the ABI.
This change in behavior wasn't noticed because the <__config_site> header
is not generated by default. However, the Apple configuration does cause
a <__config_site> header to be generated, which lead to the wrong RTTI
implementation being used, and to https://llvm.org/PR45549. We came close
to an ABI break in the dylib, but were saved due to a downstream-only
change that overrode the decision of the <__config_site> for the purpose
of RTTI comparisons in libc++abi. This is an incredible luck that we should
not rely on ever again.
While the problem itself was fixed with 2464d8135e2a by setting
LIBCXX_HAS_MERGED_TYPEINFO_NAMES_DEFAULT explicitly in the Apple
CMake cache and then in d0fcdcd28f95 by making the setting less
brittle, the point still is that we should have had a single code
path from the beginning. Unlike most normal libraries, the macros
that configure libc++ are really complex, there's a lot of them and
they control important properties of the C++ runtime. There must be
a single code path for that, and it must be simple and robust.
Differential Revision: https://reviews.llvm.org/D80927
2020-05-15 14:54:27 -04:00
|
|
|
COMMAND ${CMAKE_COMMAND} -E copy_if_different ${src} ${dst}
|
|
|
|
COMMENT "Copying CXX __config")
|
|
|
|
list(APPEND out_files ${dst})
|
2020-06-26 16:05:55 -04:00
|
|
|
add_custom_target(generate-cxx-headers DEPENDS ${out_files})
|
2018-06-12 03:10:02 +00:00
|
|
|
|
2020-06-26 16:05:55 -04:00
|
|
|
add_library(${CXX_HEADER_TARGET} INTERFACE)
|
|
|
|
add_dependencies(${CXX_HEADER_TARGET} generate-cxx-headers ${LIBCXX_CXX_ABI_HEADER_TARGET})
|
|
|
|
# TODO: Use target_include_directories once we figure out why that breaks the runtimes build
|
|
|
|
if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC" OR "${CMAKE_CXX_SIMULATE_ID}" STREQUAL "MSVC")
|
|
|
|
target_compile_options(${CXX_HEADER_TARGET} INTERFACE /I "${output_dir}")
|
|
|
|
else()
|
|
|
|
target_compile_options(${CXX_HEADER_TARGET} INTERFACE -I "${output_dir}")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# Make sure the generated __config_site header is included when we build the library.
|
|
|
|
if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC" OR "${CMAKE_CXX_SIMULATE_ID}" STREQUAL "MSVC")
|
|
|
|
target_compile_options(${CXX_HEADER_TARGET} INTERFACE /FI "${LIBCXX_BINARY_DIR}/__config_site")
|
|
|
|
else()
|
|
|
|
target_compile_options(${CXX_HEADER_TARGET} INTERFACE -include "${LIBCXX_BINARY_DIR}/__config_site")
|
|
|
|
endif()
|
2018-06-12 03:10:02 +00:00
|
|
|
else()
|
2020-06-26 16:05:55 -04:00
|
|
|
add_library(${CXX_HEADER_TARGET} INTERFACE)
|
2016-08-30 16:51:34 +00:00
|
|
|
endif()
|
2014-10-23 16:51:12 +00:00
|
|
|
|
2014-12-12 22:52:58 +00:00
|
|
|
if (LIBCXX_INSTALL_HEADERS)
|
2018-06-12 03:10:02 +00:00
|
|
|
foreach(file ${files})
|
|
|
|
get_filename_component(dir ${file} DIRECTORY)
|
|
|
|
install(FILES ${file}
|
2018-07-15 04:09:35 +00:00
|
|
|
DESTINATION ${LIBCXX_INSTALL_HEADER_PREFIX}include/c++/v1/${dir}
|
2019-05-23 17:06:46 +00:00
|
|
|
COMPONENT ${CXX_HEADER_TARGET}
|
2018-06-12 03:10:02 +00:00
|
|
|
PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ
|
|
|
|
)
|
|
|
|
endforeach()
|
[libcxx] Capture configuration information when installing the libc++ headers
Summary:
Hi all,
This patch is a successor to D11963. However it has changed dramatically and I felt it would be best to start a new review thread.
Please read the design documentation added in this patch for a description of how it works.
Reviewers: mclow.lists, danalbert, jroelofs, EricWF
Subscribers: vkalintiris, rnk, ed, espositofulvio, asl, eugenis, cfe-commits
Differential Revision: http://reviews.llvm.org/D13407
llvm-svn: 250235
2015-10-13 22:12:02 +00:00
|
|
|
|
[libc++] Always generate a __config_site header
Before this patch, the __config_site header was only generated when at
least one __config_site macro needed to be defined. This lead to two
different code paths in how libc++ is configured, depending on whether
a __config_site header was generated or not. After this patch, the
__config_site is always generated, but it can be empty in case there
are no macros to define in it.
More context on why this change is important
--------------------------------------------
In addition to being confusing, this double-code-path situation lead to
broken code being checked in undetected in 2405bd689815, which introduced
the LIBCXX_HAS_MERGED_TYPEINFO_NAMES_DEFAULT CMake setting. Specifically,
the _LIBCPP_HAS_MERGED_TYPEINFO_NAMES_DEFAULT <__config_site> macro was
supposed NOT to be defined unless LIBCXX_HAS_MERGED_TYPEINFO_NAMES_DEFAULT
was specified explicitly on the CMake command line. Instead, what happened
is that it was defined to 0 if it wasn't specified explicitly and a
<__config_site> header was generated. And defining that macro to 0 had
the important effect of using the non-unique RTTI comparison implementation,
which changes the ABI.
This change in behavior wasn't noticed because the <__config_site> header
is not generated by default. However, the Apple configuration does cause
a <__config_site> header to be generated, which lead to the wrong RTTI
implementation being used, and to https://llvm.org/PR45549. We came close
to an ABI break in the dylib, but were saved due to a downstream-only
change that overrode the decision of the <__config_site> for the purpose
of RTTI comparisons in libc++abi. This is an incredible luck that we should
not rely on ever again.
While the problem itself was fixed with 2464d8135e2a by setting
LIBCXX_HAS_MERGED_TYPEINFO_NAMES_DEFAULT explicitly in the Apple
CMake cache and then in d0fcdcd28f95 by making the setting less
brittle, the point still is that we should have had a single code
path from the beginning. Unlike most normal libraries, the macros
that configure libc++ are really complex, there's a lot of them and
they control important properties of the C++ runtime. There must be
a single code path for that, and it must be simple and robust.
Differential Revision: https://reviews.llvm.org/D80927
2020-05-15 14:54:27 -04:00
|
|
|
# Install the generated header as __config.
|
|
|
|
install(FILES ${LIBCXX_BINARY_DIR}/__generated_config
|
|
|
|
DESTINATION ${LIBCXX_INSTALL_HEADER_PREFIX}include/c++/v1
|
|
|
|
PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ
|
|
|
|
RENAME __config
|
|
|
|
COMPONENT ${CXX_HEADER_TARGET})
|
2016-04-29 22:17:15 +00:00
|
|
|
|
|
|
|
if (NOT CMAKE_CONFIGURATION_TYPES)
|
2019-05-23 17:06:46 +00:00
|
|
|
add_custom_target(install-${CXX_HEADER_TARGET}
|
2020-06-26 16:05:55 -04:00
|
|
|
DEPENDS ${CXX_HEADER_TARGET} cxx-generated-config
|
2016-04-29 22:17:15 +00:00
|
|
|
COMMAND "${CMAKE_COMMAND}"
|
2019-05-23 17:06:46 +00:00
|
|
|
-DCMAKE_INSTALL_COMPONENT=${CXX_HEADER_TARGET}
|
2016-04-29 22:17:15 +00:00
|
|
|
-P "${CMAKE_BINARY_DIR}/cmake_install.cmake")
|
2017-12-06 21:03:42 +00:00
|
|
|
# Stripping is a no-op for headers
|
2019-05-23 17:06:46 +00:00
|
|
|
add_custom_target(install-${CXX_HEADER_TARGET}-stripped DEPENDS install-${CXX_HEADER_TARGET})
|
[libcxx] Capture configuration information when installing the libc++ headers
Summary:
Hi all,
This patch is a successor to D11963. However it has changed dramatically and I felt it would be best to start a new review thread.
Please read the design documentation added in this patch for a description of how it works.
Reviewers: mclow.lists, danalbert, jroelofs, EricWF
Subscribers: vkalintiris, rnk, ed, espositofulvio, asl, eugenis, cfe-commits
Differential Revision: http://reviews.llvm.org/D13407
llvm-svn: 250235
2015-10-13 22:12:02 +00:00
|
|
|
endif()
|
2014-12-12 22:52:58 +00:00
|
|
|
endif()
|