mirror of
https://github.com/llvm-mirror/libcxx.git
synced 2025-10-21 06:40:06 +08:00

LLVM uses .h as its extension for header files. Files renamed using: for f in libcxx/test/support/*.hpp; do git mv $f ${f%.hpp}.h; done References to the files updated using: for f in $(git diff master | grep 'rename from' | cut -f 3 -d ' '); do a=$(basename $f); echo $a; rg -l $a libcxx | xargs sed -i '' "s/$a/${a%.hpp}.h/"; done HPP include guards updated manually using: for f in $(git diff master | grep 'rename from' | cut -f 3 -d ' '); do echo ${f%.hpp}.h ; done | xargs mvim Differential Revision: https://reviews.llvm.org/D66104 git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@369481 91177308-0d34-0410-b5e6-96231b3b80d8
77 lines
2.6 KiB
C++
77 lines
2.6 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// UNSUPPORTED: c++98, c++03
|
|
|
|
// <experimental/memory_resource>
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// TESTING memory_resource * get_default_resource() noexcept;
|
|
// memory_resource * set_default_resource(memory_resource*) noexcept;
|
|
//
|
|
// Concerns:
|
|
// A) 'get_default_resource()' returns a non-null memory_resource pointer.
|
|
// B) 'get_default_resource()' returns the value set by the last call to
|
|
// 'set_default_resource(...)' and 'new_delete_resource()' if no call
|
|
// to 'set_default_resource(...)' has occurred.
|
|
// C) 'set_default_resource(...)' returns the previous value of the default
|
|
// resource.
|
|
// D) 'set_default_resource(T* p)' for a non-null 'p' sets the default resource
|
|
// to be 'p'.
|
|
// E) 'set_default_resource(null)' sets the default resource to
|
|
// 'new_delete_resource()'.
|
|
// F) 'get_default_resource' and 'set_default_resource' are noexcept.
|
|
|
|
|
|
#include <experimental/memory_resource>
|
|
#include <cassert>
|
|
|
|
#include "test_memory_resource.h"
|
|
|
|
#include "test_macros.h"
|
|
|
|
using namespace std::experimental::pmr;
|
|
|
|
int main(int, char**) {
|
|
TestResource R;
|
|
{ // Test (A) and (B)
|
|
memory_resource* p = get_default_resource();
|
|
assert(p != nullptr);
|
|
assert(p == new_delete_resource());
|
|
assert(p == get_default_resource());
|
|
}
|
|
{ // Test (C) and (D)
|
|
memory_resource *expect = &R;
|
|
memory_resource *old = set_default_resource(expect);
|
|
assert(old != nullptr);
|
|
assert(old == new_delete_resource());
|
|
|
|
memory_resource *p = get_default_resource();
|
|
assert(p != nullptr);
|
|
assert(p == expect);
|
|
assert(p == get_default_resource());
|
|
}
|
|
{ // Test (E)
|
|
memory_resource* old = set_default_resource(nullptr);
|
|
assert(old == &R);
|
|
memory_resource* p = get_default_resource();
|
|
assert(p != nullptr);
|
|
assert(p == new_delete_resource());
|
|
assert(p == get_default_resource());
|
|
}
|
|
{ // Test (F)
|
|
static_assert(noexcept(get_default_resource()),
|
|
"get_default_resource() must be noexcept");
|
|
|
|
static_assert(noexcept(set_default_resource(nullptr)),
|
|
"set_default_resource() must be noexcept");
|
|
}
|
|
|
|
return 0;
|
|
}
|