[test] Cleanup nullopt_t tests

* Update specification text from N4387

* Delete not_brace_initializable.fail.cpp: it's redundant with nullopt_t.fail.cpp

* is_empty<T> implies is_class<T>

* is_literal is deprecated; directly verify that we can create a nullopt_t in a constexpr context

Differential Revision: D37024

llvm-svn: 312256
This commit is contained in:
Casey Carter 2017-08-31 17:56:31 +00:00
parent 6589748920
commit e38efe12da
3 changed files with 14 additions and 44 deletions

View File

@ -1,25 +0,0 @@
//===----------------------------------------------------------------------===//
//
// 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, c++11, c++14
// <optional>
// struct nullopt_t{see below};
#include <optional>
using std::optional;
using std::nullopt_t;
int main()
{
// I roughly interpret LWG2736 as "it shall not be possible to copy-list-initialize nullopt_t with an
// empty braced-init-list."
nullopt_t foo = {};
}

View File

@ -11,15 +11,13 @@
// <optional>
// struct nullopt_t{see below};
// constexpr nullopt_t nullopt(unspecified);
// inline constexpr nullopt_t nullopt(unspecified);
// [optional.nullopt]/2:
// Type nullopt_t shall not have a default constructor or an initializer-list constructor.
// It shall not be an aggregate and shall be a literal type.
// Constant nullopt shall be initialized with an argument of literal type.
// Type nullopt_t shall not have a default constructor or an initializer-list
// constructor, and shall not be an aggregate.
#include <optional>
#include "test_macros.h"
int main()
{

View File

@ -11,33 +11,30 @@
// <optional>
// struct nullopt_t{see below};
// constexpr nullopt_t nullopt(unspecified);
// inline constexpr nullopt_t nullopt(unspecified);
// [optional.nullopt]/2:
// Type nullopt_t shall not have a default constructor or an initializer-list constructor.
// It shall not be an aggregate and shall be a literal type.
// Constant nullopt shall be initialized with an argument of literal type.
// Type nullopt_t shall not have a default constructor or an initializer-list
// constructor, and shall not be an aggregate.
#include <optional>
#include <type_traits>
using std::optional;
using std::nullopt_t;
using std::nullopt;
constexpr
int
test(const nullopt_t&)
constexpr bool test()
{
return 3;
nullopt_t foo{nullopt};
(void)foo;
return true;
}
int main()
{
static_assert(( std::is_class<nullopt_t>::value), "");
static_assert(( std::is_empty<nullopt_t>::value), "");
static_assert(( std::is_literal_type<nullopt_t>::value), "");
static_assert((!std::is_default_constructible<nullopt_t>::value), "");
static_assert(std::is_empty_v<nullopt_t>);
static_assert(!std::is_default_constructible_v<nullopt_t>);
static_assert(test(nullopt) == 3, "");
static_assert(std::is_same_v<const nullopt_t, decltype(nullopt)>);
static_assert(test());
}