From 51231f66aee0bbbd14d361d9e8e0009e99d57974 Mon Sep 17 00:00:00 2001 From: Boris Kolpackov Date: Tue, 12 Oct 2010 11:26:08 +0200 Subject: Finish {min,max}{Exclusive,Inclusive} facets support New test: hybrid/facets. --- .../cxx/serializer/validating/negative-integer.cxx | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) (limited to 'libxsde/xsde/cxx/serializer/validating/negative-integer.cxx') diff --git a/libxsde/xsde/cxx/serializer/validating/negative-integer.cxx b/libxsde/xsde/cxx/serializer/validating/negative-integer.cxx index adc9ead..bdbc948 100644 --- a/libxsde/xsde/cxx/serializer/validating/negative-integer.cxx +++ b/libxsde/xsde/cxx/serializer/validating/negative-integer.cxx @@ -30,6 +30,24 @@ namespace xsde return; } + // 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; + } + // We only need strlen("-9223372036854775808") + 1 characters to // hold all representations of (possibly 64-bit) long. // -- cgit v1.1