mirror of
https://github.com/llvm-mirror/libcxx.git
synced 2025-10-24 12:02:36 +08:00

Summary: Exactly what the title says. This patch also adds a `std::hash<nullptr_t>` specialization in C++17, but it was not added by this paper and I can't find the actual paper that adds it. See http://wg21.link/P0513R0 for more info. If there are no comments in the next couple of days I'll commit this Reviewers: mclow.lists, K-ballo, EricWF Reviewed By: EricWF Subscribers: cfe-commits Differential Revision: https://reviews.llvm.org/D28938 git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@292684 91177308-0d34-0410-b5e6-96231b3b80d8
31 lines
1.1 KiB
C++
31 lines
1.1 KiB
C++
//===----------------------------------------------------------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
|
// Source Licenses. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// UNSUPPORTED: c++98, c++03
|
|
|
|
// Test that the header `poisoned_hash_helper.hpp` doesn't include any
|
|
// headers that provide hash<T> specializations. This is required so that the
|
|
// 'test_library_hash_specializations_available()' function returns false
|
|
// by default, unless a STL header providing hash has already been included.
|
|
|
|
#include "poisoned_hash_helper.hpp"
|
|
|
|
template <class T, size_t = sizeof(T)>
|
|
constexpr bool is_complete_imp(int) { return true; }
|
|
template <class> constexpr bool is_complete_imp(long) { return false; }
|
|
template <class T> constexpr bool is_complete() { return is_complete_imp<T>(0); }
|
|
|
|
template <class T> struct has_complete_hash {
|
|
enum { value = is_complete<std::hash<T> >() };
|
|
};
|
|
|
|
int main() {
|
|
static_assert(LibraryHashTypes::assertTrait<has_complete_hash, false>(), "");
|
|
}
|