blob: 4dfe9063a23eb3dde65fc0835e038fd8c23db097 [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(size_type n, charT c, 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(unsigned n, charT c)
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(n, c);
Dan Albert1d4a1ed2016-05-25 22:36:09 -070030 assert(s2.__invariants());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000031 assert(s2.size() == n);
32 for (unsigned i = 0; i < n; ++i)
33 assert(s2[i] == c);
34 assert(s2.get_allocator() == A());
35 assert(s2.capacity() >= s2.size());
36}
37
Howard Hinnant9dcdcde2013-06-28 16:59:19 +000038template <class charT, class A>
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000039void
Howard Hinnant9dcdcde2013-06-28 16:59:19 +000040test(unsigned n, charT c, const A& a)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000041{
Howard Hinnant9dcdcde2013-06-28 16:59:19 +000042 typedef std::basic_string<charT, std::char_traits<charT>, A> S;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000043 typedef typename S::traits_type T;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000044 S s2(n, c, a);
Dan Albert1d4a1ed2016-05-25 22:36:09 -070045 assert(s2.__invariants());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000046 assert(s2.size() == n);
47 for (unsigned i = 0; i < n; ++i)
48 assert(s2[i] == c);
49 assert(s2.get_allocator() == a);
50 assert(s2.capacity() >= s2.size());
51}
52
53template <class Tp>
54void
55test(Tp n, Tp c)
56{
57 typedef char charT;
58 typedef std::basic_string<charT, std::char_traits<charT>, test_allocator<charT> > S;
59 typedef typename S::traits_type T;
60 typedef typename S::allocator_type A;
61 S s2(n, c);
Dan Albert1d4a1ed2016-05-25 22:36:09 -070062 assert(s2.__invariants());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000063 assert(s2.size() == n);
64 for (unsigned i = 0; i < n; ++i)
65 assert(s2[i] == c);
66 assert(s2.get_allocator() == A());
67 assert(s2.capacity() >= s2.size());
68}
69
Howard Hinnant9dcdcde2013-06-28 16:59:19 +000070template <class Tp, class A>
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000071void
Howard Hinnant9dcdcde2013-06-28 16:59:19 +000072test(Tp n, Tp c, const A& a)
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000073{
74 typedef char charT;
Howard Hinnant9dcdcde2013-06-28 16:59:19 +000075 typedef std::basic_string<charT, std::char_traits<charT>, A> S;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000076 typedef typename S::traits_type T;
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000077 S s2(n, c, a);
Dan Albert1d4a1ed2016-05-25 22:36:09 -070078 assert(s2.__invariants());
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000079 assert(s2.size() == n);
80 for (unsigned i = 0; i < n; ++i)
81 assert(s2[i] == c);
82 assert(s2.get_allocator() == a);
83 assert(s2.capacity() >= s2.size());
84}
85
86int main()
87{
Howard Hinnant9dcdcde2013-06-28 16:59:19 +000088 {
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000089 typedef test_allocator<char> A;
90 typedef std::basic_string<char, std::char_traits<char>, A> S;
91
92 test(0, 'a');
93 test(0, 'a', A(2));
94
95 test(1, 'a');
96 test(1, 'a', A(2));
97
98 test(10, 'a');
99 test(10, 'a', A(2));
100
101 test(100, 'a');
102 test(100, 'a', A(2));
103
104 test(100, 65);
105 test(100, 65, A(3));
Howard Hinnant9dcdcde2013-06-28 16:59:19 +0000106 }
Dan Albert1d4a1ed2016-05-25 22:36:09 -0700107#if __cplusplus >= 201103L
Howard Hinnant9dcdcde2013-06-28 16:59:19 +0000108 {
109 typedef min_allocator<char> A;
110 typedef std::basic_string<char, std::char_traits<char>, A> S;
111
112 test(0, 'a');
113 test(0, 'a', A());
114
115 test(1, 'a');
116 test(1, 'a', A());
117
118 test(10, 'a');
119 test(10, 'a', A());
120
121 test(100, 'a');
122 test(100, 'a', A());
123
124 test(100, 65);
125 test(100, 65, A());
126 }
127#endif
Howard Hinnantbc8d3f92010-05-11 19:42:16 +0000128}