// file : xsde/cxx/parser/validating/unsigned-int.cxx // author : Boris Kolpackov // copyright : Copyright (c) 2005-2011 Code Synthesis Tools CC // license : GNU GPL v2 + exceptions; see accompanying LICENSE file #include // strtoul #include #include namespace xsde { namespace cxx { namespace parser { namespace validating { void unsigned_int_pimpl:: _pre () { size_ = 0; sign_ = none; state_ = leading_ws; } void unsigned_int_pimpl:: _characters (const ro_string& s) { if (!parse (s, str_, 11)) _schema_error (schema_error::invalid_unsigned_int_value); } void unsigned_int_pimpl:: _post () { ro_string tmp (str_, size_); size_t size = trim_right (tmp); if (size != 0 && sign_ != minus && tmp[0] != '-' && tmp[0] != '+') { str_[size] = '\0'; char* p; set_errno (0); unsigned long ul = strtoul (str_, &p, 10); if (*p != '\0' || get_errno () != 0 || ul > 4294967295UL) { _schema_error (schema_error::invalid_unsigned_int_value); return; } value_ = static_cast (ul); // Check facets. // const facets& f = _facets (); if (f.min_set_ && (value_ < f.min_ || (!f.min_inc_ && value_ == f.min_))) { _schema_error (schema_error::value_less_than_min); return; } if (f.max_set_ && (value_ > f.max_ || (!f.max_inc_ && value_ == f.max_))) { _schema_error (schema_error::value_greater_than_max); return; } } else _schema_error (schema_error::invalid_unsigned_int_value); } unsigned int unsigned_int_pimpl:: post_unsigned_int () { return value_; } } } } }