// 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 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