From fc3688ea708e9020a72ca08ab5df79fc7408a89d Mon Sep 17 00:00:00 2001 From: Paul Beckingham Date: Mon, 16 Jun 2014 18:40:34 -0400 Subject: [PATCH] Variant - Updated operator> to handle trivial values. --- src/Variant.cpp | 73 +++++++++++++++++++++++++++++++++++-------------- 1 file changed, 53 insertions(+), 20 deletions(-) diff --git a/src/Variant.cpp b/src/Variant.cpp index 6d6d12ab6..28fa4c1b5 100644 --- a/src/Variant.cpp +++ b/src/Variant.cpp @@ -556,10 +556,15 @@ bool Variant::operator> (const Variant& other) const case type_string: switch (right._type) { - case type_unknown: throw std::string ("Cannot compare unknown type"); - case type_boolean: right.cast (type_string); return left._string > right._string; - case type_integer: right.cast (type_string); return left._string > right._string; - case type_real: right.cast (type_string); return left._string > right._string; + case type_unknown: + throw std::string ("Cannot compare unknown type"); + + case type_boolean: + case type_integer: + case type_real: + right.cast (type_string); + return left._string > right._string; + case type_string: if (left.source () == "priority" || right.source () == "priority") { @@ -570,36 +575,64 @@ bool Variant::operator> (const Variant& other) const } else { + if (left.trivial () || right.trivial ()) + return false; + return left._string> right._string; } - case type_date: left.cast (type_date); return left._date > right._date; - case type_duration: left.cast (type_duration); return left._duration > right._duration; + case type_date: + if (left.trivial () || right.trivial ()) + return false; + + left.cast (type_date); + return left._date > right._date; + + case type_duration: + if (left.trivial () || right.trivial ()) + return false; + + left.cast (type_duration); + return left._duration > right._duration; } break; case type_date: switch (right._type) { - case type_unknown: throw std::string ("Cannot compare unknown type"); - case type_boolean: right.cast (type_date); return left._date > right._date; - case type_integer: right.cast (type_date); return left._date > right._date; - case type_real: right.cast (type_date); return left._date > right._date; - case type_string: right.cast (type_date); return left._date > right._date; - case type_date: return left._date > right._date; - case type_duration: return left._date > right._duration; + case type_unknown: + throw std::string ("Cannot compare unknown type"); + + case type_boolean: + case type_integer: + case type_real: + case type_string: + case type_date: + case type_duration: + if (left.trivial () || right.trivial ()) + return false; + + right.cast (type_date); + return left._date > right._date; } break; case type_duration: switch (right._type) { - case type_unknown: throw std::string ("Cannot compare unknown type"); - case type_boolean: right.cast (type_duration); return left._duration > right._duration; - case type_integer: right.cast (type_duration); return left._duration > right._duration; - case type_real: right.cast (type_duration); return left._duration > right._duration; - case type_string: right.cast (type_duration); return left._duration > right._duration; - case type_date: return left._duration > right._date; - case type_duration: return left._duration > right._duration; + case type_unknown: + throw std::string ("Cannot compare unknown type"); + + case type_boolean: + case type_integer: + case type_real: + case type_string: + case type_date: + case type_duration: + if (left.trivial () || right.trivial ()) + return false; + + right.cast (type_duration); + return left._duration > right._duration; } break; }