Skip to content

Commit

Permalink
[libc++] Add a test case for std::bit_cast with std::complex (#97751)
Browse files Browse the repository at this point in the history
This is extracted from #94620. While libc++ doesn't have the problem
described in that issue, a test case is a good idea to ensure that we
don't regress this behavior in the future. This could happen for example
if we decide to use `_Complex` in the implementation of `std::complex`
while Clang doesn't handle bit_cast with _Complex yet.
  • Loading branch information
ldionne authored Jul 8, 2024
1 parent 4b53cbb commit 8ab82a2
Showing 1 changed file with 36 additions and 0 deletions.
36 changes: 36 additions & 0 deletions libcxx/test/std/numerics/complex.number/complex/bit_cast.pass.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
//===----------------------------------------------------------------------===//
//
// 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, c++11, c++14, c++17

// Make sure that std::bit_cast works with std::complex. Test case extracted from
// https://github.com/llvm/llvm-project/issues/94620.

#include <bit>
#include <complex>

template <class T>
constexpr void test() {
using Complex = std::complex<T>;
unsigned char data[sizeof(Complex)] = {0};

[[maybe_unused]] Complex c = std::bit_cast<Complex>(data);
}

constexpr bool test_all() {
test<float>();
test<double>();
test<long double>();
return true;
}

int main(int, char**) {
test_all();
static_assert(test_all());
return 0;
}

0 comments on commit 8ab82a2

Please sign in to comment.