This patch adds a separate `extensions` directory, since there are quite a few extensions in libc++ that aren't necessarily libc++-specific. For example, the tests currently in `libcxx/test/libcxx/extensions` should also pass with libstdc++, since they originally added the extension. This also "documents" what users are allowed to rely on and what parts are just libc++ tests to make sure our implementation is behaving as we expect, which may be subject to change. This patch also formats the tests and refactors `.fail.cpp` tests to `.verify.cpp` tests.
32 lines
1.2 KiB
C++
32 lines
1.2 KiB
C++
//===----------------------------------------------------------------------===//
|
|
//
|
|
// 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Prevent <ext/hash_set> from generating deprecated warnings for this test.
|
|
// ADDITIONAL_COMPILE_FLAGS: -Wno-deprecated
|
|
|
|
#include <cassert>
|
|
#include <ext/hash_map>
|
|
#include <string>
|
|
|
|
int main(int, char**) {
|
|
char str[] = "test";
|
|
assert(__gnu_cxx::hash<const char*>()("test") == std::hash<std::string>()("test"));
|
|
assert(__gnu_cxx::hash<char*>()(str) == std::hash<std::string>()("test"));
|
|
assert(__gnu_cxx::hash<char>()(42) == 42);
|
|
assert(__gnu_cxx::hash<signed char>()(42) == 42);
|
|
assert(__gnu_cxx::hash<unsigned char>()(42) == 42);
|
|
assert(__gnu_cxx::hash<short>()(42) == 42);
|
|
assert(__gnu_cxx::hash<unsigned short>()(42) == 42);
|
|
assert(__gnu_cxx::hash<int>()(42) == 42);
|
|
assert(__gnu_cxx::hash<unsigned int>()(42) == 42);
|
|
assert(__gnu_cxx::hash<long>()(42) == 42);
|
|
assert(__gnu_cxx::hash<unsigned long>()(42) == 42);
|
|
|
|
return 0;
|
|
}
|