// // Var.h // // Library: Foundation // Package: Dynamic // Module: Var // // Definition of the Var class. // // Copyright (c) 2007, Applied Informatics Software Engineering GmbH. // and Contributors. // // SPDX-License-Identifier: BSL-1.0 // #ifndef Foundation_Var_INCLUDED #define Foundation_Var_INCLUDED #include #include "Poco/Dynamic/VarHolder.h" #include "Poco/Dynamic/VarIterator.h" #include "Poco/Format.h" #include "Poco/Foundation.h" #include "Poco/SharedPtr.h" namespace Poco { namespace Dynamic { template class Struct; class Foundation_API Var /// Var allows to store data of different types and to convert between these types transparently. /// Var puts forth the best effort to provide intuitive and reasonable conversion semantics and prevent /// unexpected data loss, particularly when performing narrowing or signedness conversions of numeric data types. /// /// An attempt to convert or extract from a non-initialized ("empty") Var variable shall result /// in an exception being thrown. /// /// Loss of signedness is not allowed for numeric values. This means that if an attempt is made to convert /// the internal value which is a negative signed integer to an unsigned integer type storage, a RangeException is thrown. /// Overflow is not allowed, so if the internal value is a larger number than the target numeric type size can accommodate, /// a RangeException is thrown. /// /// Precision loss, such as in conversion from floating-point types to integers or from double to float on platforms /// where they differ in size (provided internal actual value fits in float min/max range), is allowed. /// /// String truncation is allowed -- it is possible to convert between string and character when string length is /// greater than 1. An empty string gets converted to the char '\0', a non-empty string is truncated to the first character. /// /// Boolean conversion is performed as follows: /// /// A string value "false" (not case sensitive), "0" or "" (empty string) can be converted to a boolean value false, /// any other string not being false by the above criteria evaluates to true (e.g: "hi" -> true). /// Integer 0 values are false, everything else is true. /// Floating point values equal to the minimal FP representation on a given platform are false, everything else is true. /// /// Arithmetic operations with POD types as well as between Var's are supported, subject to following /// limitations: /// /// - for std::string and const char* values, only '+' and '+=' operations are supported /// /// - for integral and floating point numeric values, following operations are supported: /// '+', '+=', '-', '-=', '*', '*=' , '/' and '/=' /// /// - for integral values, following operations are supported: /// prefix and postfix increment (++) and decrement (--) /// /// - for all other types, InvalidArgumentException is thrown upon attempt of an arithmetic operation /// /// A Var can be created from and converted to a value of any type for which a specialization of /// VarHolderImpl is available. For supported types, see VarHolder documentation. { public: typedef SharedPtr Ptr; typedef Poco::Dynamic::VarIterator Iterator; typedef const VarIterator ConstIterator; Var(); /// Creates an empty Var. template Var(const T & val) /// Creates the Var from the given value. #ifdef POCO_NO_SOO : _pHolder(new VarHolderImpl(val)){} #else { construct(val); } #endif Var(const char * pVal); // Convenience constructor for const char* which gets mapped to a std::string internally, i.e. pVal is deep-copied. Var(const Var & other); /// Copy constructor. ~Var(); /// Destroys the Var. void swap(Var & other); /// Swaps the content of the this Var with the other Var. ConstIterator begin() const; /// Returns the const Var iterator. ConstIterator end() const; /// Returns the const Var iterator. Iterator begin(); /// Returns the Var iterator. Iterator end(); /// Returns the Var iterator. template void convert(T & val) const /// Invoke this method to perform a safe conversion. /// /// Example usage: /// Var any("42"); /// int i; /// any.convert(i); /// /// Throws a RangeException if the value does not fit /// into the result variable. /// Throws a NotImplementedException if conversion is /// not available for the given type. /// Throws InvalidAccessException if Var is empty. { VarHolder * pHolder = content(); if (!pHolder) throw InvalidAccessException("Can not convert empty value."); pHolder->convert(val); } template T convert() const /// Invoke this method to perform a safe conversion. /// /// Example usage: /// Var any("42"); /// int i = any.convert(); /// /// Throws a RangeException if the value does not fit /// into the result variable. /// Throws a NotImplementedException if conversion is /// not available for the given type. /// Throws InvalidAccessException if Var is empty. { VarHolder * pHolder = content(); if (!pHolder) throw InvalidAccessException("Can not convert empty value."); if (typeid(T) == pHolder->type()) return extract(); T result; pHolder->convert(result); return result; } template operator T() const /// Safe conversion operator for implicit type /// conversions. If the requested type T is same as the /// type being held, the operation performed is direct /// extraction, otherwise it is the conversion of the value /// from type currently held to the one requested. /// /// Throws a RangeException if the value does not fit /// into the result variable. /// Throws a NotImplementedException if conversion is /// not available for the given type. /// Throws InvalidAccessException if Var is empty. { VarHolder * pHolder = content(); if (!pHolder) throw InvalidAccessException("Can not convert empty value."); if (typeid(T) == pHolder->type()) return extract(); else { T result; pHolder->convert(result); return result; } } template const T & extract() const /// Returns a const reference to the actual value. /// /// Must be instantiated with the exact type of /// the stored value, otherwise a BadCastException /// is thrown. /// Throws InvalidAccessException if Var is empty. { VarHolder * pHolder = content(); if (pHolder && pHolder->type() == typeid(T)) { VarHolderImpl * pHolderImpl = static_cast *>(pHolder); return pHolderImpl->value(); } else if (!pHolder) throw InvalidAccessException("Can not extract empty value."); else throw BadCastException( format("Can not convert %s to %s.", std::string(pHolder->type().name()), std::string(typeid(T).name()))); } template Var & operator=(const T & other) /// Assignment operator for assigning POD to Var { #ifdef POCO_NO_SOO Var tmp(other); swap(tmp); #else construct(other); #endif return *this; } bool operator!() const; /// Logical NOT operator. Var & operator=(const Var & other); /// Assignment operator specialization for Var template const Var operator+(const T & other) const /// Addition operator for adding POD to Var { return convert() + other; } const Var operator+(const Var & other) const; /// Addition operator specialization for Var const Var operator+(const char * other) const; /// Addition operator specialization for adding const char* to Var Var & operator++(); /// Pre-increment operator const Var operator++(int); /// Post-increment operator Var & operator--(); /// Pre-decrement operator const Var operator--(int); /// Post-decrement operator template Var & operator+=(const T & other) /// Addition assignment operator for addition/assignment of POD to Var. { return *this = convert() + other; } Var & operator+=(const Var & other); /// Addition assignment operator overload for Var Var & operator+=(const char * other); /// Addition assignment operator overload for const char* template const Var operator-(const T & other) const /// Subtraction operator for subtracting POD from Var { return convert() - other; } const Var operator-(const Var & other) const; /// Subtraction operator overload for Var template Var & operator-=(const T & other) /// Subtraction assignment operator { return *this = convert() - other; } Var & operator-=(const Var & other); /// Subtraction assignment operator overload for Var template const Var operator*(const T & other) const /// Multiplication operator for multiplying Var with POD { return convert() * other; } const Var operator*(const Var & other) const; /// Multiplication operator overload for Var template Var & operator*=(const T & other) /// Multiplication assignment operator { return *this = convert() * other; } Var & operator*=(const Var & other); /// Multiplication assignment operator overload for Var template const Var operator/(const T & other) const /// Division operator for dividing Var with POD { return convert() / other; } const Var operator/(const Var & other) const; /// Division operator overload for Var template Var & operator/=(const T & other) /// Division assignment operator { return *this = convert() / other; } Var & operator/=(const Var & other); /// Division assignment operator specialization for Var template bool operator==(const T & other) const /// Equality operator { if (isEmpty()) return false; return convert() == other; } bool operator==(const char * other) const; /// Equality operator overload for const char* bool operator==(const Var & other) const; /// Equality operator overload for Var template bool operator!=(const T & other) const /// Inequality operator { if (isEmpty()) return true; return convert() != other; } bool operator!=(const Var & other) const; /// Inequality operator overload for Var bool operator!=(const char * other) const; /// Inequality operator overload for const char* template bool operator<(const T & other) const /// Less than operator { if (isEmpty()) return false; return convert() < other; } bool operator<(const Var & other) const; /// Less than operator overload for Var template bool operator<=(const T & other) const /// Less than or equal operator { if (isEmpty()) return false; return convert() <= other; } bool operator<=(const Var & other) const; /// Less than or equal operator overload for Var template bool operator>(const T & other) const /// Greater than operator { if (isEmpty()) return false; return convert() > other; } bool operator>(const Var & other) const; /// Greater than operator overload for Var template bool operator>=(const T & other) const /// Greater than or equal operator { if (isEmpty()) return false; return convert() >= other; } bool operator>=(const Var & other) const; /// Greater than or equal operator overload for Var template bool operator||(const T & other) const /// Logical OR operator { if (isEmpty()) return false; return convert() || other; } bool operator||(const Var & other) const; /// Logical OR operator operator overload for Var template bool operator&&(const T & other) const /// Logical AND operator. { if (isEmpty()) return false; return convert() && other; } bool operator&&(const Var & other) const; /// Logical AND operator operator overload for Var. bool isArray() const; /// Returns true if Var is an array. bool isVector() const; /// Returns true if Var represents a vector. bool isList() const; /// Returns true if Var represents a list. bool isDeque() const; /// Returns true if Var represents a deque. bool isStruct() const; /// Returns true if Var represents a struct. char & at(std::size_t n); /// Returns character at position n. This function only works with /// Var containing a std::string. template Var & operator[](const T & n) { return getAt(n); } template const Var & operator[](const T & n) const { return const_cast(this)->getAt(n); } Var & operator[](const std::string & name); /// Index operator by name, only use on Vars where isStruct /// returns true! In all other cases InvalidAccessException is thrown. const Var & operator[](const std::string & name) const; /// Index operator by name, only use on Vars where isStruct /// returns true! In all other cases InvalidAccessException is thrown. const std::type_info & type() const; /// Returns the type information of the stored content. //@ deprecated void empty(); /// Empties Var. /// This function is deprecated and will be removed. /// Please use clear(). void clear(); /// Empties Var. bool isEmpty() const; /// Returns true if empty. bool isInteger() const; /// Returns true if stored value is integer. bool isSigned() const; /// Returns true if stored value is signed. bool isNumeric() const; /// Returns true if stored value is numeric. /// Returns false for numeric strings (e.g. "123" is string, not number) bool isBoolean() const; /// Returns true if stored value is boolean. /// Returns false for boolean strings (e.g. "true" is string, not number) bool isString() const; /// Returns true if stored value is std::string. bool isDate() const; /// Returns true if stored value represents a date. bool isTime() const; /// Returns true if stored value represents time or date/time. bool isDateTime() const; /// Returns true if stored value represents a date/time. std::size_t size() const; /// Returns the size of this Var. /// This function returns 0 when Var is empty, 1 for POD or the size (i.e. length) /// for held container. std::string toString() const /// Returns the stored value as string. { VarHolder * pHolder = content(); if (!pHolder) throw InvalidAccessException("Can not convert empty value."); if (typeid(std::string) == pHolder->type()) return extract(); else { std::string result; pHolder->convert(result); return result; } } static Var parse(const std::string & val); /// Parses the string which must be in JSON format static std::string toString(const Var & var); /// Converts the Var to a string in JSON format. Note that toString(const Var&) will return /// a different result than Var::convert() and Var::toString()! private: Var & getAt(std::size_t n); Var & getAt(const std::string & n); static Var parse(const std::string & val, std::string::size_type & offset); /// Parses the string which must be in JSON format static Var parseObject(const std::string & val, std::string::size_type & pos); static Var parseArray(const std::string & val, std::string::size_type & pos); static std::string parseString(const std::string & val, std::string::size_type & pos); static std::string parseJSONString(const std::string & val, std::string::size_type & pos); static void skipWhiteSpace(const std::string & val, std::string::size_type & pos); template T add(const Var & other) const { return convert() + other.convert(); } template T subtract(const Var & other) const { return convert() - other.convert(); } template T multiply(const Var & other) const { return convert() * other.convert(); } template T divide(const Var & other) const { return convert() / other.convert(); } template VarHolderImpl * holderImpl(const std::string errorMessage = "") const { VarHolder * pHolder = content(); if (pHolder && pHolder->type() == typeid(T)) return static_cast *>(pHolder); else if (!pHolder) throw InvalidAccessException("Can not access empty value."); else throw E(errorMessage); } Var & structIndexOperator(VarHolderImpl> * pStr, int n) const; #ifdef POCO_NO_SOO VarHolder * content() const { return _pHolder; } void destruct() { if (!isEmpty()) delete content(); } VarHolder * _pHolder; #else VarHolder * content() const { return _placeholder.content(); } template void construct(const ValueType & value) { if (sizeof(VarHolderImpl) <= Placeholder::Size::value) { new (reinterpret_cast(_placeholder.holder)) VarHolderImpl(value); _placeholder.setLocal(true); } else { _placeholder.pHolder = new VarHolderImpl(value); _placeholder.setLocal(false); } } void construct(const char * value) { std::string val(value); if (sizeof(VarHolderImpl) <= Placeholder::Size::value) { new (reinterpret_cast(_placeholder.holder)) VarHolderImpl(val); _placeholder.setLocal(true); } else { _placeholder.pHolder = new VarHolderImpl(val); _placeholder.setLocal(false); } } void construct(const Var & other) { if (!other.isEmpty()) other.content()->clone(&_placeholder); else _placeholder.erase(); } void destruct() { if (!isEmpty()) { if (_placeholder.isLocal()) content()->~VarHolder(); else delete content(); } } Placeholder _placeholder; #endif // POCO_NO_SOO }; /// /// inlines /// /// /// Var members /// inline void Var::swap(Var & other) { #ifdef POCO_NO_SOO std::swap(_pHolder, other._pHolder); #else if (this == &other) return; if (!_placeholder.isLocal() && !other._placeholder.isLocal()) { std::swap(_placeholder.pHolder, other._placeholder.pHolder); } else { Var tmp(*this); try { if (_placeholder.isLocal()) destruct(); construct(other); other = tmp; } catch (...) { construct(tmp); throw; } } #endif } inline const std::type_info & Var::type() const { VarHolder * pHolder = content(); return pHolder ? pHolder->type() : typeid(void); } inline Var::ConstIterator Var::begin() const { if (isEmpty()) return ConstIterator(const_cast(this), true); return ConstIterator(const_cast(this), false); } inline Var::ConstIterator Var::end() const { return ConstIterator(const_cast(this), true); } inline Var::Iterator Var::begin() { if (isEmpty()) return Iterator(const_cast(this), true); return Iterator(const_cast(this), false); } inline Var::Iterator Var::end() { return Iterator(this, true); } inline Var & Var::operator[](const std::string & name) { return getAt(name); } inline const Var & Var::operator[](const std::string & name) const { return const_cast(this)->getAt(name); } inline const Var Var::operator+(const char * other) const { return convert() + other; } inline Var & Var::operator+=(const char * other) { return *this = convert() + other; } inline bool Var::operator!() const { return !convert(); } inline bool Var::isEmpty() const { return 0 == content(); } inline bool Var::isArray() const { if (isEmpty() || isString()) return false; VarHolder * pHolder = content(); return pHolder ? pHolder->isArray() : false; } inline bool Var::isVector() const { VarHolder * pHolder = content(); return pHolder ? pHolder->isVector() : false; } inline bool Var::isList() const { VarHolder * pHolder = content(); return pHolder ? pHolder->isList() : false; } inline bool Var::isDeque() const { VarHolder * pHolder = content(); return pHolder ? pHolder->isDeque() : false; } inline bool Var::isStruct() const { VarHolder * pHolder = content(); return pHolder ? pHolder->isStruct() : false; } inline bool Var::isInteger() const { VarHolder * pHolder = content(); return pHolder ? pHolder->isInteger() : false; } inline bool Var::isSigned() const { VarHolder * pHolder = content(); return pHolder ? pHolder->isSigned() : false; } inline bool Var::isNumeric() const { VarHolder * pHolder = content(); return pHolder ? pHolder->isNumeric() : false; } inline bool Var::isBoolean() const { VarHolder * pHolder = content(); return pHolder ? pHolder->isBoolean() : false; } inline bool Var::isString() const { VarHolder * pHolder = content(); return pHolder ? pHolder->isString() : false; } inline bool Var::isDate() const { VarHolder * pHolder = content(); return pHolder ? pHolder->isDate() : false; } inline bool Var::isTime() const { VarHolder * pHolder = content(); return pHolder ? pHolder->isTime() : false; } inline bool Var::isDateTime() const { VarHolder * pHolder = content(); return pHolder ? pHolder->isDateTime() : false; } inline std::size_t Var::size() const { VarHolder * pHolder = content(); return pHolder ? pHolder->size() : 0; } /// /// Var non-member functions /// inline const Var operator+(const char * other, const Var & da) /// Addition operator for adding Var to const char* { std::string tmp = other; return tmp + da.convert(); } inline char operator+(const char & other, const Var & da) /// Addition operator for adding Var to char { return other + da.convert(); } inline char operator-(const char & other, const Var & da) /// Subtraction operator for subtracting Var from char { return other - da.convert(); } inline char operator*(const char & other, const Var & da) /// Multiplication operator for multiplying Var with char { return other * da.convert(); } inline char operator/(const char & other, const Var & da) /// Division operator for dividing Var with char { return other / da.convert(); } inline char operator+=(char & other, const Var & da) /// Addition assignment operator for adding Var to char { return other += da.convert(); } inline char operator-=(char & other, const Var & da) /// Subtraction assignment operator for subtracting Var from char { return other -= da.convert(); } inline char operator*=(char & other, const Var & da) /// Multiplication assignment operator for multiplying Var with char { return other *= da.convert(); } inline char operator/=(char & other, const Var & da) /// Division assignment operator for dividing Var with char { return other /= da.convert(); } inline bool operator==(const char & other, const Var & da) /// Equality operator for comparing Var with char { if (da.isEmpty()) return false; return other == da.convert(); } inline bool operator!=(const char & other, const Var & da) /// Inequality operator for comparing Var with char { if (da.isEmpty()) return true; return other != da.convert(); } inline bool operator<(const char & other, const Var & da) /// Less than operator for comparing Var with char { if (da.isEmpty()) return false; return other < da.convert(); } inline bool operator<=(const char & other, const Var & da) /// Less than or equal operator for comparing Var with char { if (da.isEmpty()) return false; return other <= da.convert(); } inline bool operator>(const char & other, const Var & da) /// Greater than operator for comparing Var with char { if (da.isEmpty()) return false; return other > da.convert(); } inline bool operator>=(const char & other, const Var & da) /// Greater than or equal operator for comparing Var with char { if (da.isEmpty()) return false; return other >= da.convert(); } inline Poco::Int8 operator+(const Poco::Int8 & other, const Var & da) /// Addition operator for adding Var to Poco::Int8 { return other + da.convert(); } inline Poco::Int8 operator-(const Poco::Int8 & other, const Var & da) /// Subtraction operator for subtracting Var from Poco::Int8 { return other - da.convert(); } inline Poco::Int8 operator*(const Poco::Int8 & other, const Var & da) /// Multiplication operator for multiplying Var with Poco::Int8 { return other * da.convert(); } inline Poco::Int8 operator/(const Poco::Int8 & other, const Var & da) /// Division operator for dividing Var with Poco::Int8 { return other / da.convert(); } inline Poco::Int8 operator+=(Poco::Int8 & other, const Var & da) /// Addition assignment operator for adding Var to Poco::Int8 { return other += da.convert(); } inline Poco::Int8 operator-=(Poco::Int8 & other, const Var & da) /// Subtraction assignment operator for subtracting Var from Poco::Int8 { return other -= da.convert(); } inline Poco::Int8 operator*=(Poco::Int8 & other, const Var & da) /// Multiplication assignment operator for multiplying Var with Poco::Int8 { return other *= da.convert(); } inline Poco::Int8 operator/=(Poco::Int8 & other, const Var & da) /// Division assignment operator for dividing Var with Poco::Int8 { return other /= da.convert(); } inline bool operator==(const Poco::Int8 & other, const Var & da) /// Equality operator for comparing Var with Poco::Int8 { if (da.isEmpty()) return false; return other == da.convert(); } inline bool operator!=(const Poco::Int8 & other, const Var & da) /// Inequality operator for comparing Var with Poco::Int8 { if (da.isEmpty()) return true; return other != da.convert(); } inline bool operator<(const Poco::Int8 & other, const Var & da) /// Less than operator for comparing Var with Poco::Int8 { if (da.isEmpty()) return false; return other < da.convert(); } inline bool operator<=(const Poco::Int8 & other, const Var & da) /// Less than or equal operator for comparing Var with Poco::Int8 { if (da.isEmpty()) return false; return other <= da.convert(); } inline bool operator>(const Poco::Int8 & other, const Var & da) /// Greater than operator for comparing Var with Poco::Int8 { if (da.isEmpty()) return false; return other > da.convert(); } inline bool operator>=(const Poco::Int8 & other, const Var & da) /// Greater than or equal operator for comparing Var with Poco::Int8 { if (da.isEmpty()) return false; return other >= da.convert(); } inline Poco::UInt8 operator+(const Poco::UInt8 & other, const Var & da) /// Addition operator for adding Var to Poco::UInt8 { return other + da.convert(); } inline Poco::UInt8 operator-(const Poco::UInt8 & other, const Var & da) /// Subtraction operator for subtracting Var from Poco::UInt8 { return other - da.convert(); } inline Poco::UInt8 operator*(const Poco::UInt8 & other, const Var & da) /// Multiplication operator for multiplying Var with Poco::UInt8 { return other * da.convert(); } inline Poco::UInt8 operator/(const Poco::UInt8 & other, const Var & da) /// Division operator for dividing Var with Poco::UInt8 { return other / da.convert(); } inline Poco::UInt8 operator+=(Poco::UInt8 & other, const Var & da) /// Addition assignment operator for adding Var to Poco::UInt8 { return other += da.convert(); } inline Poco::UInt8 operator-=(Poco::UInt8 & other, const Var & da) /// Subtraction assignment operator for subtracting Var from Poco::UInt8 { return other -= da.convert(); } inline Poco::UInt8 operator*=(Poco::UInt8 & other, const Var & da) /// Multiplication assignment operator for multiplying Var with Poco::UInt8 { return other *= da.convert(); } inline Poco::UInt8 operator/=(Poco::UInt8 & other, const Var & da) /// Division assignment operator for dividing Var with Poco::UInt8 { return other /= da.convert(); } inline bool operator==(const Poco::UInt8 & other, const Var & da) /// Equality operator for comparing Var with Poco::UInt8 { if (da.isEmpty()) return false; return other == da.convert(); } inline bool operator!=(const Poco::UInt8 & other, const Var & da) /// Inequality operator for comparing Var with Poco::UInt8 { if (da.isEmpty()) return true; return other != da.convert(); } inline bool operator<(const Poco::UInt8 & other, const Var & da) /// Less than operator for comparing Var with Poco::UInt8 { if (da.isEmpty()) return false; return other < da.convert(); } inline bool operator<=(const Poco::UInt8 & other, const Var & da) /// Less than or equal operator for comparing Var with Poco::UInt8 { if (da.isEmpty()) return false; return other <= da.convert(); } inline bool operator>(const Poco::UInt8 & other, const Var & da) /// Greater than operator for comparing Var with Poco::UInt8 { if (da.isEmpty()) return false; return other > da.convert(); } inline bool operator>=(const Poco::UInt8 & other, const Var & da) /// Greater than or equal operator for comparing Var with Poco::UInt8 { if (da.isEmpty()) return false; return other >= da.convert(); } inline Poco::Int16 operator+(const Poco::Int16 & other, const Var & da) /// Addition operator for adding Var to Poco::Int16 { return other + da.convert(); } inline Poco::Int16 operator-(const Poco::Int16 & other, const Var & da) /// Subtraction operator for subtracting Var from Poco::Int16 { return other - da.convert(); } inline Poco::Int16 operator*(const Poco::Int16 & other, const Var & da) /// Multiplication operator for multiplying Var with Poco::Int16 { return other * da.convert(); } inline Poco::Int16 operator/(const Poco::Int16 & other, const Var & da) /// Division operator for dividing Var with Poco::Int16 { return other / da.convert(); } inline Poco::Int16 operator+=(Poco::Int16 & other, const Var & da) /// Addition assignment operator for adding Var to Poco::Int16 { return other += da.convert(); } inline Poco::Int16 operator-=(Poco::Int16 & other, const Var & da) /// Subtraction assignment operator for subtracting Var from Poco::Int16 { return other -= da.convert(); } inline Poco::Int16 operator*=(Poco::Int16 & other, const Var & da) /// Multiplication assignment operator for multiplying Var with Poco::Int16 { return other *= da.convert(); } inline Poco::Int16 operator/=(Poco::Int16 & other, const Var & da) /// Division assignment operator for dividing Var with Poco::Int16 { return other /= da.convert(); } inline bool operator==(const Poco::Int16 & other, const Var & da) /// Equality operator for comparing Var with Poco::Int16 { if (da.isEmpty()) return false; return other == da.convert(); } inline bool operator!=(const Poco::Int16 & other, const Var & da) /// Inequality operator for comparing Var with Poco::Int16 { if (da.isEmpty()) return true; return other != da.convert(); } inline bool operator<(const Poco::Int16 & other, const Var & da) /// Less than operator for comparing Var with Poco::Int16 { if (da.isEmpty()) return false; return other < da.convert(); } inline bool operator<=(const Poco::Int16 & other, const Var & da) /// Less than or equal operator for comparing Var with Poco::Int16 { if (da.isEmpty()) return false; return other <= da.convert(); } inline bool operator>(const Poco::Int16 & other, const Var & da) /// Greater than operator for comparing Var with Poco::Int16 { if (da.isEmpty()) return false; return other > da.convert(); } inline bool operator>=(const Poco::Int16 & other, const Var & da) /// Greater than or equal operator for comparing Var with Poco::Int16 { if (da.isEmpty()) return false; return other >= da.convert(); } inline Poco::UInt16 operator+(const Poco::UInt16 & other, const Var & da) /// Addition operator for adding Var to Poco::UInt16 { return other + da.convert(); } inline Poco::UInt16 operator-(const Poco::UInt16 & other, const Var & da) /// Subtraction operator for subtracting Var from Poco::UInt16 { return other - da.convert(); } inline Poco::UInt16 operator*(const Poco::UInt16 & other, const Var & da) /// Multiplication operator for multiplying Var with Poco::UInt16 { return other * da.convert(); } inline Poco::UInt16 operator/(const Poco::UInt16 & other, const Var & da) /// Division operator for dividing Var with Poco::UInt16 { return other / da.convert(); } inline Poco::UInt16 operator+=(Poco::UInt16 & other, const Var & da) /// Addition assignment operator for adding Var to Poco::UInt16 { return other += da.convert(); } inline Poco::UInt16 operator-=(Poco::UInt16 & other, const Var & da) /// Subtraction assignment operator for subtracting Var from Poco::UInt16 { return other -= da.convert(); } inline Poco::UInt16 operator*=(Poco::UInt16 & other, const Var & da) /// Multiplication assignment operator for multiplying Var with Poco::UInt16 { return other *= da.convert(); } inline Poco::UInt16 operator/=(Poco::UInt16 & other, const Var & da) /// Division assignment operator for dividing Var with Poco::UInt16 { return other /= da.convert(); } inline bool operator==(const Poco::UInt16 & other, const Var & da) /// Equality operator for comparing Var with Poco::UInt16 { if (da.isEmpty()) return false; return other == da.convert(); } inline bool operator!=(const Poco::UInt16 & other, const Var & da) /// Inequality operator for comparing Var with Poco::UInt16 { if (da.isEmpty()) return true; return other != da.convert(); } inline bool operator<(const Poco::UInt16 & other, const Var & da) /// Less than operator for comparing Var with Poco::UInt16 { if (da.isEmpty()) return false; return other < da.convert(); } inline bool operator<=(const Poco::UInt16 & other, const Var & da) /// Less than or equal operator for comparing Var with Poco::UInt16 { if (da.isEmpty()) return false; return other <= da.convert(); } inline bool operator>(const Poco::UInt16 & other, const Var & da) /// Greater than operator for comparing Var with Poco::UInt16 { if (da.isEmpty()) return false; return other > da.convert(); } inline bool operator>=(const Poco::UInt16 & other, const Var & da) /// Greater than or equal operator for comparing Var with Poco::UInt16 { if (da.isEmpty()) return false; return other >= da.convert(); } inline Poco::Int32 operator+(const Poco::Int32 & other, const Var & da) /// Addition operator for adding Var to Poco::Int32 { return other + da.convert(); } inline Poco::Int32 operator-(const Poco::Int32 & other, const Var & da) /// Subtraction operator for subtracting Var from Poco::Int32 { return other - da.convert(); } inline Poco::Int32 operator*(const Poco::Int32 & other, const Var & da) /// Multiplication operator for multiplying Var with Poco::Int32 { return other * da.convert(); } inline Poco::Int32 operator/(const Poco::Int32 & other, const Var & da) /// Division operator for dividing Var with Poco::Int32 { return other / da.convert(); } inline Poco::Int32 operator+=(Poco::Int32 & other, const Var & da) /// Addition assignment operator for adding Var to Poco::Int32 { return other += da.convert(); } inline Poco::Int32 operator-=(Poco::Int32 & other, const Var & da) /// Subtraction assignment operator for subtracting Var from Poco::Int32 { return other -= da.convert(); } inline Poco::Int32 operator*=(Poco::Int32 & other, const Var & da) /// Multiplication assignment operator for multiplying Var with Poco::Int32 { return other *= da.convert(); } inline Poco::Int32 operator/=(Poco::Int32 & other, const Var & da) /// Division assignment operator for dividing Var with Poco::Int32 { return other /= da.convert(); } inline bool operator==(const Poco::Int32 & other, const Var & da) /// Equality operator for comparing Var with Poco::Int32 { if (da.isEmpty()) return false; return other == da.convert(); } inline bool operator!=(const Poco::Int32 & other, const Var & da) /// Inequality operator for comparing Var with Poco::Int32 { if (da.isEmpty()) return true; return other != da.convert(); } inline bool operator<(const Poco::Int32 & other, const Var & da) /// Less than operator for comparing Var with Poco::Int32 { if (da.isEmpty()) return false; return other < da.convert(); } inline bool operator<=(const Poco::Int32 & other, const Var & da) /// Less than or equal operator for comparing Var with Poco::Int32 { if (da.isEmpty()) return false; return other <= da.convert(); } inline bool operator>(const Poco::Int32 & other, const Var & da) /// Greater than operator for comparing Var with Poco::Int32 { if (da.isEmpty()) return false; return other > da.convert(); } inline bool operator>=(const Poco::Int32 & other, const Var & da) /// Greater than or equal operator for comparing Var with Poco::Int32 { if (da.isEmpty()) return false; return other >= da.convert(); } inline Poco::UInt32 operator+(const Poco::UInt32 & other, const Var & da) /// Addition operator for adding Var to Poco::UInt32 { return other + da.convert(); } inline Poco::UInt32 operator-(const Poco::UInt32 & other, const Var & da) /// Subtraction operator for subtracting Var from Poco::UInt32 { return other - da.convert(); } inline Poco::UInt32 operator*(const Poco::UInt32 & other, const Var & da) /// Multiplication operator for multiplying Var with Poco::UInt32 { return other * da.convert(); } inline Poco::UInt32 operator/(const Poco::UInt32 & other, const Var & da) /// Division operator for dividing Var with Poco::UInt32 { return other / da.convert(); } inline Poco::UInt32 operator+=(Poco::UInt32 & other, const Var & da) /// Addition assignment operator for adding Var to Poco::UInt32 { return other += da.convert(); } inline Poco::UInt32 operator-=(Poco::UInt32 & other, const Var & da) /// Subtraction assignment operator for subtracting Var from Poco::UInt32 { return other -= da.convert(); } inline Poco::UInt32 operator*=(Poco::UInt32 & other, const Var & da) /// Multiplication assignment operator for multiplying Var with Poco::UInt32 { return other *= da.convert(); } inline Poco::UInt32 operator/=(Poco::UInt32 & other, const Var & da) /// Division assignment operator for dividing Var with Poco::UInt32 { return other /= da.convert(); } inline bool operator==(const Poco::UInt32 & other, const Var & da) /// Equality operator for comparing Var with Poco::UInt32 { if (da.isEmpty()) return false; return other == da.convert(); } inline bool operator!=(const Poco::UInt32 & other, const Var & da) /// Inequality operator for comparing Var with Poco::UInt32 { if (da.isEmpty()) return true; return other != da.convert(); } inline bool operator<(const Poco::UInt32 & other, const Var & da) /// Less than operator for comparing Var with Poco::UInt32 { if (da.isEmpty()) return false; return other < da.convert(); } inline bool operator<=(const Poco::UInt32 & other, const Var & da) /// Less than or equal operator for comparing Var with Poco::UInt32 { if (da.isEmpty()) return false; return other <= da.convert(); } inline bool operator>(const Poco::UInt32 & other, const Var & da) /// Greater than operator for comparing Var with Poco::UInt32 { if (da.isEmpty()) return false; return other > da.convert(); } inline bool operator>=(const Poco::UInt32 & other, const Var & da) /// Greater than or equal operator for comparing Var with Poco::UInt32 { if (da.isEmpty()) return false; return other >= da.convert(); } inline Poco::Int64 operator+(const Poco::Int64 & other, const Var & da) /// Addition operator for adding Var to Poco::Int64 { return other + da.convert(); } inline Poco::Int64 operator-(const Poco::Int64 & other, const Var & da) /// Subtraction operator for subtracting Var from Poco::Int64 { return other - da.convert(); } inline Poco::Int64 operator*(const Poco::Int64 & other, const Var & da) /// Multiplication operator for multiplying Var with Poco::Int64 { return other * da.convert(); } inline Poco::Int64 operator/(const Poco::Int64 & other, const Var & da) /// Division operator for dividing Var with Poco::Int64 { return other / da.convert(); } inline Poco::Int64 operator+=(Poco::Int64 & other, const Var & da) /// Addition assignment operator for adding Var to Poco::Int64 { return other += da.convert(); } inline Poco::Int64 operator-=(Poco::Int64 & other, const Var & da) /// Subtraction assignment operator for subtracting Var from Poco::Int64 { return other -= da.convert(); } inline Poco::Int64 operator*=(Poco::Int64 & other, const Var & da) /// Multiplication assignment operator for multiplying Var with Poco::Int64 { return other *= da.convert(); } inline Poco::Int64 operator/=(Poco::Int64 & other, const Var & da) /// Division assignment operator for dividing Var with Poco::Int64 { return other /= da.convert(); } inline bool operator==(const Poco::Int64 & other, const Var & da) /// Equality operator for comparing Var with Poco::Int64 { if (da.isEmpty()) return false; return other == da.convert(); } inline bool operator!=(const Poco::Int64 & other, const Var & da) /// Inequality operator for comparing Var with Poco::Int64 { if (da.isEmpty()) return true; return other != da.convert(); } inline bool operator<(const Poco::Int64 & other, const Var & da) /// Less than operator for comparing Var with Poco::Int64 { if (da.isEmpty()) return false; return other < da.convert(); } inline bool operator<=(const Poco::Int64 & other, const Var & da) /// Less than or equal operator for comparing Var with Poco::Int64 { if (da.isEmpty()) return false; return other <= da.convert(); } inline bool operator>(const Poco::Int64 & other, const Var & da) /// Greater than operator for comparing Var with Poco::Int64 { if (da.isEmpty()) return false; return other > da.convert(); } inline bool operator>=(const Poco::Int64 & other, const Var & da) /// Greater than or equal operator for comparing Var with Poco::Int64 { if (da.isEmpty()) return false; return other >= da.convert(); } inline Poco::UInt64 operator+(const Poco::UInt64 & other, const Var & da) /// Addition operator for adding Var to Poco::UInt64 { return other + da.convert(); } inline Poco::UInt64 operator-(const Poco::UInt64 & other, const Var & da) /// Subtraction operator for subtracting Var from Poco::UInt64 { return other - da.convert(); } inline Poco::UInt64 operator*(const Poco::UInt64 & other, const Var & da) /// Multiplication operator for multiplying Var with Poco::UInt64 { return other * da.convert(); } inline Poco::UInt64 operator/(const Poco::UInt64 & other, const Var & da) /// Division operator for dividing Var with Poco::UInt64 { return other / da.convert(); } inline Poco::UInt64 operator+=(Poco::UInt64 & other, const Var & da) /// Addition assignment operator for adding Var to Poco::UInt64 { return other += da.convert(); } inline Poco::UInt64 operator-=(Poco::UInt64 & other, const Var & da) /// Subtraction assignment operator for subtracting Var from Poco::UInt64 { return other -= da.convert(); } inline Poco::UInt64 operator*=(Poco::UInt64 & other, const Var & da) /// Multiplication assignment operator for multiplying Var with Poco::UInt64 { return other *= da.convert(); } inline Poco::UInt64 operator/=(Poco::UInt64 & other, const Var & da) /// Division assignment operator for dividing Var with Poco::UInt64 { return other /= da.convert(); } inline bool operator==(const Poco::UInt64 & other, const Var & da) /// Equality operator for comparing Var with Poco::UInt64 { if (da.isEmpty()) return false; return other == da.convert(); } inline bool operator!=(const Poco::UInt64 & other, const Var & da) /// Inequality operator for comparing Var with Poco::UInt64 { if (da.isEmpty()) return true; return other != da.convert(); } inline bool operator<(const Poco::UInt64 & other, const Var & da) /// Less than operator for comparing Var with Poco::UInt64 { if (da.isEmpty()) return false; return other < da.convert(); } inline bool operator<=(const Poco::UInt64 & other, const Var & da) /// Less than or equal operator for comparing Var with Poco::UInt64 { if (da.isEmpty()) return false; return other <= da.convert(); } inline bool operator>(const Poco::UInt64 & other, const Var & da) /// Greater than operator for comparing Var with Poco::UInt64 { if (da.isEmpty()) return false; return other > da.convert(); } inline bool operator>=(const Poco::UInt64 & other, const Var & da) /// Greater than or equal operator for comparing Var with Poco::UInt64 { if (da.isEmpty()) return false; return other >= da.convert(); } inline float operator+(const float & other, const Var & da) /// Addition operator for adding Var to float { return other + da.convert(); } inline float operator-(const float & other, const Var & da) /// Subtraction operator for subtracting Var from float { return other - da.convert(); } inline float operator*(const float & other, const Var & da) /// Multiplication operator for multiplying Var with float { return other * da.convert(); } inline float operator/(const float & other, const Var & da) /// Division operator for dividing Var with float { return other / da.convert(); } inline float operator+=(float & other, const Var & da) /// Addition assignment operator for adding Var to float { return other += da.convert(); } inline float operator-=(float & other, const Var & da) /// Subtraction assignment operator for subtracting Var from float { return other -= da.convert(); } inline float operator*=(float & other, const Var & da) /// Multiplication assignment operator for multiplying Var with float { return other *= da.convert(); } inline float operator/=(float & other, const Var & da) /// Division assignment operator for dividing Var with float { return other /= da.convert(); } inline bool operator==(const float & other, const Var & da) /// Equality operator for comparing Var with float { if (da.isEmpty()) return false; return other == da.convert(); } inline bool operator!=(const float & other, const Var & da) /// Inequality operator for comparing Var with float { if (da.isEmpty()) return true; return other != da.convert(); } inline bool operator<(const float & other, const Var & da) /// Less than operator for comparing Var with float { if (da.isEmpty()) return false; return other < da.convert(); } inline bool operator<=(const float & other, const Var & da) /// Less than or equal operator for comparing Var with float { if (da.isEmpty()) return false; return other <= da.convert(); } inline bool operator>(const float & other, const Var & da) /// Greater than operator for comparing Var with float { if (da.isEmpty()) return false; return other > da.convert(); } inline bool operator>=(const float & other, const Var & da) /// Greater than or equal operator for comparing Var with float { if (da.isEmpty()) return false; return other >= da.convert(); } inline double operator+(const double & other, const Var & da) /// Addition operator for adding Var to double { return other + da.convert(); } inline double operator-(const double & other, const Var & da) /// Subtraction operator for subtracting Var from double { return other - da.convert(); } inline double operator*(const double & other, const Var & da) /// Multiplication operator for multiplying Var with double { return other * da.convert(); } inline double operator/(const double & other, const Var & da) /// Division operator for dividing Var with double { return other / da.convert(); } inline double operator+=(double & other, const Var & da) /// Addition assignment operator for adding Var to double { return other += da.convert(); } inline double operator-=(double & other, const Var & da) /// Subtraction assignment operator for subtracting Var from double { return other -= da.convert(); } inline double operator*=(double & other, const Var & da) /// Multiplication assignment operator for multiplying Var with double { return other *= da.convert(); } inline double operator/=(double & other, const Var & da) /// Division assignment operator for dividing Var with double { return other /= da.convert(); } inline bool operator==(const double & other, const Var & da) /// Equality operator for comparing Var with double { if (da.isEmpty()) return false; return other == da.convert(); } inline bool operator!=(const double & other, const Var & da) /// Inequality operator for comparing Var with double { if (da.isEmpty()) return true; return other != da.convert(); } inline bool operator<(const double & other, const Var & da) /// Less than operator for comparing Var with double { if (da.isEmpty()) return false; return other < da.convert(); } inline bool operator<=(const double & other, const Var & da) /// Less than or equal operator for comparing Var with double { if (da.isEmpty()) return false; return other <= da.convert(); } inline bool operator>(const double & other, const Var & da) /// Greater than operator for comparing Var with double { if (da.isEmpty()) return false; return other > da.convert(); } inline bool operator>=(const double & other, const Var & da) /// Greater than or equal operator for comparing Var with double { if (da.isEmpty()) return false; return other >= da.convert(); } inline bool operator==(const bool & other, const Var & da) /// Equality operator for comparing Var with bool { if (da.isEmpty()) return false; return other == da.convert(); } inline bool operator!=(const bool & other, const Var & da) /// Inequality operator for comparing Var with bool { if (da.isEmpty()) return true; return other != da.convert(); } inline bool operator==(const std::string & other, const Var & da) /// Equality operator for comparing Var with std::string { if (da.isEmpty()) return false; return other == da.convert(); } inline bool operator!=(const std::string & other, const Var & da) /// Inequality operator for comparing Var with std::string { if (da.isEmpty()) return true; return other != da.convert(); } inline bool operator==(const UTF16String & other, const Var & da) /// Equality operator for comparing Var with UTF16String { if (da.isEmpty()) return false; return other == da.convert(); } inline bool operator!=(const UTF16String & other, const Var & da) /// Inequality operator for comparing Var with UTF16String { if (da.isEmpty()) return true; return other != da.convert(); } inline bool operator==(const char * other, const Var & da) /// Equality operator for comparing Var with const char* { if (da.isEmpty()) return false; return da.convert() == other; } inline bool operator!=(const char * other, const Var & da) /// Inequality operator for comparing Var with const char* { if (da.isEmpty()) return true; return da.convert() != other; } #ifndef POCO_LONG_IS_64_BIT inline long operator+(const long & other, const Var & da) /// Addition operator for adding Var to long { return other + da.convert(); } inline long operator-(const long & other, const Var & da) /// Subtraction operator for subtracting Var from long { return other - da.convert(); } inline long operator*(const long & other, const Var & da) /// Multiplication operator for multiplying Var with long { return other * da.convert(); } inline long operator/(const long & other, const Var & da) /// Division operator for dividing Var with long { return other / da.convert(); } inline long operator+=(long & other, const Var & da) /// Addition assignment operator for adding Var to long { return other += da.convert(); } inline long operator-=(long & other, const Var & da) /// Subtraction assignment operator for subtracting Var from long { return other -= da.convert(); } inline long operator*=(long & other, const Var & da) /// Multiplication assignment operator for multiplying Var with long { return other *= da.convert(); } inline long operator/=(long & other, const Var & da) /// Division assignment operator for dividing Var with long { return other /= da.convert(); } inline bool operator==(const long & other, const Var & da) /// Equality operator for comparing Var with long { if (da.isEmpty()) return false; return other == da.convert(); } inline bool operator!=(const long & other, const Var & da) /// Inequality operator for comparing Var with long { if (da.isEmpty()) return true; return other != da.convert(); } inline bool operator<(const long & other, const Var & da) /// Less than operator for comparing Var with long { if (da.isEmpty()) return false; return other < da.convert(); } inline bool operator<=(const long & other, const Var & da) /// Less than or equal operator for comparing Var with long { if (da.isEmpty()) return false; return other <= da.convert(); } inline bool operator>(const long & other, const Var & da) /// Greater than operator for comparing Var with long { if (da.isEmpty()) return false; return other > da.convert(); } inline bool operator>=(const long & other, const Var & da) /// Greater than or equal operator for comparing Var with long { if (da.isEmpty()) return false; return other >= da.convert(); } #endif // POCO_LONG_IS_64_BIT } // namespace Dynamic //@ deprecated typedef Dynamic::Var DynamicAny; } // namespace Poco #endif // Foundation_Var_INCLUDED