Mercurial > hg > CbC > CbC_llvm
view libcxxabi/test/catch_reference_nullptr.pass.cpp @ 236:c4bab56944e8 llvm-original
LLVM 16
author | kono |
---|---|
date | Wed, 09 Nov 2022 17:45:10 +0900 |
parents | 79ff65ed7e25 |
children | 1f2b6ac9f198 |
line wrap: on
line source
//===----------------------------------------------------------------------===// // // 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: c++03, // UNSUPPORTED: no-exceptions #include <cassert> #include <cstdlib> struct A {}; template<typename T, bool CanCatchNullptr> static void catch_nullptr_test() { try { throw nullptr; } catch (T &p) { assert(CanCatchNullptr && !static_cast<bool>(p)); } catch (...) { assert(!CanCatchNullptr); } } int main(int, char**) { using nullptr_t = decltype(nullptr); // A reference to nullptr_t can catch nullptr. catch_nullptr_test<nullptr_t, true>(); catch_nullptr_test<const nullptr_t, true>(); catch_nullptr_test<volatile nullptr_t, true>(); catch_nullptr_test<const volatile nullptr_t, true>(); // No other reference type can. #if 0 // FIXME: These tests fail, because the ABI provides no way for us to // distinguish this from catching by value. catch_nullptr_test<void *, false>(); catch_nullptr_test<void * const, false>(); catch_nullptr_test<int *, false>(); catch_nullptr_test<A *, false>(); catch_nullptr_test<int A::*, false>(); catch_nullptr_test<int (A::*)(), false>(); #endif return 0; }