//===----------------------------------------------------------------------===// // // 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. // //===----------------------------------------------------------------------===// // // class num_get // iter_type get(iter_type in, iter_type end, ios_base&, // ios_base::iostate& err, unsigned long& v) const; #include #include #include #include #include "test_iterators.h" typedef std::num_get > F; class my_facet : public F { public: explicit my_facet(std::size_t refs = 0) : F(refs) {} }; class my_numpunct : public std::numpunct { public: my_numpunct() : std::numpunct() {} protected: virtual char_type do_thousands_sep() const {return '_';} virtual std::string do_grouping() const {return std::string("\1\2\3");} }; int main() { const my_facet f(1); std::ios ios(0); unsigned long v = static_cast(-1); { const char str[] = "0"; std::ios_base::iostate err = ios.goodbit; input_iterator iter = f.get(input_iterator(str), input_iterator(str+sizeof(str)), ios, err, v); assert(iter.base() == str+sizeof(str)-1); assert(err == ios.goodbit); assert(v == 0); } { const char str[] = "1"; std::ios_base::iostate err = ios.goodbit; input_iterator iter = f.get(input_iterator(str), input_iterator(str+sizeof(str)), ios, err, v); assert(iter.base() == str+sizeof(str)-1); assert(err == ios.goodbit); assert(v == 1); } hex(ios); { const char str[] = "0xFFFFFFFF"; std::ios_base::iostate err = ios.goodbit; input_iterator iter = f.get(input_iterator(str), input_iterator(str+sizeof(str)), ios, err, v); assert(iter.base() == str+sizeof(str)-1); assert(err == ios.goodbit); assert(v == 0xFFFFFFFF); } }