Initial implementation of <dynarray>. No allocator support pending resolution of LWG #2235; no stack allocation pending compiler support

git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@190697 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Marshall Clow
2013-09-13 15:22:55 +00:00
parent f4107076e4
commit 27a1c252e3
13 changed files with 1079 additions and 0 deletions

View File

@@ -0,0 +1,49 @@
//===----------------------------------------------------------------------===//
//
// 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.
//
//===----------------------------------------------------------------------===//
// dynarray.zero
// dynarray shall provide support for the special case of construction with a size of zero.
// In the case that the size is zero, begin() == end() == unique value.
// The return value of data() is unspecified.
// The effect of calling front() or back() for a zero-sized dynarray is undefined.
#include <__config>
#if _LIBCPP_STD_VER > 11
#include <dynarray>
#include <cassert>
#include <algorithm>
#include <complex>
#include <string>
template <class T>
void test ( ) {
typedef std::dynarray<T> dynA;
dynA d1 ( 0 );
assert ( d1.size() == 0 );
assert ( d1.begin() == d1.end ());
}
int main()
{
test<int> ();
test<double> ();
test<std::complex<double>> ();
test<std::string> ();
}
#else
int main() {}
#endif