aboutsummaryrefslogtreecommitdiff
path: root/libcxx/src/stdexcept.cpp
diff options
context:
space:
mode:
authorEric Fiselier <eric@efcs.ca>2019-03-05 01:57:01 +0000
committerEric Fiselier <eric@efcs.ca>2019-03-05 01:57:01 +0000
commite69290dc7ff7319acf5904f15ab6630fad07ab58 (patch)
tree35b89875fe5bc992c80f093fbaa91547aa06f9af /libcxx/src/stdexcept.cpp
parent3fd4a968ad80d603ea4dbd616c00824cf165e384 (diff)
downloadllvm-e69290dc7ff7319acf5904f15ab6630fad07ab58.zip
llvm-e69290dc7ff7319acf5904f15ab6630fad07ab58.tar.gz
llvm-e69290dc7ff7319acf5904f15ab6630fad07ab58.tar.bz2
Make VCRuntime ABI configuration a first-class option.
Summary: On Windows we currently provide two separate ABI configurations. One which defers to `vcruntime` to provide the C++ runtime and another which doesn't. Using `vcruntime` allows interoperability which programs compiled against the MSVC STL, and should be preferred whenever possible. When deferring to `vcruntime` much of the ABI we provide changes. Including the layout of `<stdexcept>` types, their vtables, and how the linkage of their members. This patch introduces the `_LIBCPP_ABI_VCRUNTIME` macro to denote this configuration. It also cleans up the existing configuration for using `vcruntime`. This cleanup lays the groundwork for fixing a number of ABI and interoperability bugs in `<stdexcept>`. Reviewers: thomasanderson, ldionne, smeenai Reviewed By: smeenai Subscribers: jdoerfert, libcxx-commits, #libc Differential Revision: https://reviews.llvm.org/D58942 llvm-svn: 355366
Diffstat (limited to 'libcxx/src/stdexcept.cpp')
-rw-r--r--libcxx/src/stdexcept.cpp2
1 files changed, 1 insertions, 1 deletions
diff --git a/libcxx/src/stdexcept.cpp b/libcxx/src/stdexcept.cpp
index 179c250..1507062 100644
--- a/libcxx/src/stdexcept.cpp
+++ b/libcxx/src/stdexcept.cpp
@@ -77,7 +77,7 @@ runtime_error::what() const _NOEXCEPT
return __imp_.c_str();
}
-#if !defined(_LIBCPP_ABI_MICROSOFT) || defined(_LIBCPP_NO_VCRUNTIME)
+#if !defined(_LIBCPP_ABI_VCRUNTIME)
logic_error::~logic_error() _NOEXCEPT {}
domain_error::~domain_error() _NOEXCEPT {}