
The standard isn't exactly clear how std::array should handle zero-sized arrays with const element types. In particular W.R.T. copy assignment, swap, and fill. This patch takes the position that those operations should be ill-formed, and makes changes to libc++ to make it so. This follows up on commit r324182. llvm-svn: 324185
58 lines
1.4 KiB
C++
58 lines
1.4 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.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// <array>
|
|
|
|
// T *data();
|
|
|
|
#include <array>
|
|
#include <cassert>
|
|
|
|
// std::array is explicitly allowed to be initialized with A a = { init-list };.
|
|
// Disable the missing braces warning for this reason.
|
|
#include "disable_missing_braces_warning.h"
|
|
|
|
int main()
|
|
{
|
|
{
|
|
typedef double T;
|
|
typedef std::array<T, 3> C;
|
|
C c = {1, 2, 3.5};
|
|
T* p = c.data();
|
|
assert(p[0] == 1);
|
|
assert(p[1] == 2);
|
|
assert(p[2] == 3.5);
|
|
}
|
|
{
|
|
typedef double T;
|
|
typedef std::array<T, 0> C;
|
|
C c = {};
|
|
T* p = c.data();
|
|
(void)p; // to placate scan-build
|
|
}
|
|
{
|
|
typedef double T;
|
|
typedef std::array<const T, 0> C;
|
|
C c = {};
|
|
const T* p = c.data();
|
|
static_assert((std::is_same<decltype(c.data()), const T*>::value), "");
|
|
(void)p; // to placate scan-build
|
|
}
|
|
{
|
|
struct NoDefault {
|
|
NoDefault(int) {}
|
|
};
|
|
typedef NoDefault T;
|
|
typedef std::array<T, 0> C;
|
|
C c = {};
|
|
T* p = c.data();
|
|
assert(p != nullptr);
|
|
}
|
|
}
|