1 //===----------------------------------------------------------------------===//
2 //
3 // The LLVM Compiler Infrastructure
4 //
5 // This file is dual licensed under the MIT and the University of Illinois Open
6 // Source Licenses. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9
10 // <locale>
11
12 // class time_get<charT, InputIterator>
13
14 // iter_type
15 // get_time(iter_type s, iter_type end, ios_base& str,
16 // ios_base::iostate& err, tm* t) const;
17
18 #include <locale>
19 #include <cassert>
20 #include "test_iterators.h"
21
22 typedef input_iterator<const char*> I;
23
24 typedef std::time_get<char, I> F;
25
26 class my_facet
27 : public F
28 {
29 public:
my_facet(std::size_t refs=0)30 explicit my_facet(std::size_t refs = 0)
31 : F(refs) {}
32 };
33
main()34 int main()
35 {
36 const my_facet f(1);
37 std::ios ios(0);
38 std::ios_base::iostate err;
39 std::tm t;
40 {
41 const char in[] = "0:0:0";
42 err = std::ios_base::goodbit;
43 t = std::tm();
44 I i = f.get_time(I(in), I(in+sizeof(in)-1), ios, err, &t);
45 assert(i.base() == in+sizeof(in)-1);
46 assert(t.tm_hour == 0);
47 assert(t.tm_min == 0);
48 assert(t.tm_sec == 0);
49 assert(err == std::ios_base::eofbit);
50 }
51 {
52 const char in[] = "23:59:60";
53 err = std::ios_base::goodbit;
54 t = std::tm();
55 I i = f.get_time(I(in), I(in+sizeof(in)-1), ios, err, &t);
56 assert(i.base() == in+sizeof(in)-1);
57 assert(t.tm_hour == 23);
58 assert(t.tm_min == 59);
59 assert(t.tm_sec == 60);
60 assert(err == std::ios_base::eofbit);
61 }
62 {
63 const char in[] = "24:59:60";
64 err = std::ios_base::goodbit;
65 t = std::tm();
66 I i = f.get_time(I(in), I(in+sizeof(in)-1), ios, err, &t);
67 assert(i.base() == in+2);
68 assert(t.tm_hour == 0);
69 assert(t.tm_min == 0);
70 assert(t.tm_sec == 0);
71 assert(err == std::ios_base::failbit);
72 }
73 {
74 const char in[] = "23:60:60";
75 err = std::ios_base::goodbit;
76 t = std::tm();
77 I i = f.get_time(I(in), I(in+sizeof(in)-1), ios, err, &t);
78 assert(i.base() == in+5);
79 // assert(t.tm_hour == 0);
80 // assert(t.tm_min == 0);
81 // assert(t.tm_sec == 0);
82 assert(err == std::ios_base::failbit);
83 }
84 {
85 const char in[] = "23:59:61";
86 err = std::ios_base::goodbit;
87 t = std::tm();
88 I i = f.get_time(I(in), I(in+sizeof(in)-1), ios, err, &t);
89 assert(i.base() == in+8);
90 // assert(t.tm_hour == 0);
91 // assert(t.tm_min == 0);
92 // assert(t.tm_sec == 0);
93 assert(err == (std::ios_base::failbit | std::ios_base::eofbit));
94 }
95 {
96 const char in[] = "2:43:221";
97 err = std::ios_base::goodbit;
98 t = std::tm();
99 I i = f.get_time(I(in), I(in+sizeof(in)-1), ios, err, &t);
100 assert(i.base() == in+7);
101 assert(t.tm_hour == 2);
102 assert(t.tm_min == 43);
103 assert(t.tm_sec == 22);
104 assert(err == std::ios_base::goodbit);
105 }
106 {
107 const char in[] = "2.43:221";
108 err = std::ios_base::goodbit;
109 t = std::tm();
110 I i = f.get_time(I(in), I(in+sizeof(in)-1), ios, err, &t);
111 assert(i.base() == in+1);
112 // assert(t.tm_hour == 0);
113 // assert(t.tm_min == 0);
114 // assert(t.tm_sec == 0);
115 assert(err == std::ios_base::failbit);
116 }
117 }
118