blob: f1f107af20bb14d9c792aae6b6d32a31a68f0db6 [file] [log] [blame]
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001//===----------------------------------------------------------------------===//
2//
Howard Hinnantf5256e12010-05-11 21:36:01 +00003// The LLVM Compiler Infrastructure
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00004//
Howard Hinnantb64f8b02010-11-16 22:09:02 +00005// This file is dual licensed under the MIT and the University of Illinois Open
6// Source Licenses. See LICENSE.TXT for details.
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00007//
8//===----------------------------------------------------------------------===//
9
10// <string>
11
12// basic_string(const charT* s, size_type n, const Allocator& a = Allocator());
13
14#include <string>
15#include <stdexcept>
16#include <algorithm>
17#include <cassert>
18
Marshall Clow1b921882013-12-03 00:18:10 +000019#include "test_allocator.h"
Marshall Clow061d0cc2013-11-26 20:58:02 +000020#include "min_allocator.h"
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000021
22template <class charT>
23void
24test(const charT* s, unsigned n)
25{
26 typedef std::basic_string<charT, std::char_traits<charT>, test_allocator<charT> > S;
27 typedef typename S::traits_type T;
28 typedef typename S::allocator_type A;
29 S s2(s, n);
Dan Albert1d4a1ed2016-05-25 22:36:09 -070030 assert(s2.__invariants());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000031 assert(s2.size() == n);
32 assert(T::compare(s2.data(), s, n) == 0);
33 assert(s2.get_allocator() == A());
34 assert(s2.capacity() >= s2.size());
35}
36
Howard Hinnant9dcdcde2013-06-28 16:59:19 +000037template <class charT, class A>
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000038void
Howard Hinnant9dcdcde2013-06-28 16:59:19 +000039test(const charT* s, unsigned n, const A& a)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000040{
Howard Hinnant9dcdcde2013-06-28 16:59:19 +000041 typedef std::basic_string<charT, std::char_traits<charT>, A> S;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000042 typedef typename S::traits_type T;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000043 S s2(s, n, a);
Dan Albert1d4a1ed2016-05-25 22:36:09 -070044 assert(s2.__invariants());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000045 assert(s2.size() == n);
46 assert(T::compare(s2.data(), s, n) == 0);
47 assert(s2.get_allocator() == a);
48 assert(s2.capacity() >= s2.size());
49}
50
51int main()
52{
Howard Hinnant9dcdcde2013-06-28 16:59:19 +000053 {
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000054 typedef test_allocator<char> A;
55 typedef std::basic_string<char, std::char_traits<char>, A> S;
56
57 test("", 0);
58 test("", 0, A(2));
59
60 test("1", 1);
61 test("1", 1, A(2));
62
63 test("1234567980", 10);
64 test("1234567980", 10, A(2));
65
66 test("123456798012345679801234567980123456798012345679801234567980", 60);
67 test("123456798012345679801234567980123456798012345679801234567980", 60, A(2));
Howard Hinnant9dcdcde2013-06-28 16:59:19 +000068 }
Dan Albert1d4a1ed2016-05-25 22:36:09 -070069#if __cplusplus >= 201103L
Howard Hinnant9dcdcde2013-06-28 16:59:19 +000070 {
71 typedef min_allocator<char> A;
72 typedef std::basic_string<char, std::char_traits<char>, A> S;
73
74 test("", 0);
75 test("", 0, A());
76
77 test("1", 1);
78 test("1", 1, A());
79
80 test("1234567980", 10);
81 test("1234567980", 10, A());
82
83 test("123456798012345679801234567980123456798012345679801234567980", 60);
84 test("123456798012345679801234567980123456798012345679801234567980", 60, A());
85 }
86#endif
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000087}