llvm-project/clang/test/PCH/cxx1z-aligned-alloc.cpp

39 lines
1.1 KiB
C++

// No PCH:
// RUN: %clang_cc1 -pedantic -fsized-deallocation -std=c++1z -include %s -verify %s
//
// With PCH:
// RUN: %clang_cc1 -pedantic -fsized-deallocation -std=c++1z -emit-pch %s -o %t
// RUN: %clang_cc1 -pedantic -fsized-deallocation -std=c++1z -include-pch %t -verify %s
// RUN: %clang_cc1 -pedantic -fsized-deallocation -std=c++1z -emit-pch -fpch-instantiate-templates %s -o %t
// RUN: %clang_cc1 -pedantic -fsized-deallocation -std=c++1z -include-pch %t -verify %s
// expected-no-diagnostics
#ifndef HEADER
#define HEADER
using size_t = decltype(sizeof(0));
// Call the overaligned form of 'operator new'.
struct alignas(256) Q { int n; };
void *f() { return new Q; }
// Extract the std::align_val_t type from the implicit declaration of operator delete.
template<typename AlignValT>
AlignValT extract(void (*)(void*, size_t, AlignValT));
using T = decltype(extract(&operator delete));
#else
// ok, calls aligned allocation via placement syntax
void *q = new (T{16}) Q;
namespace std {
enum class align_val_t : size_t {};
}
using T = std::align_val_t; // ok, same type
#endif