llvm-capstone/libcxxabi/test/catch_member_data_pointer_01.pass.cpp
Louis Dionne ed61d6a466 [libc++] Use the stdlib=<LIB> Lit feature instead of use_system_cxx_lib
The use_system_cxx_lib Lit feature was only used for back-deployment
testing. However, one immense hole in that setup was that we didn't
have a proper way to test Apple's own libc++ outside of back-deployment,
which was embodied by the fact that we needed to define _LIBCPP_DISABLE_AVAILABILITY
when testing (see change in libcxx/utils/libcxx/test/params.py).

This led to the apple-system testing configuration not checking for
availability markup, which is obviously quite bad since the library
we ship actually has availability markup.

Using stdlib=<VENDOR>-libc++ instead to encode back-deployment restrictions
on tests is simpler and it makes it possible to naturally support tests
such as availability markup checking even in the tip-of-trunk Apple-libc++
configuration.

Differential Revision: https://reviews.llvm.org/D146366
2023-03-30 06:57:56 -04:00

180 lines
2.6 KiB
C++

//===----------------------------------------------------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
// UNSUPPORTED: no-exceptions
// 1b00fc5d8133 made it in the dylib in macOS 10.11
// XFAIL: stdlib=apple-libc++ && target={{.+}}-apple-macosx10.{{9|10}}
#include <cassert>
struct A
{
A() : i(0), j(0) {} // explicitly initialize 'i' to prevent warnings
const int i;
int j;
};
typedef const int A::*md1;
typedef int A::*md2;
struct B : public A
{
B() : k(0), l(0) {} // explicitly initialize 'k' to prevent warnings.
const int k;
int l;
};
typedef const int B::*der1;
typedef int B::*der2;
void test1()
{
try
{
throw &A::i;
assert(false);
}
catch (md2)
{
assert(false);
}
catch (md1)
{
}
}
// Check that cv qualified conversions are allowed.
void test2()
{
try
{
throw &A::j;
}
catch (md2)
{
}
catch (...)
{
assert(false);
}
try
{
throw &A::j;
assert(false);
}
catch (md1)
{
}
catch (...)
{
assert(false);
}
}
// Check that Base -> Derived conversions are NOT allowed.
void test3()
{
try
{
throw &A::i;
assert(false);
}
catch (md2)
{
assert(false);
}
catch (der2)
{
assert(false);
}
catch (der1)
{
assert(false);
}
catch (md1)
{
}
}
// Check that Base -> Derived conversions NOT are allowed with different cv
// qualifiers.
void test4()
{
try
{
throw &A::j;
assert(false);
}
catch (der2)
{
assert(false);
}
catch (der1)
{
assert(false);
}
catch (md2)
{
}
catch (...)
{
assert(false);
}
}
// Check that no Derived -> Base conversions are allowed.
void test5()
{
try
{
throw &B::k;
assert(false);
}
catch (md1)
{
assert(false);
}
catch (md2)
{
assert(false);
}
catch (der1)
{
}
try
{
throw &B::l;
assert(false);
}
catch (md1)
{
assert(false);
}
catch (md2)
{
assert(false);
}
catch (der2)
{
}
}
int main(int, char**)
{
test1();
test2();
test3();
test4();
test5();
return 0;
}