//===----------------------------------------------------------------------===// // // 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 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 constexpr bool is_complete_imp(int) { return true; } template constexpr bool is_complete_imp(long) { return false; } template constexpr bool is_complete() { return is_complete_imp(0); } template struct has_complete_hash { enum { value = is_complete >() }; }; int main() { static_assert(LibraryHashTypes::assertTrait(), ""); }