// file : xsde/cxx/parser/validating/unsigned-short.cxx // copyright : Copyright (c) 2005-2011 Code Synthesis Tools CC // license : GNU GPL v2 + exceptions; see accompanying LICENSE file #include // strtoul #include namespace xsde { namespace cxx { namespace parser { namespace validating { void unsigned_short_pimpl:: _pre () { size_ = 0; sign_ = none; state_ = leading_ws; } void unsigned_short_pimpl:: _characters (const ro_string& s) { if (!parse (s, str_, 6)) _schema_error (schema_error::invalid_unsigned_short_value); } void unsigned_short_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'; // No need to check errno since our string representation // can never overflow an unsigned long. // char* p; unsigned long ul = strtoul (str_, &p, 10); if (*p != '\0' || ul > 65535) { _schema_error (schema_error::invalid_unsigned_short_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_short_value); } unsigned short unsigned_short_pimpl:: post_unsigned_short () { return value_; } } } } }