diff options
author | alejes <[email protected]> | 2022-02-10 16:49:21 +0300 |
---|---|---|
committer | Daniil Cherednik <[email protected]> | 2022-02-10 16:49:21 +0300 |
commit | 296addf192418e73b12dd8c5110ac1a36d9dee19 (patch) | |
tree | 5d5cb817648f650d76cf1076100726fd9b8448e8 /library/cpp/yson/node/node.cpp | |
parent | b60afd91b05e759239ecb08faaf494d5c7445d4e (diff) |
Restoring authorship annotation for <[email protected]>. Commit 2 of 2.
Diffstat (limited to 'library/cpp/yson/node/node.cpp')
-rw-r--r-- | library/cpp/yson/node/node.cpp | 138 |
1 files changed, 69 insertions, 69 deletions
diff --git a/library/cpp/yson/node/node.cpp b/library/cpp/yson/node/node.cpp index a6b73d89334..b39e0707187 100644 --- a/library/cpp/yson/node/node.cpp +++ b/library/cpp/yson/node/node.cpp @@ -22,75 +22,75 @@ bool TNode::TUndefined::operator==(const TUndefined&) const { //////////////////////////////////////////////////////////////////////////////// -namespace NNodeCmp { - -bool IsComparableType(const TNode::EType type) { - switch (type) { - case TNode::String: - case TNode::Int64: - case TNode::Uint64: - case TNode::Double: - case TNode::Bool: - case TNode::Null: - case TNode::Undefined: - return true; - default: - return false; - } -} - -bool operator<(const TNode& lhs, const TNode& rhs) -{ - if (!lhs.GetAttributes().Empty() || !rhs.GetAttributes().Empty()) { - ythrow TNode::TTypeError() << "Unsupported attributes comparison"; - } - - if (!IsComparableType(lhs.GetType()) || !IsComparableType(rhs.GetType())) { - ythrow TNode::TTypeError() << "Unsupported types for comparison: " << lhs.GetType() << " with " << rhs.GetType(); - } - - if (lhs.GetType() != rhs.GetType()) { - return lhs.GetType() < rhs.GetType(); - } - - switch (lhs.GetType()) { - case TNode::String: - return lhs.AsString() < rhs.AsString(); - case TNode::Int64: - return lhs.AsInt64() < rhs.AsInt64(); - case TNode::Uint64: - return lhs.AsUint64() < rhs.AsUint64(); - case TNode::Double: - return lhs.AsDouble() < rhs.AsDouble(); - case TNode::Bool: - return lhs.AsBool() < rhs.AsBool(); - case TNode::Null: - case TNode::Undefined: - return false; - default: - Y_FAIL("Unexpected type: %d", lhs.GetType()); - } -} - -bool operator>(const TNode& lhs, const TNode& rhs) -{ - return rhs < lhs; -} - -bool operator<=(const TNode& lhs, const TNode& rhs) -{ - return !(lhs > rhs); -} - -bool operator>=(const TNode& lhs, const TNode& rhs) -{ - return !(lhs < rhs); -} - -} // namespace NNodeCmp - -//////////////////////////////////////////////////////////////////////////////// - +namespace NNodeCmp { + +bool IsComparableType(const TNode::EType type) { + switch (type) { + case TNode::String: + case TNode::Int64: + case TNode::Uint64: + case TNode::Double: + case TNode::Bool: + case TNode::Null: + case TNode::Undefined: + return true; + default: + return false; + } +} + +bool operator<(const TNode& lhs, const TNode& rhs) +{ + if (!lhs.GetAttributes().Empty() || !rhs.GetAttributes().Empty()) { + ythrow TNode::TTypeError() << "Unsupported attributes comparison"; + } + + if (!IsComparableType(lhs.GetType()) || !IsComparableType(rhs.GetType())) { + ythrow TNode::TTypeError() << "Unsupported types for comparison: " << lhs.GetType() << " with " << rhs.GetType(); + } + + if (lhs.GetType() != rhs.GetType()) { + return lhs.GetType() < rhs.GetType(); + } + + switch (lhs.GetType()) { + case TNode::String: + return lhs.AsString() < rhs.AsString(); + case TNode::Int64: + return lhs.AsInt64() < rhs.AsInt64(); + case TNode::Uint64: + return lhs.AsUint64() < rhs.AsUint64(); + case TNode::Double: + return lhs.AsDouble() < rhs.AsDouble(); + case TNode::Bool: + return lhs.AsBool() < rhs.AsBool(); + case TNode::Null: + case TNode::Undefined: + return false; + default: + Y_FAIL("Unexpected type: %d", lhs.GetType()); + } +} + +bool operator>(const TNode& lhs, const TNode& rhs) +{ + return rhs < lhs; +} + +bool operator<=(const TNode& lhs, const TNode& rhs) +{ + return !(lhs > rhs); +} + +bool operator>=(const TNode& lhs, const TNode& rhs) +{ + return !(lhs < rhs); +} + +} // namespace NNodeCmp + +//////////////////////////////////////////////////////////////////////////////// + TNode::TNode() : Value_(TUndefined{}) { } |