// file : xsde/cxx/parser/validating/byte.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 namespace xsde { namespace cxx { namespace parser { namespace validating { void byte_pimpl:: _pre () { size_ = 0; sign_ = none; state_ = leading_ws; } void byte_pimpl:: _characters (const ro_string& s) { if (!parse (s, str_, 4)) _schema_error (schema_error::invalid_byte_value); } void byte_pimpl:: _post () { ro_string tmp (str_, size_); size_t size = trim_right (tmp); if (size != 0 && 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); bool neg = (sign_ == minus); if (*p != '\0' || (neg && ul > 128) || (!neg && ul > 127)) _schema_error (schema_error::invalid_byte_value); value_ = neg ? static_cast (-static_cast (ul)) : 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_byte_value); } signed char byte_pimpl:: post_byte () { return value_; } } } } }