blob: 630565b7d77f67277cf1f053282f7e30131b11e9 [file] [log] [blame]
Howard Hinnant3e519522010-05-11 19:42:16 +00001//===----------------------------------------------------------------------===//
2//
Howard Hinnant5b08a8a2010-05-11 21:36:01 +00003// The LLVM Compiler Infrastructure
Howard Hinnant3e519522010-05-11 19:42:16 +00004//
Howard Hinnant412dbeb2010-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 Hinnant3e519522010-05-11 19:42:16 +00007//
8//===----------------------------------------------------------------------===//
9
10// <string>
11
12// reverse_iterator rend();
13// const_reverse_iterator rend() const;
14
15#include <string>
16#include <cassert>
17
Howard Hinnanteec72182013-06-28 16:59:19 +000018#include "../min_allocator.h"
19
Howard Hinnant3e519522010-05-11 19:42:16 +000020template <class S>
21void
22test(S s)
23{
24 const S& cs = s;
25 typename S::reverse_iterator e = s.rend();
26 typename S::const_reverse_iterator ce = cs.rend();
27 if (s.empty())
28 {
29 assert(e == s.rbegin());
30 assert(ce == cs.rbegin());
31 }
32 assert(e - s.rbegin() == s.size());
33 assert(ce - cs.rbegin() == cs.size());
34}
35
36int main()
37{
Howard Hinnanteec72182013-06-28 16:59:19 +000038 {
Howard Hinnant3e519522010-05-11 19:42:16 +000039 typedef std::string S;
40 test(S());
41 test(S("123"));
Howard Hinnanteec72182013-06-28 16:59:19 +000042 }
43#if __cplusplus >= 201103L
44 {
45 typedef std::basic_string<char, std::char_traits<char>, min_allocator<char>> S;
46 test(S());
47 test(S("123"));
48 }
49#endif
Howard Hinnant3e519522010-05-11 19:42:16 +000050}