aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/libs/poco/Foundation/include/Poco/Dynamic
diff options
context:
space:
mode:
authororivej <orivej@yandex-team.ru>2022-02-10 16:44:49 +0300
committerDaniil Cherednik <dcherednik@yandex-team.ru>2022-02-10 16:44:49 +0300
commit718c552901d703c502ccbefdfc3c9028d608b947 (patch)
tree46534a98bbefcd7b1f3faa5b52c138ab27db75b7 /contrib/libs/poco/Foundation/include/Poco/Dynamic
parente9656aae26e0358d5378e5b63dcac5c8dbe0e4d0 (diff)
downloadydb-718c552901d703c502ccbefdfc3c9028d608b947.tar.gz
Restoring authorship annotation for <orivej@yandex-team.ru>. Commit 1 of 2.
Diffstat (limited to 'contrib/libs/poco/Foundation/include/Poco/Dynamic')
-rw-r--r--contrib/libs/poco/Foundation/include/Poco/Dynamic/Pair.h824
-rw-r--r--contrib/libs/poco/Foundation/include/Poco/Dynamic/Struct.h1134
-rw-r--r--contrib/libs/poco/Foundation/include/Poco/Dynamic/Var.h4424
-rw-r--r--contrib/libs/poco/Foundation/include/Poco/Dynamic/VarHolder.h8422
-rw-r--r--contrib/libs/poco/Foundation/include/Poco/Dynamic/VarIterator.h300
5 files changed, 7552 insertions, 7552 deletions
diff --git a/contrib/libs/poco/Foundation/include/Poco/Dynamic/Pair.h b/contrib/libs/poco/Foundation/include/Poco/Dynamic/Pair.h
index c64eececeb..18b283a501 100644
--- a/contrib/libs/poco/Foundation/include/Poco/Dynamic/Pair.h
+++ b/contrib/libs/poco/Foundation/include/Poco/Dynamic/Pair.h
@@ -1,412 +1,412 @@
-//
-// Pair.h
-//
-// Library: Foundation
-// Package: Dynamic
-// Module: Pair
-//
-// Definition of the Pair class.
-//
-// Copyright (c) 2007, Applied Informatics Software Engineering GmbH.
-// and Contributors.
-//
-// SPDX-License-Identifier: BSL-1.0
-//
-
-
-#ifndef Foundation_Pair_INCLUDED
-#define Foundation_Pair_INCLUDED
-
-
-#include "Poco/Foundation.h"
-#include "Poco/Dynamic/Var.h"
-#include "Poco/Dynamic/VarHolder.h"
-#include <utility>
-
-
-namespace Poco {
-namespace Dynamic {
-
-
-template <typename K>
-class Pair
- /// Pair allows to define a pair of values.
-{
-public:
- typedef typename std::pair<K, Var> Data;
-
- Pair(): _data()
- /// Creates an empty Pair
- {
- }
-
- Pair(const Pair& other): _data(other._data)
- /// Creates the Pair from another pair.
- {
- }
-
- Pair(const Data& val): _data(val)
- /// Creates the Pair from the given value.
- {
- }
-
- template <typename T>
- Pair(const std::pair<K, T>& val): _data(std::make_pair(val.first, val.second))
- /// Creates Pair form standard pair.
- {
- }
-
- template <typename T>
- Pair(const K& first, const T& second): _data(std::make_pair(first, second))
- /// Creates pair from two values.
- {
- }
-
- virtual ~Pair()
- /// Destroys the Pair.
- {
- }
-
- Pair& swap(Pair& other)
- /// Swaps the content of the two Pairs.
- {
- std::swap(_data, other._data);
- return *this;
- }
-
- Pair& operator = (const Pair& other)
- /// Copy constructs Pair from another pair.
- {
- Pair(other).swap(*this);
- return *this;
- }
-
- inline const K& first() const
- /// Returns the first member of the pair.
- {
- return _data.first;
- }
-
- inline const Var& second() const
- /// Returns the second member of the pair.
- {
- return _data.second;
- }
-
- std::string toString()
- {
- std::string str;
- Var(*this).convert<std::string>(str);
- return str;
- }
-
-private:
- Data _data;
-};
-
-
-template <>
-class VarHolderImpl<Pair<std::string> >: public VarHolder
-{
-public:
- VarHolderImpl(const Pair<std::string>& val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(Pair<std::string>);
- }
-
- void convert(Int8& val) const
- {
- throw BadCastException("Cannot cast Pair type to Int8");
- }
-
- void convert(Int16& val) const
- {
- throw BadCastException("Cannot cast Pair type to Int16");
- }
-
- void convert(Int32& val) const
- {
- throw BadCastException("Cannot cast Pair type to Int32");
- }
-
- void convert(Int64& val) const
- {
- throw BadCastException("Cannot cast Pair type to Int64");
- }
-
- void convert(UInt8& val) const
- {
- throw BadCastException("Cannot cast Pair type to UInt8");
- }
-
- void convert(UInt16& val) const
- {
- throw BadCastException("Cannot cast Pair type to UInt16");
- }
-
- void convert(UInt32& val) const
- {
- throw BadCastException("Cannot cast Pair type to UInt32");
- }
-
- void convert(UInt64& val) const
- {
- throw BadCastException("Cannot cast Pair type to UInt64");
- }
-
- void convert(bool& val) const
- {
- throw BadCastException("Cannot cast Pair type to bool");
- }
-
- void convert(float& val) const
- {
- throw BadCastException("Cannot cast Pair type to float");
- }
-
- void convert(double& val) const
- {
- throw BadCastException("Cannot cast Pair type to double");
- }
-
- void convert(char& val) const
- {
- throw BadCastException("Cannot cast Pair type to char");
- }
-
- void convert(std::string& val) const
- {
- // Serialize in JSON format: equals an object
- // JSON format definition: { string ':' value } string:value pair n-times, sep. by ','
- val.append("{ ");
- Var key(_val.first());
- Impl::appendJSONKey(val, key);
- val.append(" : ");
- Impl::appendJSONValue(val, _val.second());
- val.append(" }");
- }
-
- void convert(Poco::DateTime&) const
- {
- throw BadCastException("Pair -> Poco::DateTime");
- }
-
- void convert(Poco::LocalDateTime&) const
- {
- throw BadCastException("Pair -> Poco::LocalDateTime");
- }
-
- void convert(Poco::Timestamp&) const
- {
- throw BadCastException("Pair -> Poco::Timestamp");
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const Pair<std::string>& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return false;
- }
-
- bool isSigned() const
- {
- return false;
- }
-
- bool isNumeric() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- Pair<std::string> _val;
-};
-
-
-template <>
-class VarHolderImpl<Pair<int> >: public VarHolder
-{
-public:
- VarHolderImpl(const Pair<int>& val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(Pair<int>);
- }
-
- void convert(Int8& val) const
- {
- throw BadCastException("Cannot cast Pair type to Int8");
- }
-
- void convert(Int16& val) const
- {
- throw BadCastException("Cannot cast Pair type to Int16");
- }
-
- void convert(Int32& val) const
- {
- throw BadCastException("Cannot cast Pair type to Int32");
- }
-
- void convert(Int64& val) const
- {
- throw BadCastException("Cannot cast Pair type to Int64");
- }
-
- void convert(UInt8& val) const
- {
- throw BadCastException("Cannot cast Pair type to UInt8");
- }
-
- void convert(UInt16& val) const
- {
- throw BadCastException("Cannot cast Pair type to UInt16");
- }
-
- void convert(UInt32& val) const
- {
- throw BadCastException("Cannot cast Pair type to UInt32");
- }
-
- void convert(UInt64& val) const
- {
- throw BadCastException("Cannot cast Pair type to UInt64");
- }
-
- void convert(bool& val) const
- {
- throw BadCastException("Cannot cast Pair type to bool");
- }
-
- void convert(float& val) const
- {
- throw BadCastException("Cannot cast Pair type to float");
- }
-
- void convert(double& val) const
- {
- throw BadCastException("Cannot cast Pair type to double");
- }
-
- void convert(char& val) const
- {
- throw BadCastException("Cannot cast Pair type to char");
- }
-
- void convert(std::string& val) const
- {
- // Serialize in JSON format: equals an object
- // JSON format definition: { string ':' value } string:value pair n-times, sep. by ','
- val.append("{ ");
- Var key(_val.first());
- Impl::appendJSONKey(val, key);
- val.append(" : ");
- Impl::appendJSONValue(val, _val.second());
- val.append(" }");
- }
-
- void convert(Poco::DateTime&) const
- {
- throw BadCastException("Pair -> Poco::DateTime");
- }
-
- void convert(Poco::LocalDateTime&) const
- {
- throw BadCastException("Pair -> Poco::LocalDateTime");
- }
-
- void convert(Poco::Timestamp&) const
- {
- throw BadCastException("Pair -> Poco::Timestamp");
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const Pair<int>& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return false;
- }
-
- bool isSigned() const
- {
- return false;
- }
-
- bool isNumeric() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- Pair<int> _val;
-};
-
-
-} // namespace Dynamic
-
-
-} // namespace Poco
-
-
-#endif // Foundation_Pair_INCLUDED
+//
+// Pair.h
+//
+// Library: Foundation
+// Package: Dynamic
+// Module: Pair
+//
+// Definition of the Pair class.
+//
+// Copyright (c) 2007, Applied Informatics Software Engineering GmbH.
+// and Contributors.
+//
+// SPDX-License-Identifier: BSL-1.0
+//
+
+
+#ifndef Foundation_Pair_INCLUDED
+#define Foundation_Pair_INCLUDED
+
+
+#include "Poco/Foundation.h"
+#include "Poco/Dynamic/Var.h"
+#include "Poco/Dynamic/VarHolder.h"
+#include <utility>
+
+
+namespace Poco {
+namespace Dynamic {
+
+
+template <typename K>
+class Pair
+ /// Pair allows to define a pair of values.
+{
+public:
+ typedef typename std::pair<K, Var> Data;
+
+ Pair(): _data()
+ /// Creates an empty Pair
+ {
+ }
+
+ Pair(const Pair& other): _data(other._data)
+ /// Creates the Pair from another pair.
+ {
+ }
+
+ Pair(const Data& val): _data(val)
+ /// Creates the Pair from the given value.
+ {
+ }
+
+ template <typename T>
+ Pair(const std::pair<K, T>& val): _data(std::make_pair(val.first, val.second))
+ /// Creates Pair form standard pair.
+ {
+ }
+
+ template <typename T>
+ Pair(const K& first, const T& second): _data(std::make_pair(first, second))
+ /// Creates pair from two values.
+ {
+ }
+
+ virtual ~Pair()
+ /// Destroys the Pair.
+ {
+ }
+
+ Pair& swap(Pair& other)
+ /// Swaps the content of the two Pairs.
+ {
+ std::swap(_data, other._data);
+ return *this;
+ }
+
+ Pair& operator = (const Pair& other)
+ /// Copy constructs Pair from another pair.
+ {
+ Pair(other).swap(*this);
+ return *this;
+ }
+
+ inline const K& first() const
+ /// Returns the first member of the pair.
+ {
+ return _data.first;
+ }
+
+ inline const Var& second() const
+ /// Returns the second member of the pair.
+ {
+ return _data.second;
+ }
+
+ std::string toString()
+ {
+ std::string str;
+ Var(*this).convert<std::string>(str);
+ return str;
+ }
+
+private:
+ Data _data;
+};
+
+
+template <>
+class VarHolderImpl<Pair<std::string> >: public VarHolder
+{
+public:
+ VarHolderImpl(const Pair<std::string>& val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(Pair<std::string>);
+ }
+
+ void convert(Int8& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to Int8");
+ }
+
+ void convert(Int16& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to Int16");
+ }
+
+ void convert(Int32& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to Int32");
+ }
+
+ void convert(Int64& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to Int64");
+ }
+
+ void convert(UInt8& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to UInt8");
+ }
+
+ void convert(UInt16& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to UInt16");
+ }
+
+ void convert(UInt32& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to UInt32");
+ }
+
+ void convert(UInt64& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to UInt64");
+ }
+
+ void convert(bool& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to bool");
+ }
+
+ void convert(float& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to float");
+ }
+
+ void convert(double& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to double");
+ }
+
+ void convert(char& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to char");
+ }
+
+ void convert(std::string& val) const
+ {
+ // Serialize in JSON format: equals an object
+ // JSON format definition: { string ':' value } string:value pair n-times, sep. by ','
+ val.append("{ ");
+ Var key(_val.first());
+ Impl::appendJSONKey(val, key);
+ val.append(" : ");
+ Impl::appendJSONValue(val, _val.second());
+ val.append(" }");
+ }
+
+ void convert(Poco::DateTime&) const
+ {
+ throw BadCastException("Pair -> Poco::DateTime");
+ }
+
+ void convert(Poco::LocalDateTime&) const
+ {
+ throw BadCastException("Pair -> Poco::LocalDateTime");
+ }
+
+ void convert(Poco::Timestamp&) const
+ {
+ throw BadCastException("Pair -> Poco::Timestamp");
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const Pair<std::string>& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return false;
+ }
+
+ bool isSigned() const
+ {
+ return false;
+ }
+
+ bool isNumeric() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ Pair<std::string> _val;
+};
+
+
+template <>
+class VarHolderImpl<Pair<int> >: public VarHolder
+{
+public:
+ VarHolderImpl(const Pair<int>& val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(Pair<int>);
+ }
+
+ void convert(Int8& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to Int8");
+ }
+
+ void convert(Int16& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to Int16");
+ }
+
+ void convert(Int32& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to Int32");
+ }
+
+ void convert(Int64& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to Int64");
+ }
+
+ void convert(UInt8& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to UInt8");
+ }
+
+ void convert(UInt16& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to UInt16");
+ }
+
+ void convert(UInt32& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to UInt32");
+ }
+
+ void convert(UInt64& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to UInt64");
+ }
+
+ void convert(bool& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to bool");
+ }
+
+ void convert(float& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to float");
+ }
+
+ void convert(double& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to double");
+ }
+
+ void convert(char& val) const
+ {
+ throw BadCastException("Cannot cast Pair type to char");
+ }
+
+ void convert(std::string& val) const
+ {
+ // Serialize in JSON format: equals an object
+ // JSON format definition: { string ':' value } string:value pair n-times, sep. by ','
+ val.append("{ ");
+ Var key(_val.first());
+ Impl::appendJSONKey(val, key);
+ val.append(" : ");
+ Impl::appendJSONValue(val, _val.second());
+ val.append(" }");
+ }
+
+ void convert(Poco::DateTime&) const
+ {
+ throw BadCastException("Pair -> Poco::DateTime");
+ }
+
+ void convert(Poco::LocalDateTime&) const
+ {
+ throw BadCastException("Pair -> Poco::LocalDateTime");
+ }
+
+ void convert(Poco::Timestamp&) const
+ {
+ throw BadCastException("Pair -> Poco::Timestamp");
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const Pair<int>& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return false;
+ }
+
+ bool isSigned() const
+ {
+ return false;
+ }
+
+ bool isNumeric() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ Pair<int> _val;
+};
+
+
+} // namespace Dynamic
+
+
+} // namespace Poco
+
+
+#endif // Foundation_Pair_INCLUDED
diff --git a/contrib/libs/poco/Foundation/include/Poco/Dynamic/Struct.h b/contrib/libs/poco/Foundation/include/Poco/Dynamic/Struct.h
index fc9d57d55e..6cd3e3cd65 100644
--- a/contrib/libs/poco/Foundation/include/Poco/Dynamic/Struct.h
+++ b/contrib/libs/poco/Foundation/include/Poco/Dynamic/Struct.h
@@ -1,567 +1,567 @@
-//
-// Struct.h
-//
-// Library: Foundation
-// Package: Dynamic
-// Module: Struct
-//
-// Definition of the Struct class.
-//
-// Copyright (c) 2007, Applied Informatics Software Engineering GmbH.
-// and Contributors.
-//
-// SPDX-License-Identifier: BSL-1.0
-//
-
-
-#ifndef Foundation_Struct_INCLUDED
-#define Foundation_Struct_INCLUDED
-
-
-#include "Poco/Foundation.h"
-#include "Poco/Dynamic/Var.h"
-#include "Poco/Dynamic/VarHolder.h"
-#include "Poco/SharedPtr.h"
-#include <map>
-#include <set>
-
-
-namespace Poco {
-namespace Dynamic {
-
-
-template <typename K>
-class Struct
- /// Struct allows to define a named collection of Var objects.
-{
-public:
- typedef typename std::map<K, Var> Data;
- typedef typename std::set<K> NameSet;
- typedef typename Data::iterator Iterator;
- typedef typename Data::const_iterator ConstIterator;
- typedef typename Struct<K>::Data::value_type ValueType;
- typedef typename Struct<K>::Data::size_type SizeType;
- typedef typename std::pair<typename Struct<K>::Iterator, bool> InsRetVal;
- typedef typename Poco::SharedPtr<Struct<K> > Ptr;
-
- Struct(): _data()
- /// Creates an empty Struct
- {
- }
-
- Struct(const Data& val): _data(val)
- /// Creates the Struct from the given value.
- {
- }
-
- template <typename T>
- Struct(const std::map<K, T>& val)
- {
- typedef typename std::map<K, T>::const_iterator MapConstIterator;
-
- MapConstIterator it = val.begin();
- MapConstIterator itEnd = val.end();
- for (; it != itEnd; ++it) _data.insert(ValueType(it->first, Var(it->second)));
- }
-
- virtual ~Struct()
- /// Destroys the Struct.
- {
- }
-
- inline Var& operator [] (const K& name)
- /// Returns the Var with the given name, creates an entry if not found.
- {
- return _data[name];
- }
-
- const Var& operator [] (const K& name) const
- /// Returns the Var with the given name, throws a
- /// NotFoundException if the data member is not found.
- {
- ConstIterator it = find(name);
- if (it == end()) throw NotFoundException(name);
- return it->second;
- }
-
- inline bool contains(const K& name) const
- /// Returns true if the Struct contains a member with the given name
- {
- return find(name) != end();
- }
-
- inline Iterator find(const K& name)
- /// Returns an iterator, pointing to the <name,Var> pair containing
- /// the element, or it returns end() if the member was not found
- {
- return _data.find(name);
- }
-
- inline ConstIterator find(const K& name) const
- /// Returns a const iterator, pointing to the <name,Var> pair containing
- /// the element, or it returns end() if the member was not found
- {
- return _data.find(name);
- }
-
- inline Iterator end()
- /// Returns the end iterator for the Struct
- {
- return _data.end();
- }
-
- inline ConstIterator end() const
- /// Returns the end const iterator for the Struct
- {
- return _data.end();
- }
-
- inline Iterator begin()
- /// Returns the begin iterator for the Struct
- {
- return _data.begin();
- }
-
- inline ConstIterator begin() const
- /// Returns the begin const iterator for the Struct
- {
- return _data.begin();
- }
-
- template <typename T>
- inline InsRetVal insert(const K& key, const T& value)
- /// Inserts a <name, Var> pair into the Struct,
- /// returns a pair containing the iterator and a boolean which
- /// indicates success or not (is true, when insert succeeded, false,
- /// when already another element was present, in this case Iterator
- /// points to that other element)
- {
- // fix: SunPro C++ is silly ...
- ValueType valueType(key, value);
- return insert(valueType);
- }
-
- inline InsRetVal insert(const ValueType& aPair)
- /// Inserts a <name, Var> pair into the Struct,
- /// returns a pair containing the iterator and a boolean which
- /// indicates success or not (is true, when insert succeeded, false,
- /// when already another element was present, in this case Iterator
- /// points to that other element)
- {
- return _data.insert(aPair);
- }
-
- inline SizeType erase(const K& key)
- /// Erases the element if found, returns number of elements deleted
- {
- return _data.erase(key);
- }
-
- inline void erase(Iterator& it)
- /// Erases the element at the given position
- {
- _data.erase(it);
- }
-
- inline bool empty() const
- /// Returns true if the Struct doesn't contain any members
- {
- return _data.empty();
- }
-
- inline void clear()
- /// Clears the Struct contents
- {
- _data.clear();
- }
-
- SizeType size() const
- /// Returns the number of members the Struct contains
- {
- return _data.size();
- }
-
- inline NameSet members() const
- /// Returns a sorted collection containing all member names
- {
- NameSet keys;
- ConstIterator it = begin();
- ConstIterator itEnd = end();
- for (; it != itEnd; ++it) keys.insert(it->first);
- return keys;
- }
-
- std::string toString()
- {
- std::string str;
- Var(*this).convert<std::string>(str);
- return str;
- }
-
-private:
- Data _data;
-};
-
-
-template <>
-class VarHolderImpl<Struct<std::string> >: public VarHolder
-{
-public:
- VarHolderImpl(const Struct<std::string>& val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(Struct<std::string>);
- }
-
- void convert(Int8&) const
- {
- throw BadCastException("Cannot cast Struct type to Int8");
- }
-
- void convert(Int16&) const
- {
- throw BadCastException("Cannot cast Struct type to Int16");
- }
-
- void convert(Int32&) const
- {
- throw BadCastException("Cannot cast Struct type to Int32");
- }
-
- void convert(Int64&) const
- {
- throw BadCastException("Cannot cast Struct type to Int64");
- }
-
- void convert(UInt8&) const
- {
- throw BadCastException("Cannot cast Struct type to UInt8");
- }
-
- void convert(UInt16&) const
- {
- throw BadCastException("Cannot cast Struct type to UInt16");
- }
-
- void convert(UInt32&) const
- {
- throw BadCastException("Cannot cast Struct type to UInt32");
- }
-
- void convert(UInt64&) const
- {
- throw BadCastException("Cannot cast Struct type to UInt64");
- }
-
- void convert(bool&) const
- {
- throw BadCastException("Cannot cast Struct type to bool");
- }
-
- void convert(float&) const
- {
- throw BadCastException("Cannot cast Struct type to float");
- }
-
- void convert(double&) const
- {
- throw BadCastException("Cannot cast Struct type to double");
- }
-
- void convert(char&) const
- {
- throw BadCastException("Cannot cast Struct type to char");
- }
-
- void convert(std::string& val) const
- {
- val.append("{ ");
- Struct<std::string>::ConstIterator it = _val.begin();
- Struct<std::string>::ConstIterator itEnd = _val.end();
- if (!_val.empty())
- {
- Var key(it->first);
- Impl::appendJSONKey(val, key);
- val.append(" : ");
- Impl::appendJSONValue(val, it->second);
- ++it;
- }
- for (; it != itEnd; ++it)
- {
- val.append(", ");
- Var key(it->first);
- Impl::appendJSONKey(val, key);
- val.append(" : ");
- Impl::appendJSONValue(val, it->second);
- }
- val.append(" }");
- }
-
- void convert(Poco::DateTime&) const
- {
- throw BadCastException("Struct -> Poco::DateTime");
- }
-
- void convert(Poco::LocalDateTime&) const
- {
- throw BadCastException("Struct -> Poco::LocalDateTime");
- }
-
- void convert(Poco::Timestamp&) const
- {
- throw BadCastException("Struct -> Poco::Timestamp");
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const Struct<std::string>& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return true;
- }
-
- bool isInteger() const
- {
- return false;
- }
-
- bool isSigned() const
- {
- return false;
- }
-
- bool isNumeric() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
- std::size_t size() const
- {
- return _val.size();
- }
-
- Var& operator [] (const std::string& name)
- {
- return _val[name];
- }
-
- const Var& operator [] (const std::string& name) const
- {
- return _val[name];
- }
-
-private:
- Struct<std::string> _val;
-};
-
-
-template <>
-class VarHolderImpl<Struct<int> >: public VarHolder
-{
-public:
- VarHolderImpl(const Struct<int>& val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(Struct<int>);
- }
-
- void convert(Int8&) const
- {
- throw BadCastException("Cannot cast Struct type to Int8");
- }
-
- void convert(Int16&) const
- {
- throw BadCastException("Cannot cast Struct type to Int16");
- }
-
- void convert(Int32&) const
- {
- throw BadCastException("Cannot cast Struct type to Int32");
- }
-
- void convert(Int64&) const
- {
- throw BadCastException("Cannot cast Struct type to Int64");
- }
-
- void convert(UInt8&) const
- {
- throw BadCastException("Cannot cast Struct type to UInt8");
- }
-
- void convert(UInt16&) const
- {
- throw BadCastException("Cannot cast Struct type to UInt16");
- }
-
- void convert(UInt32&) const
- {
- throw BadCastException("Cannot cast Struct type to UInt32");
- }
-
- void convert(UInt64&) const
- {
- throw BadCastException("Cannot cast Struct type to UInt64");
- }
-
- void convert(bool&) const
- {
- throw BadCastException("Cannot cast Struct type to bool");
- }
-
- void convert(float&) const
- {
- throw BadCastException("Cannot cast Struct type to float");
- }
-
- void convert(double&) const
- {
- throw BadCastException("Cannot cast Struct type to double");
- }
-
- void convert(char&) const
- {
- throw BadCastException("Cannot cast Struct type to char");
- }
-
- void convert(std::string& val) const
- {
- val.append("{ ");
- Struct<int>::ConstIterator it = _val.begin();
- Struct<int>::ConstIterator itEnd = _val.end();
- if (!_val.empty())
- {
- Var key(it->first);
- Impl::appendJSONKey(val, key);
- val.append(" : ");
- Impl::appendJSONValue(val, it->second);
- ++it;
- }
- for (; it != itEnd; ++it)
- {
- val.append(", ");
- Var key(it->first);
- Impl::appendJSONKey(val, key);
- val.append(" : ");
- Impl::appendJSONValue(val, it->second);
- }
- val.append(" }");
- }
-
- void convert(Poco::DateTime&) const
- {
- throw BadCastException("Struct -> Poco::DateTime");
- }
-
- void convert(Poco::LocalDateTime&) const
- {
- throw BadCastException("Struct -> Poco::LocalDateTime");
- }
-
- void convert(Poco::Timestamp&) const
- {
- throw BadCastException("Struct -> Poco::Timestamp");
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const Struct<int>& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return true;
- }
-
- bool isInteger() const
- {
- return false;
- }
-
- bool isSigned() const
- {
- return false;
- }
-
- bool isNumeric() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
- std::size_t size() const
- {
- return _val.size();
- }
-
- Var& operator [] (int name)
- {
- return _val[name];
- }
-
- const Var& operator [] (int name) const
- {
- return _val[name];
- }
-
-private:
- Struct<int> _val;
-};
-
-
-} // namespace Dynamic
-
-
-typedef Dynamic::Struct<std::string> DynamicStruct;
-
-
-} // namespace Poco
-
-
-#endif // Foundation_Struct_INCLUDED
+//
+// Struct.h
+//
+// Library: Foundation
+// Package: Dynamic
+// Module: Struct
+//
+// Definition of the Struct class.
+//
+// Copyright (c) 2007, Applied Informatics Software Engineering GmbH.
+// and Contributors.
+//
+// SPDX-License-Identifier: BSL-1.0
+//
+
+
+#ifndef Foundation_Struct_INCLUDED
+#define Foundation_Struct_INCLUDED
+
+
+#include "Poco/Foundation.h"
+#include "Poco/Dynamic/Var.h"
+#include "Poco/Dynamic/VarHolder.h"
+#include "Poco/SharedPtr.h"
+#include <map>
+#include <set>
+
+
+namespace Poco {
+namespace Dynamic {
+
+
+template <typename K>
+class Struct
+ /// Struct allows to define a named collection of Var objects.
+{
+public:
+ typedef typename std::map<K, Var> Data;
+ typedef typename std::set<K> NameSet;
+ typedef typename Data::iterator Iterator;
+ typedef typename Data::const_iterator ConstIterator;
+ typedef typename Struct<K>::Data::value_type ValueType;
+ typedef typename Struct<K>::Data::size_type SizeType;
+ typedef typename std::pair<typename Struct<K>::Iterator, bool> InsRetVal;
+ typedef typename Poco::SharedPtr<Struct<K> > Ptr;
+
+ Struct(): _data()
+ /// Creates an empty Struct
+ {
+ }
+
+ Struct(const Data& val): _data(val)
+ /// Creates the Struct from the given value.
+ {
+ }
+
+ template <typename T>
+ Struct(const std::map<K, T>& val)
+ {
+ typedef typename std::map<K, T>::const_iterator MapConstIterator;
+
+ MapConstIterator it = val.begin();
+ MapConstIterator itEnd = val.end();
+ for (; it != itEnd; ++it) _data.insert(ValueType(it->first, Var(it->second)));
+ }
+
+ virtual ~Struct()
+ /// Destroys the Struct.
+ {
+ }
+
+ inline Var& operator [] (const K& name)
+ /// Returns the Var with the given name, creates an entry if not found.
+ {
+ return _data[name];
+ }
+
+ const Var& operator [] (const K& name) const
+ /// Returns the Var with the given name, throws a
+ /// NotFoundException if the data member is not found.
+ {
+ ConstIterator it = find(name);
+ if (it == end()) throw NotFoundException(name);
+ return it->second;
+ }
+
+ inline bool contains(const K& name) const
+ /// Returns true if the Struct contains a member with the given name
+ {
+ return find(name) != end();
+ }
+
+ inline Iterator find(const K& name)
+ /// Returns an iterator, pointing to the <name,Var> pair containing
+ /// the element, or it returns end() if the member was not found
+ {
+ return _data.find(name);
+ }
+
+ inline ConstIterator find(const K& name) const
+ /// Returns a const iterator, pointing to the <name,Var> pair containing
+ /// the element, or it returns end() if the member was not found
+ {
+ return _data.find(name);
+ }
+
+ inline Iterator end()
+ /// Returns the end iterator for the Struct
+ {
+ return _data.end();
+ }
+
+ inline ConstIterator end() const
+ /// Returns the end const iterator for the Struct
+ {
+ return _data.end();
+ }
+
+ inline Iterator begin()
+ /// Returns the begin iterator for the Struct
+ {
+ return _data.begin();
+ }
+
+ inline ConstIterator begin() const
+ /// Returns the begin const iterator for the Struct
+ {
+ return _data.begin();
+ }
+
+ template <typename T>
+ inline InsRetVal insert(const K& key, const T& value)
+ /// Inserts a <name, Var> pair into the Struct,
+ /// returns a pair containing the iterator and a boolean which
+ /// indicates success or not (is true, when insert succeeded, false,
+ /// when already another element was present, in this case Iterator
+ /// points to that other element)
+ {
+ // fix: SunPro C++ is silly ...
+ ValueType valueType(key, value);
+ return insert(valueType);
+ }
+
+ inline InsRetVal insert(const ValueType& aPair)
+ /// Inserts a <name, Var> pair into the Struct,
+ /// returns a pair containing the iterator and a boolean which
+ /// indicates success or not (is true, when insert succeeded, false,
+ /// when already another element was present, in this case Iterator
+ /// points to that other element)
+ {
+ return _data.insert(aPair);
+ }
+
+ inline SizeType erase(const K& key)
+ /// Erases the element if found, returns number of elements deleted
+ {
+ return _data.erase(key);
+ }
+
+ inline void erase(Iterator& it)
+ /// Erases the element at the given position
+ {
+ _data.erase(it);
+ }
+
+ inline bool empty() const
+ /// Returns true if the Struct doesn't contain any members
+ {
+ return _data.empty();
+ }
+
+ inline void clear()
+ /// Clears the Struct contents
+ {
+ _data.clear();
+ }
+
+ SizeType size() const
+ /// Returns the number of members the Struct contains
+ {
+ return _data.size();
+ }
+
+ inline NameSet members() const
+ /// Returns a sorted collection containing all member names
+ {
+ NameSet keys;
+ ConstIterator it = begin();
+ ConstIterator itEnd = end();
+ for (; it != itEnd; ++it) keys.insert(it->first);
+ return keys;
+ }
+
+ std::string toString()
+ {
+ std::string str;
+ Var(*this).convert<std::string>(str);
+ return str;
+ }
+
+private:
+ Data _data;
+};
+
+
+template <>
+class VarHolderImpl<Struct<std::string> >: public VarHolder
+{
+public:
+ VarHolderImpl(const Struct<std::string>& val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(Struct<std::string>);
+ }
+
+ void convert(Int8&) const
+ {
+ throw BadCastException("Cannot cast Struct type to Int8");
+ }
+
+ void convert(Int16&) const
+ {
+ throw BadCastException("Cannot cast Struct type to Int16");
+ }
+
+ void convert(Int32&) const
+ {
+ throw BadCastException("Cannot cast Struct type to Int32");
+ }
+
+ void convert(Int64&) const
+ {
+ throw BadCastException("Cannot cast Struct type to Int64");
+ }
+
+ void convert(UInt8&) const
+ {
+ throw BadCastException("Cannot cast Struct type to UInt8");
+ }
+
+ void convert(UInt16&) const
+ {
+ throw BadCastException("Cannot cast Struct type to UInt16");
+ }
+
+ void convert(UInt32&) const
+ {
+ throw BadCastException("Cannot cast Struct type to UInt32");
+ }
+
+ void convert(UInt64&) const
+ {
+ throw BadCastException("Cannot cast Struct type to UInt64");
+ }
+
+ void convert(bool&) const
+ {
+ throw BadCastException("Cannot cast Struct type to bool");
+ }
+
+ void convert(float&) const
+ {
+ throw BadCastException("Cannot cast Struct type to float");
+ }
+
+ void convert(double&) const
+ {
+ throw BadCastException("Cannot cast Struct type to double");
+ }
+
+ void convert(char&) const
+ {
+ throw BadCastException("Cannot cast Struct type to char");
+ }
+
+ void convert(std::string& val) const
+ {
+ val.append("{ ");
+ Struct<std::string>::ConstIterator it = _val.begin();
+ Struct<std::string>::ConstIterator itEnd = _val.end();
+ if (!_val.empty())
+ {
+ Var key(it->first);
+ Impl::appendJSONKey(val, key);
+ val.append(" : ");
+ Impl::appendJSONValue(val, it->second);
+ ++it;
+ }
+ for (; it != itEnd; ++it)
+ {
+ val.append(", ");
+ Var key(it->first);
+ Impl::appendJSONKey(val, key);
+ val.append(" : ");
+ Impl::appendJSONValue(val, it->second);
+ }
+ val.append(" }");
+ }
+
+ void convert(Poco::DateTime&) const
+ {
+ throw BadCastException("Struct -> Poco::DateTime");
+ }
+
+ void convert(Poco::LocalDateTime&) const
+ {
+ throw BadCastException("Struct -> Poco::LocalDateTime");
+ }
+
+ void convert(Poco::Timestamp&) const
+ {
+ throw BadCastException("Struct -> Poco::Timestamp");
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const Struct<std::string>& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return true;
+ }
+
+ bool isInteger() const
+ {
+ return false;
+ }
+
+ bool isSigned() const
+ {
+ return false;
+ }
+
+ bool isNumeric() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+ std::size_t size() const
+ {
+ return _val.size();
+ }
+
+ Var& operator [] (const std::string& name)
+ {
+ return _val[name];
+ }
+
+ const Var& operator [] (const std::string& name) const
+ {
+ return _val[name];
+ }
+
+private:
+ Struct<std::string> _val;
+};
+
+
+template <>
+class VarHolderImpl<Struct<int> >: public VarHolder
+{
+public:
+ VarHolderImpl(const Struct<int>& val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(Struct<int>);
+ }
+
+ void convert(Int8&) const
+ {
+ throw BadCastException("Cannot cast Struct type to Int8");
+ }
+
+ void convert(Int16&) const
+ {
+ throw BadCastException("Cannot cast Struct type to Int16");
+ }
+
+ void convert(Int32&) const
+ {
+ throw BadCastException("Cannot cast Struct type to Int32");
+ }
+
+ void convert(Int64&) const
+ {
+ throw BadCastException("Cannot cast Struct type to Int64");
+ }
+
+ void convert(UInt8&) const
+ {
+ throw BadCastException("Cannot cast Struct type to UInt8");
+ }
+
+ void convert(UInt16&) const
+ {
+ throw BadCastException("Cannot cast Struct type to UInt16");
+ }
+
+ void convert(UInt32&) const
+ {
+ throw BadCastException("Cannot cast Struct type to UInt32");
+ }
+
+ void convert(UInt64&) const
+ {
+ throw BadCastException("Cannot cast Struct type to UInt64");
+ }
+
+ void convert(bool&) const
+ {
+ throw BadCastException("Cannot cast Struct type to bool");
+ }
+
+ void convert(float&) const
+ {
+ throw BadCastException("Cannot cast Struct type to float");
+ }
+
+ void convert(double&) const
+ {
+ throw BadCastException("Cannot cast Struct type to double");
+ }
+
+ void convert(char&) const
+ {
+ throw BadCastException("Cannot cast Struct type to char");
+ }
+
+ void convert(std::string& val) const
+ {
+ val.append("{ ");
+ Struct<int>::ConstIterator it = _val.begin();
+ Struct<int>::ConstIterator itEnd = _val.end();
+ if (!_val.empty())
+ {
+ Var key(it->first);
+ Impl::appendJSONKey(val, key);
+ val.append(" : ");
+ Impl::appendJSONValue(val, it->second);
+ ++it;
+ }
+ for (; it != itEnd; ++it)
+ {
+ val.append(", ");
+ Var key(it->first);
+ Impl::appendJSONKey(val, key);
+ val.append(" : ");
+ Impl::appendJSONValue(val, it->second);
+ }
+ val.append(" }");
+ }
+
+ void convert(Poco::DateTime&) const
+ {
+ throw BadCastException("Struct -> Poco::DateTime");
+ }
+
+ void convert(Poco::LocalDateTime&) const
+ {
+ throw BadCastException("Struct -> Poco::LocalDateTime");
+ }
+
+ void convert(Poco::Timestamp&) const
+ {
+ throw BadCastException("Struct -> Poco::Timestamp");
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const Struct<int>& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return true;
+ }
+
+ bool isInteger() const
+ {
+ return false;
+ }
+
+ bool isSigned() const
+ {
+ return false;
+ }
+
+ bool isNumeric() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+ std::size_t size() const
+ {
+ return _val.size();
+ }
+
+ Var& operator [] (int name)
+ {
+ return _val[name];
+ }
+
+ const Var& operator [] (int name) const
+ {
+ return _val[name];
+ }
+
+private:
+ Struct<int> _val;
+};
+
+
+} // namespace Dynamic
+
+
+typedef Dynamic::Struct<std::string> DynamicStruct;
+
+
+} // namespace Poco
+
+
+#endif // Foundation_Struct_INCLUDED
diff --git a/contrib/libs/poco/Foundation/include/Poco/Dynamic/Var.h b/contrib/libs/poco/Foundation/include/Poco/Dynamic/Var.h
index bd06afe54b..674041c87b 100644
--- a/contrib/libs/poco/Foundation/include/Poco/Dynamic/Var.h
+++ b/contrib/libs/poco/Foundation/include/Poco/Dynamic/Var.h
@@ -1,2228 +1,2228 @@
-//
-// 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 "Poco/Foundation.h"
-#include "Poco/Format.h"
-#include "Poco/SharedPtr.h"
-#include "Poco/Dynamic/VarHolder.h"
-#include "Poco/Dynamic/VarIterator.h"
-#include <typeinfo>
-
-
-namespace Poco {
-namespace Dynamic {
-
-
-template <typename T>
-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.
+//
+// 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 "Poco/Foundation.h"
+#include "Poco/Format.h"
+#include "Poco/SharedPtr.h"
+#include "Poco/Dynamic/VarHolder.h"
+#include "Poco/Dynamic/VarIterator.h"
+#include <typeinfo>
+
+
+namespace Poco {
+namespace Dynamic {
+
+
+template <typename T>
+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.
///
- /// 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:
+ /// An attempt to convert or extract from a non-initialized ("empty") Var variable shall result
+ /// in an exception being thrown.
///
- /// - for std::string and const char* values, only '+' and '+=' operations are supported
+ /// 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.
///
- /// - 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 (--)
+ /// 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.
///
- /// - for all other types, InvalidArgumentException is thrown upon attempt of an arithmetic operation
+ /// Boolean conversion is performed as follows:
///
- /// 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<Var> Ptr;
- typedef Poco::Dynamic::VarIterator Iterator;
- typedef const VarIterator ConstIterator;
-
- Var();
- /// Creates an empty Var.
-
- template <typename T>
- Var(const T& val)
- /// Creates the Var from the given value.
-#ifdef POCO_NO_SOO
- : _pHolder(new VarHolderImpl<T>(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 <typename T>
- 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 <typename T>
- T convert() const
- /// Invoke this method to perform a safe conversion.
- ///
- /// Example usage:
- /// Var any("42");
- /// int i = any.convert<int>();
- ///
- /// 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>();
-
- T result;
- pHolder->convert(result);
- return result;
- }
-
- template <typename T>
- 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<T>();
- else
- {
- T result;
- pHolder->convert(result);
- return result;
- }
- }
-
- template <typename T>
- 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<T>* pHolderImpl = static_cast<VarHolderImpl<T>*>(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 <typename T>
- 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 <typename T>
- const Var operator + (const T& other) const
- /// Addition operator for adding POD to Var
- {
- return convert<T>() + 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 <typename T>
- Var& operator += (const T& other)
- /// Addition assignment operator for addition/assignment of POD to Var.
- {
- return *this = convert<T>() + 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 <typename T>
- const Var operator - (const T& other) const
- /// Subtraction operator for subtracting POD from Var
- {
- return convert<T>() - other;
- }
-
- const Var operator - (const Var& other) const;
- /// Subtraction operator overload for Var
-
+ /// 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<Var> Ptr;
+ typedef Poco::Dynamic::VarIterator Iterator;
+ typedef const VarIterator ConstIterator;
+
+ Var();
+ /// Creates an empty Var.
+
+ template <typename T>
+ Var(const T& val)
+ /// Creates the Var from the given value.
+#ifdef POCO_NO_SOO
+ : _pHolder(new VarHolderImpl<T>(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 <typename T>
+ 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 <typename T>
+ T convert() const
+ /// Invoke this method to perform a safe conversion.
+ ///
+ /// Example usage:
+ /// Var any("42");
+ /// int i = any.convert<int>();
+ ///
+ /// 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>();
+
+ T result;
+ pHolder->convert(result);
+ return result;
+ }
+
template <typename T>
- Var& operator -= (const T& other)
- /// Subtraction assignment operator
- {
- return *this = convert<T>() - other;
- }
-
- Var& operator -= (const Var& other);
- /// Subtraction assignment operator overload for Var
-
+ 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<T>();
+ else
+ {
+ T result;
+ pHolder->convert(result);
+ return result;
+ }
+ }
+
template <typename T>
- const Var operator * (const T& other) const
- /// Multiplication operator for multiplying Var with POD
- {
- return convert<T>() * other;
- }
-
- const Var operator * (const Var& other) const;
- /// Multiplication operator overload for Var
-
+ 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<T>* pHolderImpl = static_cast<VarHolderImpl<T>*>(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 <typename T>
+ 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 <typename T>
- Var& operator *= (const T& other)
- /// Multiplication assignment operator
- {
- return *this = convert<T>() * other;
- }
-
- Var& operator *= (const Var& other);
- /// Multiplication assignment operator overload for Var
-
+ const Var operator + (const T& other) const
+ /// Addition operator for adding POD to Var
+ {
+ return convert<T>() + 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 <typename T>
+ Var& operator += (const T& other)
+ /// Addition assignment operator for addition/assignment of POD to Var.
+ {
+ return *this = convert<T>() + 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 <typename T>
+ const Var operator - (const T& other) const
+ /// Subtraction operator for subtracting POD from Var
+ {
+ return convert<T>() - other;
+ }
+
+ const Var operator - (const Var& other) const;
+ /// Subtraction operator overload for Var
+
+ template <typename T>
+ Var& operator -= (const T& other)
+ /// Subtraction assignment operator
+ {
+ return *this = convert<T>() - other;
+ }
+
+ Var& operator -= (const Var& other);
+ /// Subtraction assignment operator overload for Var
+
+ template <typename T>
+ const Var operator * (const T& other) const
+ /// Multiplication operator for multiplying Var with POD
+ {
+ return convert<T>() * other;
+ }
+
+ const Var operator * (const Var& other) const;
+ /// Multiplication operator overload for Var
+
+ template <typename T>
+ Var& operator *= (const T& other)
+ /// Multiplication assignment operator
+ {
+ return *this = convert<T>() * other;
+ }
+
+ Var& operator *= (const Var& other);
+ /// Multiplication assignment operator overload for Var
+
+ template <typename T>
+ const Var operator / (const T& other) const
+ /// Division operator for dividing Var with POD
+ {
+ return convert<T>() / other;
+ }
+
+ const Var operator / (const Var& other) const;
+ /// Division operator overload for Var
+
+ template <typename T>
+ Var& operator /= (const T& other)
+ /// Division assignment operator
+ {
+ return *this = convert<T>() / other;
+ }
+
+ Var& operator /= (const Var& other);
+ /// Division assignment operator specialization for Var
+
+ template <typename T>
+ bool operator == (const T& other) const
+ /// Equality operator
+ {
+ if (isEmpty()) return false;
+ return convert<T>() == 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 <typename T>
+ bool operator != (const T& other) const
+ /// Inequality operator
+ {
+ if (isEmpty()) return true;
+ return convert<T>() != 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 <typename T>
+ bool operator < (const T& other) const
+ /// Less than operator
+ {
+ if (isEmpty()) return false;
+ return convert<T>() < other;
+ }
+
+ bool operator < (const Var& other) const;
+ /// Less than operator overload for Var
+
+ template <typename T>
+ bool operator <= (const T& other) const
+ /// Less than or equal operator
+ {
+ if (isEmpty()) return false;
+ return convert<T>() <= other;
+ }
+
+ bool operator <= (const Var& other) const;
+ /// Less than or equal operator overload for Var
+
+ template <typename T>
+ bool operator > (const T& other) const
+ /// Greater than operator
+ {
+ if (isEmpty()) return false;
+ return convert<T>() > other;
+ }
+
+ bool operator > (const Var& other) const;
+ /// Greater than operator overload for Var
+
+ template <typename T>
+ bool operator >= (const T& other) const
+ /// Greater than or equal operator
+ {
+ if (isEmpty()) return false;
+ return convert<T>() >= other;
+ }
+
+ bool operator >= (const Var& other) const;
+ /// Greater than or equal operator overload for Var
+
template <typename T>
- const Var operator / (const T& other) const
- /// Division operator for dividing Var with POD
- {
- return convert<T>() / other;
- }
-
- const Var operator / (const Var& other) const;
- /// Division operator overload for Var
-
+ bool operator || (const T& other) const
+ /// Logical OR operator
+ {
+ if (isEmpty()) return false;
+ return convert<bool>() || other;
+ }
+
+ bool operator || (const Var& other) const;
+ /// Logical OR operator operator overload for Var
+
template <typename T>
- Var& operator /= (const T& other)
- /// Division assignment operator
- {
- return *this = convert<T>() / other;
- }
-
- Var& operator /= (const Var& other);
- /// Division assignment operator specialization for Var
-
+ bool operator && (const T& other) const
+ /// Logical AND operator.
+ {
+ if (isEmpty()) return false;
+ return convert<bool>() && 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 <typename T>
- bool operator == (const T& other) const
- /// Equality operator
- {
- if (isEmpty()) return false;
- return convert<T>() == other;
- }
-
- bool operator == (const char* other) const;
- /// Equality operator overload for const char*
-
- bool operator == (const Var& other) const;
- /// Equality operator overload for Var
-
+ Var& operator [] (const T& n)
+ {
+ return getAt(n);
+ }
+
template <typename T>
- bool operator != (const T& other) const
- /// Inequality operator
- {
- if (isEmpty()) return true;
- return convert<T>() != other;
- }
-
- bool operator != (const Var& other) const;
- /// Inequality operator overload for Var
-
- bool operator != (const char* other) const;
- /// Inequality operator overload for const char*
-
+ const Var& operator [] (const T& n) const
+ {
+ return const_cast<Var*>(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<std::string>();
+ 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<std::string>() 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 <typename T>
- bool operator < (const T& other) const
- /// Less than operator
- {
- if (isEmpty()) return false;
- return convert<T>() < other;
- }
-
- bool operator < (const Var& other) const;
- /// Less than operator overload for Var
-
+ T add(const Var& other) const
+ {
+ return convert<T>() + other.convert<T>();
+ }
+
template <typename T>
- bool operator <= (const T& other) const
- /// Less than or equal operator
- {
- if (isEmpty()) return false;
- return convert<T>() <= other;
- }
-
- bool operator <= (const Var& other) const;
- /// Less than or equal operator overload for Var
-
+ T subtract(const Var& other) const
+ {
+ return convert<T>() - other.convert<T>();
+ }
+
template <typename T>
- bool operator > (const T& other) const
- /// Greater than operator
- {
- if (isEmpty()) return false;
- return convert<T>() > other;
- }
-
- bool operator > (const Var& other) const;
- /// Greater than operator overload for Var
-
+ T multiply(const Var& other) const
+ {
+ return convert<T>() * other.convert<T>();
+ }
+
template <typename T>
- bool operator >= (const T& other) const
- /// Greater than or equal operator
- {
- if (isEmpty()) return false;
- return convert<T>() >= other;
- }
-
- bool operator >= (const Var& other) const;
- /// Greater than or equal operator overload for Var
-
- template <typename T>
- bool operator || (const T& other) const
- /// Logical OR operator
- {
- if (isEmpty()) return false;
- return convert<bool>() || other;
- }
-
- bool operator || (const Var& other) const;
- /// Logical OR operator operator overload for Var
-
- template <typename T>
- bool operator && (const T& other) const
- /// Logical AND operator.
- {
- if (isEmpty()) return false;
- return convert<bool>() && 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 <typename T>
- Var& operator [] (const T& n)
- {
- return getAt(n);
- }
-
- template <typename T>
- const Var& operator [] (const T& n) const
- {
- return const_cast<Var*>(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<std::string>();
- 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<std::string>() 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 <typename T>
- T add(const Var& other) const
- {
- return convert<T>() + other.convert<T>();
- }
-
- template <typename T>
- T subtract(const Var& other) const
- {
- return convert<T>() - other.convert<T>();
- }
-
- template <typename T>
- T multiply(const Var& other) const
- {
- return convert<T>() * other.convert<T>();
- }
-
- template <typename T>
- T divide(const Var& other) const
- {
- return convert<T>() / other.convert<T>();
- }
-
- template <typename T, typename E>
- VarHolderImpl<T>* holderImpl(const std::string errorMessage = "") const
- {
- VarHolder* pHolder = content();
-
- if (pHolder && pHolder->type() == typeid(T))
- return static_cast<VarHolderImpl<T>*>(pHolder);
- else if (!pHolder)
- throw InvalidAccessException("Can not access empty value.");
- else
- throw E(errorMessage);
- }
-
- Var& structIndexOperator(VarHolderImpl<Struct<int> >* 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<typename ValueType>
- void construct(const ValueType& value)
- {
- if (sizeof(VarHolderImpl<ValueType>) <= Placeholder<ValueType>::Size::value)
- {
- new (reinterpret_cast<VarHolder*>(_placeholder.holder)) VarHolderImpl<ValueType>(value);
- _placeholder.setLocal(true);
- }
- else
- {
- _placeholder.pHolder = new VarHolderImpl<ValueType>(value);
- _placeholder.setLocal(false);
- }
- }
-
- void construct(const char* value)
- {
- std::string val(value);
- if (sizeof(VarHolderImpl<std::string>) <= Placeholder<std::string>::Size::value)
- {
- new (reinterpret_cast<VarHolder*>(_placeholder.holder)) VarHolderImpl<std::string>(val);
- _placeholder.setLocal(true);
- }
- else
- {
- _placeholder.pHolder = new VarHolderImpl<std::string>(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<VarHolder> _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<Var*>(this), true);
-
- return ConstIterator(const_cast<Var*>(this), false);
-}
-
-inline Var::ConstIterator Var::end() const
-{
- return ConstIterator(const_cast<Var*>(this), true);
-}
-
-inline Var::Iterator Var::begin()
-{
- if (isEmpty()) return Iterator(const_cast<Var*>(this), true);
-
- return Iterator(const_cast<Var*>(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<Var*>(this)->getAt(name);
-}
-
-
-inline const Var Var::operator + (const char* other) const
-{
- return convert<std::string>() + other;
-}
-
-
-inline Var& Var::operator += (const char*other)
-{
- return *this = convert<std::string>() + other;
-}
-
-
-inline bool Var::operator ! () const
-{
- return !convert<bool>();
-}
-
-
-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<std::string>();
-}
-
-
-inline char operator + (const char& other, const Var& da)
- /// Addition operator for adding Var to char
-{
- return other + da.convert<char>();
-}
-
-
-inline char operator - (const char& other, const Var& da)
- /// Subtraction operator for subtracting Var from char
-{
- return other - da.convert<char>();
-}
-
-
-inline char operator * (const char& other, const Var& da)
- /// Multiplication operator for multiplying Var with char
-{
- return other * da.convert<char>();
-}
-
-
-inline char operator / (const char& other, const Var& da)
- /// Division operator for dividing Var with char
-{
- return other / da.convert<char>();
-}
-
-
-inline char operator += (char& other, const Var& da)
- /// Addition assignment operator for adding Var to char
-{
- return other += da.convert<char>();
-}
-
-
-inline char operator -= (char& other, const Var& da)
- /// Subtraction assignment operator for subtracting Var from char
-{
- return other -= da.convert<char>();
-}
-
-
-inline char operator *= (char& other, const Var& da)
- /// Multiplication assignment operator for multiplying Var with char
-{
- return other *= da.convert<char>();
-}
-
-
-inline char operator /= (char& other, const Var& da)
- /// Division assignment operator for dividing Var with char
-{
- return other /= da.convert<char>();
-}
-
-
-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<char>();
-}
-
-
-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<char>();
-}
-
-
-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<char>();
-}
-
-
-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<char>();
-}
-
-
-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<char>();
-}
-
-
-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<char>();
-}
-
-
-inline Poco::Int8 operator + (const Poco::Int8& other, const Var& da)
- /// Addition operator for adding Var to Poco::Int8
-{
- return other + da.convert<Poco::Int8>();
-}
-
-
-inline Poco::Int8 operator - (const Poco::Int8& other, const Var& da)
- /// Subtraction operator for subtracting Var from Poco::Int8
-{
- return other - da.convert<Poco::Int8>();
-}
-
-
-inline Poco::Int8 operator * (const Poco::Int8& other, const Var& da)
- /// Multiplication operator for multiplying Var with Poco::Int8
-{
- return other * da.convert<Poco::Int8>();
-}
-
-
-inline Poco::Int8 operator / (const Poco::Int8& other, const Var& da)
- /// Division operator for dividing Var with Poco::Int8
-{
- return other / da.convert<Poco::Int8>();
-}
-
-
-inline Poco::Int8 operator += (Poco::Int8& other, const Var& da)
- /// Addition assignment operator for adding Var to Poco::Int8
-{
- return other += da.convert<Poco::Int8>();
-}
-
-
-inline Poco::Int8 operator -= (Poco::Int8& other, const Var& da)
- /// Subtraction assignment operator for subtracting Var from Poco::Int8
-{
- return other -= da.convert<Poco::Int8>();
-}
-
-
-inline Poco::Int8 operator *= (Poco::Int8& other, const Var& da)
- /// Multiplication assignment operator for multiplying Var with Poco::Int8
-{
- return other *= da.convert<Poco::Int8>();
-}
-
-
-inline Poco::Int8 operator /= (Poco::Int8& other, const Var& da)
- /// Division assignment operator for dividing Var with Poco::Int8
-{
- return other /= da.convert<Poco::Int8>();
-}
-
-
-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<Poco::Int8>();
-}
-
-
-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<Poco::Int8>();
-}
-
-
-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<Poco::Int8>();
-}
-
-
-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<Poco::Int8>();
-}
-
-
-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<Poco::Int8>();
-}
-
-
-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<Poco::Int8>();
-}
-
-
-inline Poco::UInt8 operator + (const Poco::UInt8& other, const Var& da)
- /// Addition operator for adding Var to Poco::UInt8
-{
- return other + da.convert<Poco::UInt8>();
-}
-
-
-inline Poco::UInt8 operator - (const Poco::UInt8& other, const Var& da)
- /// Subtraction operator for subtracting Var from Poco::UInt8
-{
- return other - da.convert<Poco::UInt8>();
-}
-
-
-inline Poco::UInt8 operator * (const Poco::UInt8& other, const Var& da)
- /// Multiplication operator for multiplying Var with Poco::UInt8
-{
- return other * da.convert<Poco::UInt8>();
-}
-
-
-inline Poco::UInt8 operator / (const Poco::UInt8& other, const Var& da)
- /// Division operator for dividing Var with Poco::UInt8
-{
- return other / da.convert<Poco::UInt8>();
-}
-
-
-inline Poco::UInt8 operator += (Poco::UInt8& other, const Var& da)
- /// Addition assignment operator for adding Var to Poco::UInt8
-{
- return other += da.convert<Poco::UInt8>();
-}
-
-
-inline Poco::UInt8 operator -= (Poco::UInt8& other, const Var& da)
- /// Subtraction assignment operator for subtracting Var from Poco::UInt8
-{
- return other -= da.convert<Poco::UInt8>();
-}
-
-
-inline Poco::UInt8 operator *= (Poco::UInt8& other, const Var& da)
- /// Multiplication assignment operator for multiplying Var with Poco::UInt8
-{
- return other *= da.convert<Poco::UInt8>();
-}
-
-
-inline Poco::UInt8 operator /= (Poco::UInt8& other, const Var& da)
- /// Division assignment operator for dividing Var with Poco::UInt8
-{
- return other /= da.convert<Poco::UInt8>();
-}
-
-
-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<Poco::UInt8>();
-}
-
-
-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<Poco::UInt8>();
-}
-
-
-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<Poco::UInt8>();
-}
-
-
-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<Poco::UInt8>();
-}
-
-
-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<Poco::UInt8>();
-}
-
-
-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<Poco::UInt8>();
-}
-
-
-inline Poco::Int16 operator + (const Poco::Int16& other, const Var& da)
- /// Addition operator for adding Var to Poco::Int16
-{
- return other + da.convert<Poco::Int16>();
-}
-
-
-inline Poco::Int16 operator - (const Poco::Int16& other, const Var& da)
- /// Subtraction operator for subtracting Var from Poco::Int16
-{
- return other - da.convert<Poco::Int16>();
-}
-
-
-inline Poco::Int16 operator * (const Poco::Int16& other, const Var& da)
- /// Multiplication operator for multiplying Var with Poco::Int16
-{
- return other * da.convert<Poco::Int16>();
-}
-
-
-inline Poco::Int16 operator / (const Poco::Int16& other, const Var& da)
- /// Division operator for dividing Var with Poco::Int16
-{
- return other / da.convert<Poco::Int16>();
-}
-
-
-inline Poco::Int16 operator += (Poco::Int16& other, const Var& da)
- /// Addition assignment operator for adding Var to Poco::Int16
-{
- return other += da.convert<Poco::Int16>();
-}
-
-
-inline Poco::Int16 operator -= (Poco::Int16& other, const Var& da)
- /// Subtraction assignment operator for subtracting Var from Poco::Int16
-{
- return other -= da.convert<Poco::Int16>();
-}
-
-
-inline Poco::Int16 operator *= (Poco::Int16& other, const Var& da)
- /// Multiplication assignment operator for multiplying Var with Poco::Int16
-{
- return other *= da.convert<Poco::Int16>();
-}
-
-
-inline Poco::Int16 operator /= (Poco::Int16& other, const Var& da)
- /// Division assignment operator for dividing Var with Poco::Int16
-{
- return other /= da.convert<Poco::Int16>();
-}
-
-
-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<Poco::Int16>();
-}
-
-
-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<Poco::Int16>();
-}
-
-
-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<Poco::Int16>();
-}
-
-
-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<Poco::Int16>();
-}
-
-
-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<Poco::Int16>();
-}
-
-
-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<Poco::Int16>();
-}
-
-
-inline Poco::UInt16 operator + (const Poco::UInt16& other, const Var& da)
- /// Addition operator for adding Var to Poco::UInt16
-{
- return other + da.convert<Poco::UInt16>();
-}
-
-
-inline Poco::UInt16 operator - (const Poco::UInt16& other, const Var& da)
- /// Subtraction operator for subtracting Var from Poco::UInt16
-{
- return other - da.convert<Poco::UInt16>();
-}
-
-
-inline Poco::UInt16 operator * (const Poco::UInt16& other, const Var& da)
- /// Multiplication operator for multiplying Var with Poco::UInt16
-{
- return other * da.convert<Poco::UInt16>();
-}
-
-
-inline Poco::UInt16 operator / (const Poco::UInt16& other, const Var& da)
- /// Division operator for dividing Var with Poco::UInt16
-{
- return other / da.convert<Poco::UInt16>();
-}
-
-
-inline Poco::UInt16 operator += (Poco::UInt16& other, const Var& da)
- /// Addition assignment operator for adding Var to Poco::UInt16
-{
- return other += da.convert<Poco::UInt16>();
-}
-
-
-inline Poco::UInt16 operator -= (Poco::UInt16& other, const Var& da)
- /// Subtraction assignment operator for subtracting Var from Poco::UInt16
-{
- return other -= da.convert<Poco::UInt16>();
-}
-
-
-inline Poco::UInt16 operator *= (Poco::UInt16& other, const Var& da)
- /// Multiplication assignment operator for multiplying Var with Poco::UInt16
-{
- return other *= da.convert<Poco::UInt16>();
-}
-
-
-inline Poco::UInt16 operator /= (Poco::UInt16& other, const Var& da)
- /// Division assignment operator for dividing Var with Poco::UInt16
-{
- return other /= da.convert<Poco::UInt16>();
-}
-
-
-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<Poco::UInt16>();
-}
-
-
-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<Poco::UInt16>();
-}
-
-
-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<Poco::UInt16>();
-}
-
-
-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<Poco::UInt16>();
-}
-
-
-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<Poco::UInt16>();
-}
-
-
-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<Poco::UInt16>();
-}
-
-
-inline Poco::Int32 operator + (const Poco::Int32& other, const Var& da)
- /// Addition operator for adding Var to Poco::Int32
-{
- return other + da.convert<Poco::Int32>();
-}
-
-
-inline Poco::Int32 operator - (const Poco::Int32& other, const Var& da)
- /// Subtraction operator for subtracting Var from Poco::Int32
-{
- return other - da.convert<Poco::Int32>();
-}
-
-
-inline Poco::Int32 operator * (const Poco::Int32& other, const Var& da)
- /// Multiplication operator for multiplying Var with Poco::Int32
-{
- return other * da.convert<Poco::Int32>();
-}
-
-
-inline Poco::Int32 operator / (const Poco::Int32& other, const Var& da)
- /// Division operator for dividing Var with Poco::Int32
-{
- return other / da.convert<Poco::Int32>();
-}
-
-
-inline Poco::Int32 operator += (Poco::Int32& other, const Var& da)
- /// Addition assignment operator for adding Var to Poco::Int32
-{
- return other += da.convert<Poco::Int32>();
-}
-
-
-inline Poco::Int32 operator -= (Poco::Int32& other, const Var& da)
- /// Subtraction assignment operator for subtracting Var from Poco::Int32
-{
- return other -= da.convert<Poco::Int32>();
-}
-
-
-inline Poco::Int32 operator *= (Poco::Int32& other, const Var& da)
- /// Multiplication assignment operator for multiplying Var with Poco::Int32
-{
- return other *= da.convert<Poco::Int32>();
-}
-
-
-inline Poco::Int32 operator /= (Poco::Int32& other, const Var& da)
- /// Division assignment operator for dividing Var with Poco::Int32
-{
- return other /= da.convert<Poco::Int32>();
-}
-
-
-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<Poco::Int32>();
-}
-
-
-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<Poco::Int32>();
-}
-
-
-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<Poco::Int32>();
-}
-
-
-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<Poco::Int32>();
-}
-
-
-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<Poco::Int32>();
-}
-
-
-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<Poco::Int32>();
-}
-
-
-inline Poco::UInt32 operator + (const Poco::UInt32& other, const Var& da)
- /// Addition operator for adding Var to Poco::UInt32
-{
- return other + da.convert<Poco::UInt32>();
-}
-
-
-inline Poco::UInt32 operator - (const Poco::UInt32& other, const Var& da)
- /// Subtraction operator for subtracting Var from Poco::UInt32
-{
- return other - da.convert<Poco::UInt32>();
-}
-
-
-inline Poco::UInt32 operator * (const Poco::UInt32& other, const Var& da)
- /// Multiplication operator for multiplying Var with Poco::UInt32
-{
- return other * da.convert<Poco::UInt32>();
-}
-
-
-inline Poco::UInt32 operator / (const Poco::UInt32& other, const Var& da)
- /// Division operator for dividing Var with Poco::UInt32
-{
- return other / da.convert<Poco::UInt32>();
-}
-
-
-inline Poco::UInt32 operator += (Poco::UInt32& other, const Var& da)
- /// Addition assignment operator for adding Var to Poco::UInt32
-{
- return other += da.convert<Poco::UInt32>();
-}
-
-
-inline Poco::UInt32 operator -= (Poco::UInt32& other, const Var& da)
- /// Subtraction assignment operator for subtracting Var from Poco::UInt32
-{
- return other -= da.convert<Poco::UInt32>();
-}
-
-
-inline Poco::UInt32 operator *= (Poco::UInt32& other, const Var& da)
- /// Multiplication assignment operator for multiplying Var with Poco::UInt32
-{
- return other *= da.convert<Poco::UInt32>();
-}
-
-
-inline Poco::UInt32 operator /= (Poco::UInt32& other, const Var& da)
- /// Division assignment operator for dividing Var with Poco::UInt32
-{
- return other /= da.convert<Poco::UInt32>();
-}
-
-
-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<Poco::UInt32>();
-}
-
-
-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<Poco::UInt32>();
-}
-
-
-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<Poco::UInt32>();
-}
-
-
-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<Poco::UInt32>();
-}
-
-
-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<Poco::UInt32>();
-}
-
-
-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<Poco::UInt32>();
-}
-
-
-inline Poco::Int64 operator + (const Poco::Int64& other, const Var& da)
- /// Addition operator for adding Var to Poco::Int64
-{
- return other + da.convert<Poco::Int64>();
-}
-
-
-inline Poco::Int64 operator - (const Poco::Int64& other, const Var& da)
- /// Subtraction operator for subtracting Var from Poco::Int64
-{
- return other - da.convert<Poco::Int64>();
-}
-
-
-inline Poco::Int64 operator * (const Poco::Int64& other, const Var& da)
- /// Multiplication operator for multiplying Var with Poco::Int64
-{
- return other * da.convert<Poco::Int64>();
-}
-
-
-inline Poco::Int64 operator / (const Poco::Int64& other, const Var& da)
- /// Division operator for dividing Var with Poco::Int64
-{
- return other / da.convert<Poco::Int64>();
-}
-
-
-inline Poco::Int64 operator += (Poco::Int64& other, const Var& da)
- /// Addition assignment operator for adding Var to Poco::Int64
-{
- return other += da.convert<Poco::Int64>();
-}
-
-
-inline Poco::Int64 operator -= (Poco::Int64& other, const Var& da)
- /// Subtraction assignment operator for subtracting Var from Poco::Int64
-{
- return other -= da.convert<Poco::Int64>();
-}
-
-
-inline Poco::Int64 operator *= (Poco::Int64& other, const Var& da)
- /// Multiplication assignment operator for multiplying Var with Poco::Int64
-{
- return other *= da.convert<Poco::Int64>();
-}
-
-
-inline Poco::Int64 operator /= (Poco::Int64& other, const Var& da)
- /// Division assignment operator for dividing Var with Poco::Int64
-{
- return other /= da.convert<Poco::Int64>();
-}
-
-
-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<Poco::Int64>();
-}
-
-
-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<Poco::Int64>();
-}
-
-
-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<Poco::Int64>();
-}
-
-
-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<Poco::Int64>();
-}
-
-
-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<Poco::Int64>();
-}
-
-
-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<Poco::Int64>();
-}
-
-
-inline Poco::UInt64 operator + (const Poco::UInt64& other, const Var& da)
- /// Addition operator for adding Var to Poco::UInt64
-{
- return other + da.convert<Poco::UInt64>();
-}
-
-
-inline Poco::UInt64 operator - (const Poco::UInt64& other, const Var& da)
- /// Subtraction operator for subtracting Var from Poco::UInt64
-{
- return other - da.convert<Poco::UInt64>();
-}
-
-
-inline Poco::UInt64 operator * (const Poco::UInt64& other, const Var& da)
- /// Multiplication operator for multiplying Var with Poco::UInt64
-{
- return other * da.convert<Poco::UInt64>();
-}
-
-
-inline Poco::UInt64 operator / (const Poco::UInt64& other, const Var& da)
- /// Division operator for dividing Var with Poco::UInt64
-{
- return other / da.convert<Poco::UInt64>();
-}
-
-
-inline Poco::UInt64 operator += (Poco::UInt64& other, const Var& da)
- /// Addition assignment operator for adding Var to Poco::UInt64
-{
- return other += da.convert<Poco::UInt64>();
-}
-
-
-inline Poco::UInt64 operator -= (Poco::UInt64& other, const Var& da)
- /// Subtraction assignment operator for subtracting Var from Poco::UInt64
-{
- return other -= da.convert<Poco::UInt64>();
-}
-
-
-inline Poco::UInt64 operator *= (Poco::UInt64& other, const Var& da)
- /// Multiplication assignment operator for multiplying Var with Poco::UInt64
-{
- return other *= da.convert<Poco::UInt64>();
-}
-
-
-inline Poco::UInt64 operator /= (Poco::UInt64& other, const Var& da)
- /// Division assignment operator for dividing Var with Poco::UInt64
-{
- return other /= da.convert<Poco::UInt64>();
-}
-
-
-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<Poco::UInt64>();
-}
-
-
-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<Poco::UInt64>();
-}
-
-
-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<Poco::UInt64>();
-}
-
-
-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<Poco::UInt64>();
-}
-
-
-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<Poco::UInt64>();
-}
-
-
-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<Poco::UInt64>();
-}
-
-
-inline float operator + (const float& other, const Var& da)
- /// Addition operator for adding Var to float
-{
- return other + da.convert<float>();
-}
-
-
-inline float operator - (const float& other, const Var& da)
- /// Subtraction operator for subtracting Var from float
-{
- return other - da.convert<float>();
-}
-
-
-inline float operator * (const float& other, const Var& da)
- /// Multiplication operator for multiplying Var with float
-{
- return other * da.convert<float>();
-}
-
-
-inline float operator / (const float& other, const Var& da)
- /// Division operator for dividing Var with float
-{
- return other / da.convert<float>();
-}
-
-
-inline float operator += (float& other, const Var& da)
- /// Addition assignment operator for adding Var to float
-{
- return other += da.convert<float>();
-}
-
-
-inline float operator -= (float& other, const Var& da)
- /// Subtraction assignment operator for subtracting Var from float
-{
- return other -= da.convert<float>();
-}
-
-
-inline float operator *= (float& other, const Var& da)
- /// Multiplication assignment operator for multiplying Var with float
-{
- return other *= da.convert<float>();
-}
-
-
-inline float operator /= (float& other, const Var& da)
- /// Division assignment operator for dividing Var with float
-{
- return other /= da.convert<float>();
-}
-
-
-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<float>();
-}
-
-
-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<float>();
-}
-
-
-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<float>();
-}
-
-
-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<float>();
-}
-
-
-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<float>();
-}
-
-
-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<float>();
-}
-
-
-inline double operator + (const double& other, const Var& da)
- /// Addition operator for adding Var to double
-{
- return other + da.convert<double>();
-}
-
-
-inline double operator - (const double& other, const Var& da)
- /// Subtraction operator for subtracting Var from double
-{
- return other - da.convert<double>();
-}
-
-
-inline double operator * (const double& other, const Var& da)
- /// Multiplication operator for multiplying Var with double
-{
- return other * da.convert<double>();
-}
-
-
-inline double operator / (const double& other, const Var& da)
- /// Division operator for dividing Var with double
-{
- return other / da.convert<double>();
-}
-
-
-inline double operator += (double& other, const Var& da)
- /// Addition assignment operator for adding Var to double
-{
- return other += da.convert<double>();
-}
-
-
-inline double operator -= (double& other, const Var& da)
- /// Subtraction assignment operator for subtracting Var from double
-{
- return other -= da.convert<double>();
-}
-
-
-inline double operator *= (double& other, const Var& da)
- /// Multiplication assignment operator for multiplying Var with double
-{
- return other *= da.convert<double>();
-}
-
-
-inline double operator /= (double& other, const Var& da)
- /// Division assignment operator for dividing Var with double
-{
- return other /= da.convert<double>();
-}
-
-
-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<double>();
-}
-
-
-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<double>();
-}
-
-
-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<double>();
-}
-
-
-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<double>();
-}
-
-
-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<double>();
-}
-
-
-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<double>();
-}
-
-
-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<bool>();
-}
-
-
-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<bool>();
-}
-
-
-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<std::string>();
-}
-
-
-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<std::string>();
-}
-
-
-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<UTF16String>();
-}
-
-
-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<UTF16String>();
-}
-
-
-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<std::string>() == 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<std::string>() != 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<long>();
-}
-
-
-inline long operator - (const long& other, const Var& da)
- /// Subtraction operator for subtracting Var from long
-{
- return other - da.convert<long>();
-}
-
-
-inline long operator * (const long& other, const Var& da)
- /// Multiplication operator for multiplying Var with long
-{
- return other * da.convert<long>();
-}
-
-
-inline long operator / (const long& other, const Var& da)
- /// Division operator for dividing Var with long
-{
- return other / da.convert<long>();
-}
-
-
-inline long operator += (long& other, const Var& da)
- /// Addition assignment operator for adding Var to long
-{
- return other += da.convert<long>();
-}
-
-
-inline long operator -= (long& other, const Var& da)
- /// Subtraction assignment operator for subtracting Var from long
-{
- return other -= da.convert<long>();
-}
-
-
-inline long operator *= (long& other, const Var& da)
- /// Multiplication assignment operator for multiplying Var with long
-{
- return other *= da.convert<long>();
-}
-
-
-inline long operator /= (long& other, const Var& da)
- /// Division assignment operator for dividing Var with long
-{
- return other /= da.convert<long>();
-}
-
-
-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<long>();
-}
-
-
-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<long>();
-}
-
-
-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<long>();
-}
-
-
-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<long>();
-}
-
-
-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<long>();
-}
-
-
-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<long>();
-}
-
-
-#endif // POCO_LONG_IS_64_BIT
-
-
-} // namespace Dynamic
-
-
-//@ deprecated
-typedef Dynamic::Var DynamicAny;
-
-
-} // namespace Poco
-
-
-#endif // Foundation_Var_INCLUDED
+ T divide(const Var& other) const
+ {
+ return convert<T>() / other.convert<T>();
+ }
+
+ template <typename T, typename E>
+ VarHolderImpl<T>* holderImpl(const std::string errorMessage = "") const
+ {
+ VarHolder* pHolder = content();
+
+ if (pHolder && pHolder->type() == typeid(T))
+ return static_cast<VarHolderImpl<T>*>(pHolder);
+ else if (!pHolder)
+ throw InvalidAccessException("Can not access empty value.");
+ else
+ throw E(errorMessage);
+ }
+
+ Var& structIndexOperator(VarHolderImpl<Struct<int> >* 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<typename ValueType>
+ void construct(const ValueType& value)
+ {
+ if (sizeof(VarHolderImpl<ValueType>) <= Placeholder<ValueType>::Size::value)
+ {
+ new (reinterpret_cast<VarHolder*>(_placeholder.holder)) VarHolderImpl<ValueType>(value);
+ _placeholder.setLocal(true);
+ }
+ else
+ {
+ _placeholder.pHolder = new VarHolderImpl<ValueType>(value);
+ _placeholder.setLocal(false);
+ }
+ }
+
+ void construct(const char* value)
+ {
+ std::string val(value);
+ if (sizeof(VarHolderImpl<std::string>) <= Placeholder<std::string>::Size::value)
+ {
+ new (reinterpret_cast<VarHolder*>(_placeholder.holder)) VarHolderImpl<std::string>(val);
+ _placeholder.setLocal(true);
+ }
+ else
+ {
+ _placeholder.pHolder = new VarHolderImpl<std::string>(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<VarHolder> _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<Var*>(this), true);
+
+ return ConstIterator(const_cast<Var*>(this), false);
+}
+
+inline Var::ConstIterator Var::end() const
+{
+ return ConstIterator(const_cast<Var*>(this), true);
+}
+
+inline Var::Iterator Var::begin()
+{
+ if (isEmpty()) return Iterator(const_cast<Var*>(this), true);
+
+ return Iterator(const_cast<Var*>(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<Var*>(this)->getAt(name);
+}
+
+
+inline const Var Var::operator + (const char* other) const
+{
+ return convert<std::string>() + other;
+}
+
+
+inline Var& Var::operator += (const char*other)
+{
+ return *this = convert<std::string>() + other;
+}
+
+
+inline bool Var::operator ! () const
+{
+ return !convert<bool>();
+}
+
+
+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<std::string>();
+}
+
+
+inline char operator + (const char& other, const Var& da)
+ /// Addition operator for adding Var to char
+{
+ return other + da.convert<char>();
+}
+
+
+inline char operator - (const char& other, const Var& da)
+ /// Subtraction operator for subtracting Var from char
+{
+ return other - da.convert<char>();
+}
+
+
+inline char operator * (const char& other, const Var& da)
+ /// Multiplication operator for multiplying Var with char
+{
+ return other * da.convert<char>();
+}
+
+
+inline char operator / (const char& other, const Var& da)
+ /// Division operator for dividing Var with char
+{
+ return other / da.convert<char>();
+}
+
+
+inline char operator += (char& other, const Var& da)
+ /// Addition assignment operator for adding Var to char
+{
+ return other += da.convert<char>();
+}
+
+
+inline char operator -= (char& other, const Var& da)
+ /// Subtraction assignment operator for subtracting Var from char
+{
+ return other -= da.convert<char>();
+}
+
+
+inline char operator *= (char& other, const Var& da)
+ /// Multiplication assignment operator for multiplying Var with char
+{
+ return other *= da.convert<char>();
+}
+
+
+inline char operator /= (char& other, const Var& da)
+ /// Division assignment operator for dividing Var with char
+{
+ return other /= da.convert<char>();
+}
+
+
+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<char>();
+}
+
+
+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<char>();
+}
+
+
+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<char>();
+}
+
+
+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<char>();
+}
+
+
+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<char>();
+}
+
+
+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<char>();
+}
+
+
+inline Poco::Int8 operator + (const Poco::Int8& other, const Var& da)
+ /// Addition operator for adding Var to Poco::Int8
+{
+ return other + da.convert<Poco::Int8>();
+}
+
+
+inline Poco::Int8 operator - (const Poco::Int8& other, const Var& da)
+ /// Subtraction operator for subtracting Var from Poco::Int8
+{
+ return other - da.convert<Poco::Int8>();
+}
+
+
+inline Poco::Int8 operator * (const Poco::Int8& other, const Var& da)
+ /// Multiplication operator for multiplying Var with Poco::Int8
+{
+ return other * da.convert<Poco::Int8>();
+}
+
+
+inline Poco::Int8 operator / (const Poco::Int8& other, const Var& da)
+ /// Division operator for dividing Var with Poco::Int8
+{
+ return other / da.convert<Poco::Int8>();
+}
+
+
+inline Poco::Int8 operator += (Poco::Int8& other, const Var& da)
+ /// Addition assignment operator for adding Var to Poco::Int8
+{
+ return other += da.convert<Poco::Int8>();
+}
+
+
+inline Poco::Int8 operator -= (Poco::Int8& other, const Var& da)
+ /// Subtraction assignment operator for subtracting Var from Poco::Int8
+{
+ return other -= da.convert<Poco::Int8>();
+}
+
+
+inline Poco::Int8 operator *= (Poco::Int8& other, const Var& da)
+ /// Multiplication assignment operator for multiplying Var with Poco::Int8
+{
+ return other *= da.convert<Poco::Int8>();
+}
+
+
+inline Poco::Int8 operator /= (Poco::Int8& other, const Var& da)
+ /// Division assignment operator for dividing Var with Poco::Int8
+{
+ return other /= da.convert<Poco::Int8>();
+}
+
+
+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<Poco::Int8>();
+}
+
+
+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<Poco::Int8>();
+}
+
+
+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<Poco::Int8>();
+}
+
+
+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<Poco::Int8>();
+}
+
+
+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<Poco::Int8>();
+}
+
+
+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<Poco::Int8>();
+}
+
+
+inline Poco::UInt8 operator + (const Poco::UInt8& other, const Var& da)
+ /// Addition operator for adding Var to Poco::UInt8
+{
+ return other + da.convert<Poco::UInt8>();
+}
+
+
+inline Poco::UInt8 operator - (const Poco::UInt8& other, const Var& da)
+ /// Subtraction operator for subtracting Var from Poco::UInt8
+{
+ return other - da.convert<Poco::UInt8>();
+}
+
+
+inline Poco::UInt8 operator * (const Poco::UInt8& other, const Var& da)
+ /// Multiplication operator for multiplying Var with Poco::UInt8
+{
+ return other * da.convert<Poco::UInt8>();
+}
+
+
+inline Poco::UInt8 operator / (const Poco::UInt8& other, const Var& da)
+ /// Division operator for dividing Var with Poco::UInt8
+{
+ return other / da.convert<Poco::UInt8>();
+}
+
+
+inline Poco::UInt8 operator += (Poco::UInt8& other, const Var& da)
+ /// Addition assignment operator for adding Var to Poco::UInt8
+{
+ return other += da.convert<Poco::UInt8>();
+}
+
+
+inline Poco::UInt8 operator -= (Poco::UInt8& other, const Var& da)
+ /// Subtraction assignment operator for subtracting Var from Poco::UInt8
+{
+ return other -= da.convert<Poco::UInt8>();
+}
+
+
+inline Poco::UInt8 operator *= (Poco::UInt8& other, const Var& da)
+ /// Multiplication assignment operator for multiplying Var with Poco::UInt8
+{
+ return other *= da.convert<Poco::UInt8>();
+}
+
+
+inline Poco::UInt8 operator /= (Poco::UInt8& other, const Var& da)
+ /// Division assignment operator for dividing Var with Poco::UInt8
+{
+ return other /= da.convert<Poco::UInt8>();
+}
+
+
+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<Poco::UInt8>();
+}
+
+
+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<Poco::UInt8>();
+}
+
+
+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<Poco::UInt8>();
+}
+
+
+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<Poco::UInt8>();
+}
+
+
+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<Poco::UInt8>();
+}
+
+
+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<Poco::UInt8>();
+}
+
+
+inline Poco::Int16 operator + (const Poco::Int16& other, const Var& da)
+ /// Addition operator for adding Var to Poco::Int16
+{
+ return other + da.convert<Poco::Int16>();
+}
+
+
+inline Poco::Int16 operator - (const Poco::Int16& other, const Var& da)
+ /// Subtraction operator for subtracting Var from Poco::Int16
+{
+ return other - da.convert<Poco::Int16>();
+}
+
+
+inline Poco::Int16 operator * (const Poco::Int16& other, const Var& da)
+ /// Multiplication operator for multiplying Var with Poco::Int16
+{
+ return other * da.convert<Poco::Int16>();
+}
+
+
+inline Poco::Int16 operator / (const Poco::Int16& other, const Var& da)
+ /// Division operator for dividing Var with Poco::Int16
+{
+ return other / da.convert<Poco::Int16>();
+}
+
+
+inline Poco::Int16 operator += (Poco::Int16& other, const Var& da)
+ /// Addition assignment operator for adding Var to Poco::Int16
+{
+ return other += da.convert<Poco::Int16>();
+}
+
+
+inline Poco::Int16 operator -= (Poco::Int16& other, const Var& da)
+ /// Subtraction assignment operator for subtracting Var from Poco::Int16
+{
+ return other -= da.convert<Poco::Int16>();
+}
+
+
+inline Poco::Int16 operator *= (Poco::Int16& other, const Var& da)
+ /// Multiplication assignment operator for multiplying Var with Poco::Int16
+{
+ return other *= da.convert<Poco::Int16>();
+}
+
+
+inline Poco::Int16 operator /= (Poco::Int16& other, const Var& da)
+ /// Division assignment operator for dividing Var with Poco::Int16
+{
+ return other /= da.convert<Poco::Int16>();
+}
+
+
+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<Poco::Int16>();
+}
+
+
+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<Poco::Int16>();
+}
+
+
+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<Poco::Int16>();
+}
+
+
+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<Poco::Int16>();
+}
+
+
+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<Poco::Int16>();
+}
+
+
+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<Poco::Int16>();
+}
+
+
+inline Poco::UInt16 operator + (const Poco::UInt16& other, const Var& da)
+ /// Addition operator for adding Var to Poco::UInt16
+{
+ return other + da.convert<Poco::UInt16>();
+}
+
+
+inline Poco::UInt16 operator - (const Poco::UInt16& other, const Var& da)
+ /// Subtraction operator for subtracting Var from Poco::UInt16
+{
+ return other - da.convert<Poco::UInt16>();
+}
+
+
+inline Poco::UInt16 operator * (const Poco::UInt16& other, const Var& da)
+ /// Multiplication operator for multiplying Var with Poco::UInt16
+{
+ return other * da.convert<Poco::UInt16>();
+}
+
+
+inline Poco::UInt16 operator / (const Poco::UInt16& other, const Var& da)
+ /// Division operator for dividing Var with Poco::UInt16
+{
+ return other / da.convert<Poco::UInt16>();
+}
+
+
+inline Poco::UInt16 operator += (Poco::UInt16& other, const Var& da)
+ /// Addition assignment operator for adding Var to Poco::UInt16
+{
+ return other += da.convert<Poco::UInt16>();
+}
+
+
+inline Poco::UInt16 operator -= (Poco::UInt16& other, const Var& da)
+ /// Subtraction assignment operator for subtracting Var from Poco::UInt16
+{
+ return other -= da.convert<Poco::UInt16>();
+}
+
+
+inline Poco::UInt16 operator *= (Poco::UInt16& other, const Var& da)
+ /// Multiplication assignment operator for multiplying Var with Poco::UInt16
+{
+ return other *= da.convert<Poco::UInt16>();
+}
+
+
+inline Poco::UInt16 operator /= (Poco::UInt16& other, const Var& da)
+ /// Division assignment operator for dividing Var with Poco::UInt16
+{
+ return other /= da.convert<Poco::UInt16>();
+}
+
+
+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<Poco::UInt16>();
+}
+
+
+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<Poco::UInt16>();
+}
+
+
+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<Poco::UInt16>();
+}
+
+
+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<Poco::UInt16>();
+}
+
+
+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<Poco::UInt16>();
+}
+
+
+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<Poco::UInt16>();
+}
+
+
+inline Poco::Int32 operator + (const Poco::Int32& other, const Var& da)
+ /// Addition operator for adding Var to Poco::Int32
+{
+ return other + da.convert<Poco::Int32>();
+}
+
+
+inline Poco::Int32 operator - (const Poco::Int32& other, const Var& da)
+ /// Subtraction operator for subtracting Var from Poco::Int32
+{
+ return other - da.convert<Poco::Int32>();
+}
+
+
+inline Poco::Int32 operator * (const Poco::Int32& other, const Var& da)
+ /// Multiplication operator for multiplying Var with Poco::Int32
+{
+ return other * da.convert<Poco::Int32>();
+}
+
+
+inline Poco::Int32 operator / (const Poco::Int32& other, const Var& da)
+ /// Division operator for dividing Var with Poco::Int32
+{
+ return other / da.convert<Poco::Int32>();
+}
+
+
+inline Poco::Int32 operator += (Poco::Int32& other, const Var& da)
+ /// Addition assignment operator for adding Var to Poco::Int32
+{
+ return other += da.convert<Poco::Int32>();
+}
+
+
+inline Poco::Int32 operator -= (Poco::Int32& other, const Var& da)
+ /// Subtraction assignment operator for subtracting Var from Poco::Int32
+{
+ return other -= da.convert<Poco::Int32>();
+}
+
+
+inline Poco::Int32 operator *= (Poco::Int32& other, const Var& da)
+ /// Multiplication assignment operator for multiplying Var with Poco::Int32
+{
+ return other *= da.convert<Poco::Int32>();
+}
+
+
+inline Poco::Int32 operator /= (Poco::Int32& other, const Var& da)
+ /// Division assignment operator for dividing Var with Poco::Int32
+{
+ return other /= da.convert<Poco::Int32>();
+}
+
+
+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<Poco::Int32>();
+}
+
+
+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<Poco::Int32>();
+}
+
+
+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<Poco::Int32>();
+}
+
+
+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<Poco::Int32>();
+}
+
+
+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<Poco::Int32>();
+}
+
+
+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<Poco::Int32>();
+}
+
+
+inline Poco::UInt32 operator + (const Poco::UInt32& other, const Var& da)
+ /// Addition operator for adding Var to Poco::UInt32
+{
+ return other + da.convert<Poco::UInt32>();
+}
+
+
+inline Poco::UInt32 operator - (const Poco::UInt32& other, const Var& da)
+ /// Subtraction operator for subtracting Var from Poco::UInt32
+{
+ return other - da.convert<Poco::UInt32>();
+}
+
+
+inline Poco::UInt32 operator * (const Poco::UInt32& other, const Var& da)
+ /// Multiplication operator for multiplying Var with Poco::UInt32
+{
+ return other * da.convert<Poco::UInt32>();
+}
+
+
+inline Poco::UInt32 operator / (const Poco::UInt32& other, const Var& da)
+ /// Division operator for dividing Var with Poco::UInt32
+{
+ return other / da.convert<Poco::UInt32>();
+}
+
+
+inline Poco::UInt32 operator += (Poco::UInt32& other, const Var& da)
+ /// Addition assignment operator for adding Var to Poco::UInt32
+{
+ return other += da.convert<Poco::UInt32>();
+}
+
+
+inline Poco::UInt32 operator -= (Poco::UInt32& other, const Var& da)
+ /// Subtraction assignment operator for subtracting Var from Poco::UInt32
+{
+ return other -= da.convert<Poco::UInt32>();
+}
+
+
+inline Poco::UInt32 operator *= (Poco::UInt32& other, const Var& da)
+ /// Multiplication assignment operator for multiplying Var with Poco::UInt32
+{
+ return other *= da.convert<Poco::UInt32>();
+}
+
+
+inline Poco::UInt32 operator /= (Poco::UInt32& other, const Var& da)
+ /// Division assignment operator for dividing Var with Poco::UInt32
+{
+ return other /= da.convert<Poco::UInt32>();
+}
+
+
+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<Poco::UInt32>();
+}
+
+
+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<Poco::UInt32>();
+}
+
+
+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<Poco::UInt32>();
+}
+
+
+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<Poco::UInt32>();
+}
+
+
+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<Poco::UInt32>();
+}
+
+
+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<Poco::UInt32>();
+}
+
+
+inline Poco::Int64 operator + (const Poco::Int64& other, const Var& da)
+ /// Addition operator for adding Var to Poco::Int64
+{
+ return other + da.convert<Poco::Int64>();
+}
+
+
+inline Poco::Int64 operator - (const Poco::Int64& other, const Var& da)
+ /// Subtraction operator for subtracting Var from Poco::Int64
+{
+ return other - da.convert<Poco::Int64>();
+}
+
+
+inline Poco::Int64 operator * (const Poco::Int64& other, const Var& da)
+ /// Multiplication operator for multiplying Var with Poco::Int64
+{
+ return other * da.convert<Poco::Int64>();
+}
+
+
+inline Poco::Int64 operator / (const Poco::Int64& other, const Var& da)
+ /// Division operator for dividing Var with Poco::Int64
+{
+ return other / da.convert<Poco::Int64>();
+}
+
+
+inline Poco::Int64 operator += (Poco::Int64& other, const Var& da)
+ /// Addition assignment operator for adding Var to Poco::Int64
+{
+ return other += da.convert<Poco::Int64>();
+}
+
+
+inline Poco::Int64 operator -= (Poco::Int64& other, const Var& da)
+ /// Subtraction assignment operator for subtracting Var from Poco::Int64
+{
+ return other -= da.convert<Poco::Int64>();
+}
+
+
+inline Poco::Int64 operator *= (Poco::Int64& other, const Var& da)
+ /// Multiplication assignment operator for multiplying Var with Poco::Int64
+{
+ return other *= da.convert<Poco::Int64>();
+}
+
+
+inline Poco::Int64 operator /= (Poco::Int64& other, const Var& da)
+ /// Division assignment operator for dividing Var with Poco::Int64
+{
+ return other /= da.convert<Poco::Int64>();
+}
+
+
+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<Poco::Int64>();
+}
+
+
+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<Poco::Int64>();
+}
+
+
+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<Poco::Int64>();
+}
+
+
+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<Poco::Int64>();
+}
+
+
+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<Poco::Int64>();
+}
+
+
+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<Poco::Int64>();
+}
+
+
+inline Poco::UInt64 operator + (const Poco::UInt64& other, const Var& da)
+ /// Addition operator for adding Var to Poco::UInt64
+{
+ return other + da.convert<Poco::UInt64>();
+}
+
+
+inline Poco::UInt64 operator - (const Poco::UInt64& other, const Var& da)
+ /// Subtraction operator for subtracting Var from Poco::UInt64
+{
+ return other - da.convert<Poco::UInt64>();
+}
+
+
+inline Poco::UInt64 operator * (const Poco::UInt64& other, const Var& da)
+ /// Multiplication operator for multiplying Var with Poco::UInt64
+{
+ return other * da.convert<Poco::UInt64>();
+}
+
+
+inline Poco::UInt64 operator / (const Poco::UInt64& other, const Var& da)
+ /// Division operator for dividing Var with Poco::UInt64
+{
+ return other / da.convert<Poco::UInt64>();
+}
+
+
+inline Poco::UInt64 operator += (Poco::UInt64& other, const Var& da)
+ /// Addition assignment operator for adding Var to Poco::UInt64
+{
+ return other += da.convert<Poco::UInt64>();
+}
+
+
+inline Poco::UInt64 operator -= (Poco::UInt64& other, const Var& da)
+ /// Subtraction assignment operator for subtracting Var from Poco::UInt64
+{
+ return other -= da.convert<Poco::UInt64>();
+}
+
+
+inline Poco::UInt64 operator *= (Poco::UInt64& other, const Var& da)
+ /// Multiplication assignment operator for multiplying Var with Poco::UInt64
+{
+ return other *= da.convert<Poco::UInt64>();
+}
+
+
+inline Poco::UInt64 operator /= (Poco::UInt64& other, const Var& da)
+ /// Division assignment operator for dividing Var with Poco::UInt64
+{
+ return other /= da.convert<Poco::UInt64>();
+}
+
+
+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<Poco::UInt64>();
+}
+
+
+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<Poco::UInt64>();
+}
+
+
+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<Poco::UInt64>();
+}
+
+
+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<Poco::UInt64>();
+}
+
+
+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<Poco::UInt64>();
+}
+
+
+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<Poco::UInt64>();
+}
+
+
+inline float operator + (const float& other, const Var& da)
+ /// Addition operator for adding Var to float
+{
+ return other + da.convert<float>();
+}
+
+
+inline float operator - (const float& other, const Var& da)
+ /// Subtraction operator for subtracting Var from float
+{
+ return other - da.convert<float>();
+}
+
+
+inline float operator * (const float& other, const Var& da)
+ /// Multiplication operator for multiplying Var with float
+{
+ return other * da.convert<float>();
+}
+
+
+inline float operator / (const float& other, const Var& da)
+ /// Division operator for dividing Var with float
+{
+ return other / da.convert<float>();
+}
+
+
+inline float operator += (float& other, const Var& da)
+ /// Addition assignment operator for adding Var to float
+{
+ return other += da.convert<float>();
+}
+
+
+inline float operator -= (float& other, const Var& da)
+ /// Subtraction assignment operator for subtracting Var from float
+{
+ return other -= da.convert<float>();
+}
+
+
+inline float operator *= (float& other, const Var& da)
+ /// Multiplication assignment operator for multiplying Var with float
+{
+ return other *= da.convert<float>();
+}
+
+
+inline float operator /= (float& other, const Var& da)
+ /// Division assignment operator for dividing Var with float
+{
+ return other /= da.convert<float>();
+}
+
+
+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<float>();
+}
+
+
+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<float>();
+}
+
+
+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<float>();
+}
+
+
+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<float>();
+}
+
+
+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<float>();
+}
+
+
+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<float>();
+}
+
+
+inline double operator + (const double& other, const Var& da)
+ /// Addition operator for adding Var to double
+{
+ return other + da.convert<double>();
+}
+
+
+inline double operator - (const double& other, const Var& da)
+ /// Subtraction operator for subtracting Var from double
+{
+ return other - da.convert<double>();
+}
+
+
+inline double operator * (const double& other, const Var& da)
+ /// Multiplication operator for multiplying Var with double
+{
+ return other * da.convert<double>();
+}
+
+
+inline double operator / (const double& other, const Var& da)
+ /// Division operator for dividing Var with double
+{
+ return other / da.convert<double>();
+}
+
+
+inline double operator += (double& other, const Var& da)
+ /// Addition assignment operator for adding Var to double
+{
+ return other += da.convert<double>();
+}
+
+
+inline double operator -= (double& other, const Var& da)
+ /// Subtraction assignment operator for subtracting Var from double
+{
+ return other -= da.convert<double>();
+}
+
+
+inline double operator *= (double& other, const Var& da)
+ /// Multiplication assignment operator for multiplying Var with double
+{
+ return other *= da.convert<double>();
+}
+
+
+inline double operator /= (double& other, const Var& da)
+ /// Division assignment operator for dividing Var with double
+{
+ return other /= da.convert<double>();
+}
+
+
+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<double>();
+}
+
+
+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<double>();
+}
+
+
+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<double>();
+}
+
+
+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<double>();
+}
+
+
+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<double>();
+}
+
+
+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<double>();
+}
+
+
+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<bool>();
+}
+
+
+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<bool>();
+}
+
+
+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<std::string>();
+}
+
+
+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<std::string>();
+}
+
+
+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<UTF16String>();
+}
+
+
+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<UTF16String>();
+}
+
+
+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<std::string>() == 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<std::string>() != 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<long>();
+}
+
+
+inline long operator - (const long& other, const Var& da)
+ /// Subtraction operator for subtracting Var from long
+{
+ return other - da.convert<long>();
+}
+
+
+inline long operator * (const long& other, const Var& da)
+ /// Multiplication operator for multiplying Var with long
+{
+ return other * da.convert<long>();
+}
+
+
+inline long operator / (const long& other, const Var& da)
+ /// Division operator for dividing Var with long
+{
+ return other / da.convert<long>();
+}
+
+
+inline long operator += (long& other, const Var& da)
+ /// Addition assignment operator for adding Var to long
+{
+ return other += da.convert<long>();
+}
+
+
+inline long operator -= (long& other, const Var& da)
+ /// Subtraction assignment operator for subtracting Var from long
+{
+ return other -= da.convert<long>();
+}
+
+
+inline long operator *= (long& other, const Var& da)
+ /// Multiplication assignment operator for multiplying Var with long
+{
+ return other *= da.convert<long>();
+}
+
+
+inline long operator /= (long& other, const Var& da)
+ /// Division assignment operator for dividing Var with long
+{
+ return other /= da.convert<long>();
+}
+
+
+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<long>();
+}
+
+
+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<long>();
+}
+
+
+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<long>();
+}
+
+
+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<long>();
+}
+
+
+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<long>();
+}
+
+
+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<long>();
+}
+
+
+#endif // POCO_LONG_IS_64_BIT
+
+
+} // namespace Dynamic
+
+
+//@ deprecated
+typedef Dynamic::Var DynamicAny;
+
+
+} // namespace Poco
+
+
+#endif // Foundation_Var_INCLUDED
diff --git a/contrib/libs/poco/Foundation/include/Poco/Dynamic/VarHolder.h b/contrib/libs/poco/Foundation/include/Poco/Dynamic/VarHolder.h
index 85af40f449..f378e869fd 100644
--- a/contrib/libs/poco/Foundation/include/Poco/Dynamic/VarHolder.h
+++ b/contrib/libs/poco/Foundation/include/Poco/Dynamic/VarHolder.h
@@ -1,4213 +1,4213 @@
-//
-// VarHolder.h
-//
-// Library: Foundation
-// Package: Dynamic
-// Module: VarHolder
-//
-// Definition of the VarHolder class.
-//
-// Copyright (c) 2007, Applied Informatics Software Engineering GmbH.
-// and Contributors.
-//
-// SPDX-License-Identifier: BSL-1.0
-//
-
-
-#ifndef Foundation_VarHolder_INCLUDED
-#define Foundation_VarHolder_INCLUDED
-
-
-#include "Poco/Foundation.h"
-#include "Poco/NumberFormatter.h"
-#include "Poco/NumberParser.h"
-#include "Poco/DateTime.h"
-#include "Poco/Timestamp.h"
-#include "Poco/LocalDateTime.h"
-#include "Poco/DateTimeFormat.h"
-#include "Poco/DateTimeFormatter.h"
-#include "Poco/DateTimeParser.h"
-#include "Poco/String.h"
-#include "Poco/UnicodeConverter.h"
-#include "Poco/UTFString.h"
-#include "Poco/UTF8String.h"
-#include "Poco/Any.h"
-#include "Poco/Exception.h"
-#include <vector>
-#include <list>
-#include <deque>
-#include <typeinfo>
-#undef min
-#undef max
-#include <limits>
-
-
-namespace Poco {
-namespace Dynamic {
-
-
-class Var;
-
-
-namespace Impl {
-
-
-bool Foundation_API isJSONString(const Var& any);
- /// Returns true for values that should be JSON-formatted as string.
-
-
-void Foundation_API appendJSONKey(std::string& val, const Var& any);
- /// Converts the any to a JSON key (i.e. wraps it into double quotes
- /// regardless of the underlying type) and appends it to val.
-
-
-void Foundation_API appendJSONString(std::string& val, const Var& any);
- /// Converts the any to a JSON string (i.e. wraps it into double quotes)
- /// regardless of the underlying type) and appends it to val.
-
-
-void Foundation_API appendJSONValue(std::string& val, const Var& any);
- /// Converts the any to a JSON value (if underlying type qualifies
- /// as string - see isJSONString() - , it is wrapped into double quotes)
- /// and appends it to val
-
-
-template <typename C>
-void containerToJSON(C& cont, std::string& val)
-{
- // Serialize in JSON format. Note: although this is a vector<T>, the code only
- // supports vector<Var>. Total specialization is not possible
- // because of the cyclic dependency between Var and VarHolder
-
- // JSON format definition: [ n times: elem ',' ], no ',' for last elem
- val.append("[ ");
- typename C::const_iterator it = cont.begin();
- typename C::const_iterator itEnd = cont.end();
- if (!cont.empty())
- {
- appendJSONValue(val, *it);
- ++it;
- }
- for (; it != itEnd; ++it)
- {
- val.append(", ");
- appendJSONValue(val, *it);
- }
- val.append(" ]");
-}
-
-
-} // namespace Impl
-
-
-class Foundation_API VarHolder
- /// Interface for a data holder used by the Var class.
- /// Provides methods to convert between data types.
- /// Only data types for which VarHolder specialization exists are supported.
+//
+// VarHolder.h
+//
+// Library: Foundation
+// Package: Dynamic
+// Module: VarHolder
+//
+// Definition of the VarHolder class.
+//
+// Copyright (c) 2007, Applied Informatics Software Engineering GmbH.
+// and Contributors.
+//
+// SPDX-License-Identifier: BSL-1.0
+//
+
+
+#ifndef Foundation_VarHolder_INCLUDED
+#define Foundation_VarHolder_INCLUDED
+
+
+#include "Poco/Foundation.h"
+#include "Poco/NumberFormatter.h"
+#include "Poco/NumberParser.h"
+#include "Poco/DateTime.h"
+#include "Poco/Timestamp.h"
+#include "Poco/LocalDateTime.h"
+#include "Poco/DateTimeFormat.h"
+#include "Poco/DateTimeFormatter.h"
+#include "Poco/DateTimeParser.h"
+#include "Poco/String.h"
+#include "Poco/UnicodeConverter.h"
+#include "Poco/UTFString.h"
+#include "Poco/UTF8String.h"
+#include "Poco/Any.h"
+#include "Poco/Exception.h"
+#include <vector>
+#include <list>
+#include <deque>
+#include <typeinfo>
+#undef min
+#undef max
+#include <limits>
+
+
+namespace Poco {
+namespace Dynamic {
+
+
+class Var;
+
+
+namespace Impl {
+
+
+bool Foundation_API isJSONString(const Var& any);
+ /// Returns true for values that should be JSON-formatted as string.
+
+
+void Foundation_API appendJSONKey(std::string& val, const Var& any);
+ /// Converts the any to a JSON key (i.e. wraps it into double quotes
+ /// regardless of the underlying type) and appends it to val.
+
+
+void Foundation_API appendJSONString(std::string& val, const Var& any);
+ /// Converts the any to a JSON string (i.e. wraps it into double quotes)
+ /// regardless of the underlying type) and appends it to val.
+
+
+void Foundation_API appendJSONValue(std::string& val, const Var& any);
+ /// Converts the any to a JSON value (if underlying type qualifies
+ /// as string - see isJSONString() - , it is wrapped into double quotes)
+ /// and appends it to val
+
+
+template <typename C>
+void containerToJSON(C& cont, std::string& val)
+{
+ // Serialize in JSON format. Note: although this is a vector<T>, the code only
+ // supports vector<Var>. Total specialization is not possible
+ // because of the cyclic dependency between Var and VarHolder
+
+ // JSON format definition: [ n times: elem ',' ], no ',' for last elem
+ val.append("[ ");
+ typename C::const_iterator it = cont.begin();
+ typename C::const_iterator itEnd = cont.end();
+ if (!cont.empty())
+ {
+ appendJSONValue(val, *it);
+ ++it;
+ }
+ for (; it != itEnd; ++it)
+ {
+ val.append(", ");
+ appendJSONValue(val, *it);
+ }
+ val.append(" ]");
+}
+
+
+} // namespace Impl
+
+
+class Foundation_API VarHolder
+ /// Interface for a data holder used by the Var class.
+ /// Provides methods to convert between data types.
+ /// Only data types for which VarHolder specialization exists are supported.
+ ///
+ /// Provided are specializations for all C++ built-in types with addition of
+ /// std::string, Poco::UTF16String, DateTime, LocalDateTime, Timestamp, std::vector<Var> and DynamicStruct.
///
- /// Provided are specializations for all C++ built-in types with addition of
- /// std::string, Poco::UTF16String, DateTime, LocalDateTime, Timestamp, std::vector<Var> and DynamicStruct.
- ///
- /// Additional types can be supported by adding specializations. When implementing specializations,
- /// the only condition is that they reside in Poco namespace and implement the pure virtual functions
- /// clone() and type().
- ///
- /// Those conversions that are not implemented shall fail back to this base
- /// class implementation. All the convert() function overloads in this class
- /// throw BadCastException.
-{
-public:
- typedef Var ArrayValueType;
-
- virtual ~VarHolder();
- /// Destroys the VarHolder.
-
- virtual VarHolder* clone(Placeholder<VarHolder>* pHolder = 0) const = 0;
- /// Implementation must implement this function to
- /// deep-copy the VarHolder.
- /// If small object optimization is enabled (i.e. if
- /// POCO_NO_SOO is not defined), VarHolder will be
- /// instantiated in-place if it's size is smaller
- /// than POCO_SMALL_OBJECT_SIZE.
-
- virtual const std::type_info& type() const = 0;
- /// Implementation must return the type information
- /// (typeid) for the stored content.
-
- virtual void convert(Int8& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
- virtual void convert(Int16& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
- virtual void convert(Int32& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
- virtual void convert(Int64& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
- virtual void convert(UInt8& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
- virtual void convert(UInt16& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
- virtual void convert(UInt32& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
- virtual void convert(UInt64& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
- virtual void convert(DateTime& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
- virtual void convert(LocalDateTime& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
- virtual void convert(Timestamp& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
-#ifndef POCO_LONG_IS_64_BIT
-
- void convert(long& val) const;
- /// Calls convert(Int32).
-
- void convert(unsigned long& val) const;
- /// Calls convert(UInt32).
-
-#else
-
- virtual void convert(long long& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to suport the conversion.
-
- virtual void convert(unsigned long long & val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to suport the conversion.
-
-#endif
-
- virtual void convert(bool& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
- virtual void convert(float& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
- virtual void convert(double& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
- virtual void convert(char& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
- virtual void convert(std::string& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
- virtual void convert(Poco::UTF16String& val) const;
- /// Throws BadCastException. Must be overriden in a type
- /// specialization in order to support the conversion.
-
- virtual bool isArray() const;
- /// Returns true.
-
- virtual bool isVector() const;
- /// Returns false. Must be properly overriden in a type
- /// specialization in order to support the diagnostic.
-
- virtual bool isList() const;
- /// Returns false. Must be properly overriden in a type
- /// specialization in order to support the diagnostic.
-
- virtual bool isDeque() const;
- /// Returns false. Must be properly overriden in a type
- /// specialization in order to support the diagnostic.
-
- virtual bool isStruct() const;
- /// Returns false. Must be properly overriden in a type
- /// specialization in order to support the diagnostic.
-
- virtual bool isInteger() const;
- /// Returns false. Must be properly overriden in a type
- /// specialization in order to support the diagnostic.
-
- virtual bool isSigned() const;
- /// Returns false. Must be properly overriden in a type
- /// specialization in order to support the diagnostic.
-
- virtual bool isNumeric() const;
- /// Returns false. Must be properly overriden in a type
- /// specialization in order to support the diagnostic.
-
- virtual bool isBoolean() const;
- /// Returns false. Must be properly overriden in a type
- /// specialization in order to support the diagnostic.
-
- virtual bool isString() const;
- /// Returns false. Must be properly overriden in a type
- /// specialization in order to support the diagnostic.
-
- virtual bool isDate() const;
- /// Returns false. Must be properly overriden in a type
- /// specialization in order to support the diagnostic.
-
- virtual bool isTime() const;
- /// Returns false. Must be properly overriden in a type
- /// specialization in order to support the diagnostic.
-
- virtual bool isDateTime() const;
- /// Returns false. Must be properly overriden in a type
- /// specialization in order to support the diagnostic.
-
- virtual std::size_t size() const;
- /// Returns 1 iff Var is not empty or this function overriden.
-
-protected:
- VarHolder();
- /// Creates the VarHolder.
-
- template <typename T>
- VarHolder* cloneHolder(Placeholder<VarHolder>* pVarHolder, const T& val) const
- /// Instantiates value holder wrapper. If size of the wrapper is
- /// larger than POCO_SMALL_OBJECT_SIZE, holder is instantiated on
- /// the heap, otherwise it is instantiated in-place (in the
- /// pre-allocated buffer inside the holder).
- ///
- /// Called from clone() member function of the implementation when
- /// small object optimization is enabled.
- {
-#ifdef POCO_NO_SOO
- (void)pVarHolder;
- return new VarHolderImpl<T>(val);
-#else
- poco_check_ptr (pVarHolder);
- if ((sizeof(VarHolderImpl<T>) <= Placeholder<T>::Size::value))
- {
- new ((VarHolder*) pVarHolder->holder) VarHolderImpl<T>(val);
- pVarHolder->setLocal(true);
- return (VarHolder*) pVarHolder->holder;
- }
- else
- {
- pVarHolder->pHolder = new VarHolderImpl<T>(val);
- pVarHolder->setLocal(false);
- return pVarHolder->pHolder;
- }
-#endif
- }
-
- template <typename F, typename T>
- void convertToSmaller(const F& from, T& to) const
- /// This function is meant to convert signed numeric values from
- /// larger to smaller type. It checks the upper and lower bound and
- /// if from value is within limits of type T (i.e. check calls do not throw),
- /// it is converted.
- {
- poco_static_assert (std::numeric_limits<F>::is_specialized);
- poco_static_assert (std::numeric_limits<T>::is_specialized);
- poco_static_assert (std::numeric_limits<F>::is_signed);
- poco_static_assert (std::numeric_limits<T>::is_signed);
-
- if (std::numeric_limits<F>::is_integer)
- {
- checkUpperLimit<F,T>(from);
- checkLowerLimit<F,T>(from);
- }
- else
- {
- checkUpperLimitFloat<F,T>(from);
- checkLowerLimitFloat<F,T>(from);
- }
-
- to = static_cast<T>(from);
- }
-
- template <typename F, typename T>
- void convertToSmallerUnsigned(const F& from, T& to) const
- /// This function is meant for converting unsigned integral data types,
- /// from larger to smaller type. Since lower limit is always 0 for unsigned types,
- /// only the upper limit is checked, thus saving some cycles compared to the signed
- /// version of the function. If the value to be converted is smaller than
- /// the maximum value for the target type, the conversion is performed.
- {
- poco_static_assert (std::numeric_limits<F>::is_specialized);
- poco_static_assert (std::numeric_limits<T>::is_specialized);
- poco_static_assert (!std::numeric_limits<F>::is_signed);
- poco_static_assert (!std::numeric_limits<T>::is_signed);
-
- checkUpperLimit<F,T>(from);
- to = static_cast<T>(from);
- }
-
- template <typename F, typename T>
- void convertSignedToUnsigned(const F& from, T& to) const
- /// This function is meant for converting signed integral data types to
- /// unsigned data types. Negative values can not be converted and if one
- /// is encountered, RangeException is thrown.
- /// If upper limit is within the target data type limits, the conversion is performed.
- {
- poco_static_assert (std::numeric_limits<F>::is_specialized);
- poco_static_assert (std::numeric_limits<T>::is_specialized);
- poco_static_assert (std::numeric_limits<F>::is_signed);
- poco_static_assert (!std::numeric_limits<T>::is_signed);
-
- if (from < 0)
- throw RangeException("Value too small.");
+ /// Additional types can be supported by adding specializations. When implementing specializations,
+ /// the only condition is that they reside in Poco namespace and implement the pure virtual functions
+ /// clone() and type().
+ ///
+ /// Those conversions that are not implemented shall fail back to this base
+ /// class implementation. All the convert() function overloads in this class
+ /// throw BadCastException.
+{
+public:
+ typedef Var ArrayValueType;
+
+ virtual ~VarHolder();
+ /// Destroys the VarHolder.
+
+ virtual VarHolder* clone(Placeholder<VarHolder>* pHolder = 0) const = 0;
+ /// Implementation must implement this function to
+ /// deep-copy the VarHolder.
+ /// If small object optimization is enabled (i.e. if
+ /// POCO_NO_SOO is not defined), VarHolder will be
+ /// instantiated in-place if it's size is smaller
+ /// than POCO_SMALL_OBJECT_SIZE.
+
+ virtual const std::type_info& type() const = 0;
+ /// Implementation must return the type information
+ /// (typeid) for the stored content.
+
+ virtual void convert(Int8& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+ virtual void convert(Int16& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+ virtual void convert(Int32& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+ virtual void convert(Int64& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+ virtual void convert(UInt8& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+ virtual void convert(UInt16& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+ virtual void convert(UInt32& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+ virtual void convert(UInt64& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+ virtual void convert(DateTime& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+ virtual void convert(LocalDateTime& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+ virtual void convert(Timestamp& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+#ifndef POCO_LONG_IS_64_BIT
+
+ void convert(long& val) const;
+ /// Calls convert(Int32).
+
+ void convert(unsigned long& val) const;
+ /// Calls convert(UInt32).
+
+#else
+
+ virtual void convert(long long& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to suport the conversion.
+
+ virtual void convert(unsigned long long & val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to suport the conversion.
+
+#endif
+
+ virtual void convert(bool& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+ virtual void convert(float& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+ virtual void convert(double& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+ virtual void convert(char& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+ virtual void convert(std::string& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+ virtual void convert(Poco::UTF16String& val) const;
+ /// Throws BadCastException. Must be overriden in a type
+ /// specialization in order to support the conversion.
+
+ virtual bool isArray() const;
+ /// Returns true.
+
+ virtual bool isVector() const;
+ /// Returns false. Must be properly overriden in a type
+ /// specialization in order to support the diagnostic.
+
+ virtual bool isList() const;
+ /// Returns false. Must be properly overriden in a type
+ /// specialization in order to support the diagnostic.
+
+ virtual bool isDeque() const;
+ /// Returns false. Must be properly overriden in a type
+ /// specialization in order to support the diagnostic.
+
+ virtual bool isStruct() const;
+ /// Returns false. Must be properly overriden in a type
+ /// specialization in order to support the diagnostic.
+
+ virtual bool isInteger() const;
+ /// Returns false. Must be properly overriden in a type
+ /// specialization in order to support the diagnostic.
+
+ virtual bool isSigned() const;
+ /// Returns false. Must be properly overriden in a type
+ /// specialization in order to support the diagnostic.
+
+ virtual bool isNumeric() const;
+ /// Returns false. Must be properly overriden in a type
+ /// specialization in order to support the diagnostic.
+
+ virtual bool isBoolean() const;
+ /// Returns false. Must be properly overriden in a type
+ /// specialization in order to support the diagnostic.
+
+ virtual bool isString() const;
+ /// Returns false. Must be properly overriden in a type
+ /// specialization in order to support the diagnostic.
+
+ virtual bool isDate() const;
+ /// Returns false. Must be properly overriden in a type
+ /// specialization in order to support the diagnostic.
+
+ virtual bool isTime() const;
+ /// Returns false. Must be properly overriden in a type
+ /// specialization in order to support the diagnostic.
+
+ virtual bool isDateTime() const;
+ /// Returns false. Must be properly overriden in a type
+ /// specialization in order to support the diagnostic.
+
+ virtual std::size_t size() const;
+ /// Returns 1 iff Var is not empty or this function overriden.
+
+protected:
+ VarHolder();
+ /// Creates the VarHolder.
+
+ template <typename T>
+ VarHolder* cloneHolder(Placeholder<VarHolder>* pVarHolder, const T& val) const
+ /// Instantiates value holder wrapper. If size of the wrapper is
+ /// larger than POCO_SMALL_OBJECT_SIZE, holder is instantiated on
+ /// the heap, otherwise it is instantiated in-place (in the
+ /// pre-allocated buffer inside the holder).
+ ///
+ /// Called from clone() member function of the implementation when
+ /// small object optimization is enabled.
+ {
+#ifdef POCO_NO_SOO
+ (void)pVarHolder;
+ return new VarHolderImpl<T>(val);
+#else
+ poco_check_ptr (pVarHolder);
+ if ((sizeof(VarHolderImpl<T>) <= Placeholder<T>::Size::value))
+ {
+ new ((VarHolder*) pVarHolder->holder) VarHolderImpl<T>(val);
+ pVarHolder->setLocal(true);
+ return (VarHolder*) pVarHolder->holder;
+ }
+ else
+ {
+ pVarHolder->pHolder = new VarHolderImpl<T>(val);
+ pVarHolder->setLocal(false);
+ return pVarHolder->pHolder;
+ }
+#endif
+ }
+
+ template <typename F, typename T>
+ void convertToSmaller(const F& from, T& to) const
+ /// This function is meant to convert signed numeric values from
+ /// larger to smaller type. It checks the upper and lower bound and
+ /// if from value is within limits of type T (i.e. check calls do not throw),
+ /// it is converted.
+ {
+ poco_static_assert (std::numeric_limits<F>::is_specialized);
+ poco_static_assert (std::numeric_limits<T>::is_specialized);
+ poco_static_assert (std::numeric_limits<F>::is_signed);
+ poco_static_assert (std::numeric_limits<T>::is_signed);
+
+ if (std::numeric_limits<F>::is_integer)
+ {
+ checkUpperLimit<F,T>(from);
+ checkLowerLimit<F,T>(from);
+ }
+ else
+ {
+ checkUpperLimitFloat<F,T>(from);
+ checkLowerLimitFloat<F,T>(from);
+ }
+
+ to = static_cast<T>(from);
+ }
+
+ template <typename F, typename T>
+ void convertToSmallerUnsigned(const F& from, T& to) const
+ /// This function is meant for converting unsigned integral data types,
+ /// from larger to smaller type. Since lower limit is always 0 for unsigned types,
+ /// only the upper limit is checked, thus saving some cycles compared to the signed
+ /// version of the function. If the value to be converted is smaller than
+ /// the maximum value for the target type, the conversion is performed.
+ {
+ poco_static_assert (std::numeric_limits<F>::is_specialized);
+ poco_static_assert (std::numeric_limits<T>::is_specialized);
+ poco_static_assert (!std::numeric_limits<F>::is_signed);
+ poco_static_assert (!std::numeric_limits<T>::is_signed);
+
+ checkUpperLimit<F,T>(from);
+ to = static_cast<T>(from);
+ }
+
+ template <typename F, typename T>
+ void convertSignedToUnsigned(const F& from, T& to) const
+ /// This function is meant for converting signed integral data types to
+ /// unsigned data types. Negative values can not be converted and if one
+ /// is encountered, RangeException is thrown.
+ /// If upper limit is within the target data type limits, the conversion is performed.
+ {
+ poco_static_assert (std::numeric_limits<F>::is_specialized);
+ poco_static_assert (std::numeric_limits<T>::is_specialized);
+ poco_static_assert (std::numeric_limits<F>::is_signed);
+ poco_static_assert (!std::numeric_limits<T>::is_signed);
+
+ if (from < 0)
+ throw RangeException("Value too small.");
+ checkUpperLimit<F,T>(from);
+ to = static_cast<T>(from);
+ }
+
+ template <typename F, typename T>
+ void convertSignedFloatToUnsigned(const F& from, T& to) const
+ /// This function is meant for converting floating point data types to
+ /// unsigned integral data types. Negative values can not be converted and if one
+ /// is encountered, RangeException is thrown.
+ /// If upper limit is within the target data type limits, the conversion is performed.
+ {
+ poco_static_assert (std::numeric_limits<F>::is_specialized);
+ poco_static_assert (std::numeric_limits<T>::is_specialized);
+ poco_static_assert (!std::numeric_limits<F>::is_integer);
+ poco_static_assert (std::numeric_limits<T>::is_integer);
+ poco_static_assert (!std::numeric_limits<T>::is_signed);
+
+ if (from < 0)
+ throw RangeException("Value too small.");
+ checkUpperLimitFloat<F,T>(from);
+ to = static_cast<T>(from);
+ }
+
+ template <typename F, typename T>
+ void convertUnsignedToSigned(const F& from, T& to) const
+ /// This function is meant for converting unsigned integral data types to
+ /// signed integral data types. Negative values can not be converted and if one
+ /// is encountered, RangeException is thrown.
+ /// If upper limit is within the target data type limits, the conversion is performed.
+ {
+ poco_static_assert (std::numeric_limits<F>::is_specialized);
+ poco_static_assert (std::numeric_limits<T>::is_specialized);
+ poco_static_assert (!std::numeric_limits<F>::is_signed);
+ poco_static_assert (std::numeric_limits<T>::is_signed);
+
checkUpperLimit<F,T>(from);
- to = static_cast<T>(from);
- }
-
- template <typename F, typename T>
- void convertSignedFloatToUnsigned(const F& from, T& to) const
- /// This function is meant for converting floating point data types to
- /// unsigned integral data types. Negative values can not be converted and if one
- /// is encountered, RangeException is thrown.
- /// If upper limit is within the target data type limits, the conversion is performed.
- {
- poco_static_assert (std::numeric_limits<F>::is_specialized);
- poco_static_assert (std::numeric_limits<T>::is_specialized);
- poco_static_assert (!std::numeric_limits<F>::is_integer);
- poco_static_assert (std::numeric_limits<T>::is_integer);
- poco_static_assert (!std::numeric_limits<T>::is_signed);
-
- if (from < 0)
- throw RangeException("Value too small.");
- checkUpperLimitFloat<F,T>(from);
- to = static_cast<T>(from);
- }
-
- template <typename F, typename T>
- void convertUnsignedToSigned(const F& from, T& to) const
- /// This function is meant for converting unsigned integral data types to
- /// signed integral data types. Negative values can not be converted and if one
- /// is encountered, RangeException is thrown.
- /// If upper limit is within the target data type limits, the conversion is performed.
- {
- poco_static_assert (std::numeric_limits<F>::is_specialized);
- poco_static_assert (std::numeric_limits<T>::is_specialized);
- poco_static_assert (!std::numeric_limits<F>::is_signed);
- poco_static_assert (std::numeric_limits<T>::is_signed);
-
- checkUpperLimit<F,T>(from);
- to = static_cast<T>(from);
- }
-
-private:
-
-#ifdef _MSC_VER
-#pragma warning( push )
-#pragma warning( disable : 4127 )
-#pragma warning( disable : 4018 )
-#endif
-
- template <typename F, typename T>
- void checkUpperLimit(const F& from) const
- {
- // casting to type of smaller size AND
- // 'from' is greater than 'T' max value
- if ((sizeof(T) < sizeof(F)) &&
- (from > static_cast<F>(std::numeric_limits<T>::max())))
- {
- throw RangeException("Value too large.");
- }
- // casting to type of equal/bigger size AND
- // 'F' is signed AND
- // 'T' is unsigned AND
- // 'from' is negative
- else if (std::numeric_limits<F>::is_signed &&
- !std::numeric_limits<T>::is_signed && from < 0)
- {
- throw RangeException("Value too small.");
- }
- // casting to type of equal/bigger size AND
- // 'F' is unsigned AND
- // 'T' is signed AND
- // 'from' is greater than 'T' max value
- else if (!std::numeric_limits<F>::is_signed &&
- std::numeric_limits<T>::is_signed &&
- static_cast<Poco::UInt64>(from) > std::numeric_limits<T>::max())
- {
- throw RangeException("Value too large.");
- }
- }
-
-#ifdef _MSC_VER
-#pragma warning( pop )
-#endif
-
- template <typename F, typename T>
- void checkUpperLimitFloat(const F& from) const
- {
- if (from > std::numeric_limits<T>::max())
- throw RangeException("Value too large.");
- }
-
- template <typename F, typename T>
- void checkLowerLimitFloat(const F& from) const
- {
- if (from < -std::numeric_limits<T>::max())
- throw RangeException("Value too small.");
- }
-
- template <typename F, typename T>
- void checkLowerLimit(const F& from) const
- {
- if (from < std::numeric_limits<T>::min())
- throw RangeException("Value too small.");
- }
-};
-
-
-//
-// inlines
-//
-
-
-inline void VarHolder::convert(Int8& /*val*/) const
-{
- throw BadCastException("Can not convert to Int8");
-}
-
-
-inline void VarHolder::convert(Int16& /*val*/) const
-{
- throw BadCastException("Can not convert to Int16");
-}
-
-
-inline void VarHolder::convert(Int32& /*val*/) const
-{
- throw BadCastException("Can not convert to Int32");
-}
-
-
-inline void VarHolder::convert(Int64& /*val*/) const
-{
- throw BadCastException("Can not convert to Int64");
-}
-
-
-inline void VarHolder::convert(UInt8& /*val*/) const
-{
- throw BadCastException("Can not convert to UInt8");
-}
-
-
-inline void VarHolder::convert(UInt16& /*val*/) const
-{
- throw BadCastException("Can not convert to UInt16");
-}
-
-
-inline void VarHolder::convert(UInt32& /*val*/) const
-{
- throw BadCastException("Can not convert to UInt32");
-}
-
-
-inline void VarHolder::convert(UInt64& /*val*/) const
-{
- throw BadCastException("Can not convert to UInt64");
-}
-
-
-inline void VarHolder::convert(DateTime& /*val*/) const
-{
- throw BadCastException("Can not convert to DateTime");
-}
-
-
-inline void VarHolder::convert(LocalDateTime& /*val*/) const
-{
- throw BadCastException("Can not convert to LocalDateTime");
-}
-
-
-inline void VarHolder::convert(Timestamp& /*val*/) const
-{
- throw BadCastException("Can not convert to Timestamp");
-}
-
-#ifndef POCO_LONG_IS_64_BIT
-
-inline void VarHolder::convert(long& val) const
-{
- Int32 tmp;
- convert(tmp);
- val = tmp;
-}
-
-
-inline void VarHolder::convert(unsigned long& val) const
-{
- UInt32 tmp;
- convert(tmp);
- val = tmp;
-}
-
-#else
-
-inline void VarHolder::convert(long long& /*val*/) const
-{
- throw BadCastException("Can not convert to long long");
-}
-
-
-inline void VarHolder::convert(unsigned long long& /*val*/) const
-{
- throw BadCastException("Can not convert to unsigned long long");
-}
-
-#endif
-
-inline void VarHolder::convert(bool& /*val*/) const
-{
- throw BadCastException("Can not convert to bool");
-}
-
-
-inline void VarHolder::convert(float& /*val*/) const
-{
- throw BadCastException("Can not convert to float");
-}
-
-
-inline void VarHolder::convert(double& /*val*/) const
-{
- throw BadCastException("Can not convert to double");
-}
-
-
-inline void VarHolder::convert(char& /*val*/) const
-{
- throw BadCastException("Can not convert to char");
-}
-
-
-inline void VarHolder::convert(std::string& /*val*/) const
-{
- throw BadCastException("Can not convert to std::string");
-}
-
-
-inline void VarHolder::convert(Poco::UTF16String& /*val*/) const
-{
- throw BadCastException("Can not convert to Poco::UTF16String");
-}
-
-
-inline bool VarHolder::isArray() const
-{
- return true;
-}
-
-
-inline bool VarHolder::isVector() const
-{
- return false;
-}
-
-
-inline bool VarHolder::isList() const
-{
- return false;
-}
-
-
-inline bool VarHolder::isDeque() const
-{
- return false;
-}
-
-
-inline bool VarHolder::isStruct() const
-{
- return false;
-}
-
-inline bool VarHolder::isInteger() const
-{
- return false;
-}
-
-
-inline bool VarHolder::isSigned() const
-{
- return false;
-}
-
-
-inline bool VarHolder::isNumeric() const
-{
- return false;
-}
-
-
-inline bool VarHolder::isBoolean() const
-{
- return false;
-}
-
-
-inline bool VarHolder::isString() const
-{
- return false;
-}
-
-
-inline bool VarHolder::isDate() const
-{
- return false;
-}
-
-
-inline bool VarHolder::isTime() const
-{
- return false;
-}
-
-
-inline bool VarHolder::isDateTime() const
-{
- return false;
-}
-
-inline std::size_t VarHolder::size() const
-{
- return 1u;
-}
-
-
-template <typename T>
-class VarHolderImpl: public VarHolder
- /// Template based implementation of a VarHolder.
- /// This class provides type storage for user-defined types
- /// that do not have VarHolderImpl specialization.
- ///
- /// The actual conversion work happens in the template specializations
- /// of this class.
- ///
- /// VarHolderImpl throws following exceptions:
- /// BadCastException (if the requested conversion is not implemented)
- /// RangeException (if an attempt is made to assign a numeric value outside of the target min/max limits
- /// SyntaxException (if an attempt is made to convert a string containing non-numeric characters to number)
- ///
- /// In order to support efficient direct extraction of the held value,
- /// all specializations must additionally implement a public member function:
- ///
- /// const T& value() const
- ///
- /// returning a const reference to the actual stored value.
-{
-public:
- VarHolderImpl(const T& val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(T);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const T& value() const
- {
- return _val;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- T _val;
-};
-
-
-template <>
-class VarHolderImpl<Int8>: public VarHolder
-{
-public:
- VarHolderImpl(Int8 val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(Int8);
- }
-
- void convert(Int8& val) const
- {
- val = _val;
- }
-
- void convert(Int16& val) const
- {
- val = _val;
- }
-
- void convert(Int32& val) const
- {
- val = _val;
- }
-
- void convert(Int64& val) const
- {
- val = _val;
- }
-
- void convert(UInt8& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt16& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt32& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt64& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- val = _val;
- }
-
- void convert(unsigned long long& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
-#endif
-
- void convert(bool& val) const
- {
- val = (_val != 0);
- }
-
- void convert(float& val) const
- {
- val = static_cast<float>(_val);
- }
-
- void convert(double& val) const
- {
- val = static_cast<double>(_val);
- }
-
- void convert(char& val) const
- {
- val = static_cast<char>(_val);
- }
-
- void convert(std::string& val) const
- {
- val = NumberFormatter::format(_val);
- }
-
- void convert(Poco::UTF16String& val) const
- {
- std::string str = NumberFormatter::format(_val);
- Poco::UnicodeConverter::convert(str, val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const Int8& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return std::numeric_limits<Int8>::is_integer;
- }
-
- bool isSigned() const
- {
- return std::numeric_limits<Int8>::is_signed;
- }
-
- bool isNumeric() const
- {
- return std::numeric_limits<Int8>::is_specialized;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- Int8 _val;
-};
-
-
-template <>
-class VarHolderImpl<Int16>: public VarHolder
-{
-public:
- VarHolderImpl(Int16 val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(Int16);
- }
-
- void convert(Int8& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int16& val) const
- {
- val = _val;
- }
-
- void convert(Int32& val) const
- {
- val = _val;
- }
-
- void convert(Int64& val) const
- {
- val = _val;
- }
-
- void convert(UInt8& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt16& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt32& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt64& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- val = _val;
- }
-
- void convert(unsigned long long& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
-#endif
-
- void convert(bool& val) const
- {
- val = (_val != 0);
- }
-
- void convert(float& val) const
- {
- val = static_cast<float>(_val);
- }
-
- void convert(double& val) const
- {
- val = static_cast<double>(_val);
- }
-
- void convert(char& val) const
- {
- UInt8 tmp;
- convert(tmp);
- val = static_cast<char>(tmp);
- }
-
- void convert(std::string& val) const
- {
- val = NumberFormatter::format(_val);
- }
-
- void convert(Poco::UTF16String& val) const
- {
- std::string str = NumberFormatter::format(_val);
- Poco::UnicodeConverter::convert(str, val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const Int16& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return std::numeric_limits<Int16>::is_integer;
- }
-
- bool isSigned() const
- {
- return std::numeric_limits<Int16>::is_signed;
- }
-
- bool isNumeric() const
- {
- return std::numeric_limits<Int16>::is_specialized;
- }
-
-
- bool isString() const
- {
- return false;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- Int16 _val;
-};
-
-
-template <>
-class VarHolderImpl<Int32>: public VarHolder
-{
-public:
- VarHolderImpl(Int32 val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(Int32);
- }
-
- void convert(Int8& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int16& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int32& val) const
- {
- val = _val;
- }
-
- void convert(Int64& val) const
- {
- val = _val;
- }
-
- void convert(UInt8& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt16& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt32& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt64& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- val = _val;
- }
-
- void convert(unsigned long long& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
-#endif
-
- void convert(bool& val) const
- {
- val = (_val != 0);
- }
-
- void convert(float& val) const
- {
- val = static_cast<float>(_val);
- }
-
- void convert(double& val) const
- {
- val = static_cast<double>(_val);
- }
-
- void convert(char& val) const
- {
- UInt8 tmp;
- convert(tmp);
- val = static_cast<char>(tmp);
- }
-
- void convert(std::string& val) const
- {
- val = NumberFormatter::format(_val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const Int32& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return std::numeric_limits<Int32>::is_integer;
- }
-
- bool isSigned() const
- {
- return std::numeric_limits<Int32>::is_signed;
- }
-
- bool isNumeric() const
- {
- return std::numeric_limits<Int32>::is_specialized;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- Int32 _val;
-};
-
-
-template <>
-class VarHolderImpl<Int64>: public VarHolder
-{
-public:
- VarHolderImpl(Int64 val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(Int64);
- }
-
- void convert(Int8& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int16& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int32& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int64& val) const
- {
- val = _val;
- }
-
- void convert(UInt8& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt16& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt32& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt64& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- val = _val;
- }
-
- void convert(unsigned long long& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
-#endif
-
- void convert(bool& val) const
- {
- val = (_val != 0);
- }
-
- void convert(float& val) const
- {
- val = static_cast<float>(_val);
- }
-
- void convert(double& val) const
- {
- val = static_cast<double>(_val);
- }
-
- void convert(char& val) const
- {
- UInt8 tmp;
- convert(tmp);
- val = static_cast<char>(tmp);
- }
-
- void convert(std::string& val) const
- {
- val = NumberFormatter::format(_val);
- }
-
- void convert(DateTime& dt) const
- {
- dt = Timestamp(_val);
- }
-
- void convert(LocalDateTime& ldt) const
- {
- ldt = Timestamp(_val);
- }
-
- void convert(Timestamp& val) const
- {
- val = Timestamp(_val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const Int64& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return std::numeric_limits<Int64>::is_integer;
- }
-
- bool isSigned() const
- {
- return std::numeric_limits<Int64>::is_signed;
- }
-
- bool isNumeric() const
- {
- return std::numeric_limits<Int64>::is_specialized;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- Int64 _val;
-};
-
-
-template <>
-class VarHolderImpl<UInt8>: public VarHolder
-{
-public:
- VarHolderImpl(UInt8 val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(UInt8);
- }
-
- void convert(Int8& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int16& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int32& val) const
- {
- val = static_cast<Int32>(_val);
- }
-
- void convert(Int64& val) const
- {
- val = static_cast<Int64>(_val);
- }
-
- void convert(UInt8& val) const
- {
- val = _val;
- }
-
- void convert(UInt16& val) const
- {
- val = _val;
- }
-
- void convert(UInt32& val) const
- {
- val = _val;
- }
-
- void convert(UInt64& val) const
- {
- val = _val;
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- val = static_cast<long long>(_val);
- }
-
- void convert(unsigned long long& val) const
- {
- val = _val;
- }
-
-#endif
-
- void convert(bool& val) const
- {
- val = (_val != 0);
- }
-
- void convert(float& val) const
- {
- val = static_cast<float>(_val);
- }
-
- void convert(double& val) const
- {
- val = static_cast<double>(_val);
- }
-
- void convert(char& val) const
- {
- UInt8 tmp;
- convert(tmp);
- val = static_cast<char>(tmp);
- }
-
- void convert(std::string& val) const
- {
- val = NumberFormatter::format(_val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const UInt8& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return std::numeric_limits<UInt8>::is_integer;
- }
-
- bool isSigned() const
- {
- return std::numeric_limits<UInt8>::is_signed;
- }
-
- bool isNumeric() const
- {
- return std::numeric_limits<UInt8>::is_specialized;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- UInt8 _val;
-};
-
-
-template <>
-class VarHolderImpl<UInt16>: public VarHolder
-{
-public:
- VarHolderImpl(UInt16 val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(UInt16);
- }
-
- void convert(Int8& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int16& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int32& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int64& val) const
- {
- val = static_cast<Int64>(_val);
- }
-
- void convert(UInt8& val) const
- {
- convertToSmallerUnsigned(_val, val);
- }
-
- void convert(UInt16& val) const
- {
- val = _val;
- }
-
- void convert(UInt32& val) const
- {
- val = _val;
- }
-
- void convert(UInt64& val) const
- {
- val = _val;
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- val = static_cast<long long>(_val);
- }
-
- void convert(unsigned long long& val) const
- {
- val = _val;
- }
-
-#endif
-
- void convert(bool& val) const
- {
- val = (_val != 0);
- }
-
- void convert(float& val) const
- {
- val = static_cast<float>(_val);
- }
-
- void convert(double& val) const
- {
- val = static_cast<double>(_val);
- }
-
- void convert(char& val) const
- {
- UInt8 tmp;
- convert(tmp);
- val = static_cast<char>(tmp);
- }
-
- void convert(std::string& val) const
- {
- val = NumberFormatter::format(_val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const UInt16& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return std::numeric_limits<UInt16>::is_integer;
- }
-
- bool isSigned() const
- {
- return std::numeric_limits<UInt16>::is_signed;
- }
-
- bool isNumeric() const
- {
- return std::numeric_limits<UInt16>::is_specialized;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- UInt16 _val;
-};
-
-
-template <>
-class VarHolderImpl<UInt32>: public VarHolder
-{
-public:
- VarHolderImpl(UInt32 val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(UInt32);
- }
-
- void convert(Int8& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int16& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int32& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int64& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(UInt8& val) const
- {
- convertToSmallerUnsigned(_val, val);
- }
-
- void convert(UInt16& val) const
- {
- convertToSmallerUnsigned(_val, val);
- }
-
- void convert(UInt32& val) const
- {
- val = _val;
- }
-
- void convert(UInt64& val) const
- {
- val = _val;
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(unsigned long long& val) const
- {
- val = _val;
- }
-
-#endif
-
- void convert(bool& val) const
- {
- val = (_val != 0);
- }
-
- void convert(float& val) const
- {
- val = static_cast<float>(_val);
- }
-
- void convert(double& val) const
- {
- val = static_cast<double>(_val);
- }
-
- void convert(char& val) const
- {
- UInt8 tmp;
- convert(tmp);
- val = static_cast<char>(tmp);
- }
-
- void convert(std::string& val) const
- {
- val = NumberFormatter::format(_val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const UInt32& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return std::numeric_limits<UInt32>::is_integer;
- }
-
- bool isSigned() const
- {
- return std::numeric_limits<UInt32>::is_signed;
- }
-
- bool isNumeric() const
- {
- return std::numeric_limits<UInt32>::is_specialized;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- UInt32 _val;
-};
-
-
-template <>
-class VarHolderImpl<UInt64>: public VarHolder
-{
-public:
- VarHolderImpl(UInt64 val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(UInt64);
- }
-
- void convert(Int8& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int16& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int32& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int64& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(UInt8& val) const
- {
- convertToSmallerUnsigned(_val, val);
- }
-
- void convert(UInt16& val) const
- {
- convertToSmallerUnsigned(_val, val);
- }
-
- void convert(UInt32& val) const
- {
- convertToSmallerUnsigned(_val, val);
- }
-
- void convert(UInt64& val) const
- {
- val = _val;
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(unsigned long long& val) const
- {
- val = _val;
- }
-
-#endif
-
- void convert(bool& val) const
- {
- val = (_val != 0);
- }
-
- void convert(float& val) const
- {
- val = static_cast<float>(_val);
- }
-
- void convert(double& val) const
- {
- val = static_cast<double>(_val);
- }
-
- void convert(char& val) const
- {
- UInt8 tmp;
- convert(tmp);
- val = static_cast<char>(tmp);
- }
-
- void convert(std::string& val) const
- {
- val = NumberFormatter::format(_val);
- }
-
- void convert(DateTime& dt) const
- {
- Int64 val;
- convertUnsignedToSigned(_val, val);
- dt = Timestamp(val);
- }
-
- void convert(LocalDateTime& ldt) const
- {
- Int64 val;
- convertUnsignedToSigned(_val, val);
- ldt = Timestamp(val);
- }
-
- void convert(Timestamp& val) const
- {
- Int64 tmp;
- convertUnsignedToSigned(_val, tmp);
- val = Timestamp(tmp);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const UInt64& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return std::numeric_limits<UInt64>::is_integer;
- }
-
- bool isSigned() const
- {
- return std::numeric_limits<UInt64>::is_signed;
- }
-
- bool isNumeric() const
- {
- return std::numeric_limits<UInt64>::is_specialized;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- UInt64 _val;
-};
-
-
-template <>
-class VarHolderImpl<bool>: public VarHolder
-{
-public:
- VarHolderImpl(bool val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(bool);
- }
-
- void convert(Int8& val) const
- {
- val = static_cast<Int8>(_val ? 1 : 0);
- }
-
- void convert(Int16& val) const
- {
- val = static_cast<Int16>(_val ? 1 : 0);
- }
-
- void convert(Int32& val) const
- {
- val = static_cast<Int32>(_val ? 1 : 0);
- }
-
- void convert(Int64& val) const
- {
- val = static_cast<Int64>(_val ? 1 : 0);
- }
-
- void convert(UInt8& val) const
- {
- val = static_cast<UInt8>(_val ? 1 : 0);
- }
-
- void convert(UInt16& val) const
- {
- val = static_cast<UInt16>(_val ? 1 : 0);
- }
-
- void convert(UInt32& val) const
- {
- val = static_cast<UInt32>(_val ? 1 : 0);
- }
-
- void convert(UInt64& val) const
- {
- val = static_cast<UInt64>(_val ? 1 : 0);
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- val = static_cast<long long>(_val ? 1 : 0);
- }
-
- void convert(unsigned long long& val) const
- {
- val = static_cast<unsigned long long>(_val ? 1 : 0);
- }
-
-#endif
-
- void convert(bool& val) const
- {
- val = _val;
- }
-
- void convert(float& val) const
- {
- val = (_val ? 1.0f : 0.0f);
- }
-
- void convert(double& val) const
- {
- val = (_val ? 1.0 : 0.0);
- }
-
- void convert(char& val) const
- {
- val = static_cast<char>(_val ? 1 : 0);
- }
-
- void convert(std::string& val) const
- {
- val = (_val ? "true" : "false");
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const bool& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return std::numeric_limits<bool>::is_integer;
- }
-
- bool isSigned() const
- {
- return std::numeric_limits<bool>::is_signed;
- }
-
- bool isNumeric() const
- {
- return std::numeric_limits<bool>::is_specialized;
- }
-
- bool isBoolean() const
- {
- return true;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- bool _val;
-};
-
-
-template <>
-class VarHolderImpl<float>: public VarHolder
-{
-public:
- VarHolderImpl(float val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(float);
- }
-
- void convert(Int8& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int16& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int32& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int64& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(UInt8& val) const
- {
- convertSignedFloatToUnsigned(_val, val);
- }
-
- void convert(UInt16& val) const
- {
- convertSignedFloatToUnsigned(_val, val);
- }
-
- void convert(UInt32& val) const
- {
- convertSignedFloatToUnsigned(_val, val);
- }
-
- void convert(UInt64& val) const
- {
- convertSignedFloatToUnsigned(_val, val);
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(unsigned long long& val) const
- {
- convertSignedFloatToUnsigned(_val, val);
- }
-
-#endif
-
- void convert(bool& val) const
- {
- val = !(_val <= std::numeric_limits<float>::min() &&
- _val >= -1 * std::numeric_limits<float>::min());
- }
-
- void convert(float& val) const
- {
- val = _val;
- }
-
- void convert(double& val) const
- {
- val = _val;
- }
-
- void convert(char& val) const
- {
- UInt8 tmp;
- convert(tmp);
- val = static_cast<char>(tmp);
- }
-
- void convert(std::string& val) const
- {
- val = NumberFormatter::format(_val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const float& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return std::numeric_limits<float>::is_integer;
- }
-
- bool isSigned() const
- {
- return std::numeric_limits<float>::is_signed;
- }
-
- bool isNumeric() const
- {
- return std::numeric_limits<float>::is_specialized;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- float _val;
-};
-
-
-template <>
-class VarHolderImpl<double>: public VarHolder
-{
-public:
- VarHolderImpl(double val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(double);
- }
-
- void convert(Int8& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int16& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int32& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int64& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(UInt8& val) const
- {
- convertSignedFloatToUnsigned(_val, val);
- }
-
- void convert(UInt16& val) const
- {
- convertSignedFloatToUnsigned(_val, val);
- }
-
- void convert(UInt32& val) const
- {
- convertSignedFloatToUnsigned(_val, val);
- }
-
- void convert(UInt64& val) const
- {
- convertSignedFloatToUnsigned(_val, val);
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(unsigned long long& val) const
- {
- convertSignedFloatToUnsigned(_val, val);
- }
-
-#endif
-
- void convert(bool& val) const
- {
- val = !(_val <= std::numeric_limits<double>::min() &&
- _val >= -1 * std::numeric_limits<double>::min());
- }
-
- void convert(float& val) const
- {
- double fMin = -1 * std::numeric_limits<float>::max();
- double fMax = std::numeric_limits<float>::max();
-
- if (_val < fMin) throw RangeException("Value too small.");
- if (_val > fMax) throw RangeException("Value too large.");
-
- val = static_cast<float>(_val);
- }
-
- void convert(double& val) const
- {
- val = _val;
- }
-
- void convert(char& val) const
- {
- UInt8 tmp;
- convert(tmp);
- val = static_cast<char>(tmp);
- }
-
- void convert(std::string& val) const
- {
- val = NumberFormatter::format(_val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const double& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return std::numeric_limits<double>::is_integer;
- }
-
- bool isSigned() const
- {
- return std::numeric_limits<double>::is_signed;
- }
-
- bool isNumeric() const
- {
- return std::numeric_limits<double>::is_specialized;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- double _val;
-};
-
-
-template <>
-class VarHolderImpl<char>: public VarHolder
-{
-public:
- VarHolderImpl(char val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(char);
- }
-
- void convert(Int8& val) const
- {
- val = static_cast<Int8>(_val);
- }
-
- void convert(Int16& val) const
- {
- val = static_cast<UInt8>(_val);
- }
-
- void convert(Int32& val) const
- {
- val = static_cast<UInt8>(_val);
- }
-
- void convert(Int64& val) const
- {
- val = static_cast<UInt8>(_val);
- }
-
- void convert(UInt8& val) const
- {
- val = static_cast<UInt8>(_val);
- }
-
- void convert(UInt16& val) const
- {
- val = static_cast<UInt8>(_val);
- }
-
- void convert(UInt32& val) const
- {
- val = static_cast<UInt8>(_val);
- }
-
- void convert(UInt64& val) const
- {
- val = static_cast<UInt8>(_val);
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- val = static_cast<long long>(_val);
- }
-
- void convert(unsigned long long& val) const
- {
- val = static_cast<unsigned long long>(_val);
- }
-
-#endif
-
- void convert(bool& val) const
- {
- val = (_val != '\0');
- }
-
- void convert(float& val) const
- {
- val = static_cast<float>(_val);
- }
-
- void convert(double& val) const
- {
- val = static_cast<double>(_val);
- }
-
- void convert(char& val) const
- {
- val = _val;
- }
-
- void convert(std::string& val) const
- {
- val = std::string(1, _val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const char& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return std::numeric_limits<char>::is_integer;
- }
-
- bool isSigned() const
- {
- return std::numeric_limits<char>::is_signed;
- }
-
- bool isNumeric() const
- {
- return std::numeric_limits<char>::is_specialized;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- char _val;
-};
-
-
-template <>
-class VarHolderImpl<std::string>: public VarHolder
-{
-public:
- VarHolderImpl(const char* pVal): _val(pVal)
- {
- }
-
- VarHolderImpl(const std::string& val) : _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(std::string);
- }
-
- void convert(Int8& val) const
- {
- int v = NumberParser::parse(_val);
- convertToSmaller(v, val);
- }
-
- void convert(Int16& val) const
- {
- int v = NumberParser::parse(_val);
- convertToSmaller(v, val);
- }
-
- void convert(Int32& val) const
- {
- val = NumberParser::parse(_val);
- }
-
- void convert(Int64& val) const
- {
- val = NumberParser::parse64(_val);
- }
-
- void convert(UInt8& val) const
- {
- unsigned int v = NumberParser::parseUnsigned(_val);
- convertToSmallerUnsigned(v, val);
- }
-
- void convert(UInt16& val) const
- {
- unsigned int v = NumberParser::parseUnsigned(_val);
- convertToSmallerUnsigned(v, val);
- }
-
- void convert(UInt32& val) const
- {
- val = NumberParser::parseUnsigned(_val);
- }
-
- void convert(UInt64& val) const
- {
- val = NumberParser::parseUnsigned64(_val);
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- val = NumberParser::parse64(_val);
- }
-
- void convert(unsigned long long& val) const
- {
- val = NumberParser::parseUnsigned64(_val);
- }
-
-#endif
-
- void convert(bool& val) const
- {
- if (_val.empty())
- {
- val = false;
- return;
- }
-
- static const std::string VAL_FALSE("false");
- static const std::string VAL_INT_FALSE("0");
- val = (_val != VAL_INT_FALSE &&
- (icompare(_val, VAL_FALSE) != 0));
- }
-
- void convert(float& val) const
- {
- double v = NumberParser::parseFloat(_val);
- convertToSmaller(v, val);
- }
-
- void convert(double& val) const
- {
- val = NumberParser::parseFloat(_val);
- }
-
- void convert(char& val) const
- {
- if (_val.empty())
- val = '\0';
- else
- val = _val[0];
- }
-
- void convert(std::string& val) const
- {
- val = _val;
- }
-
- void convert(Poco::UTF16String& val) const
- {
- Poco::UnicodeConverter::convert(_val, val);
- }
-
- void convert(DateTime& val) const
- {
- int tzd = 0;
- if (!DateTimeParser::tryParse(DateTimeFormat::ISO8601_FORMAT, _val, val, tzd))
- throw BadCastException("string -> DateTime");
- }
-
- void convert(LocalDateTime& ldt) const
- {
- int tzd = 0;
- DateTime tmp;
- if (!DateTimeParser::tryParse(DateTimeFormat::ISO8601_FORMAT, _val, tmp, tzd))
- throw BadCastException("string -> LocalDateTime");
-
- ldt = LocalDateTime(tzd, tmp, false);
- }
-
- void convert(Timestamp& ts) const
- {
- int tzd = 0;
- DateTime tmp;
- if (!DateTimeParser::tryParse(DateTimeFormat::ISO8601_FORMAT, _val, tmp, tzd))
- throw BadCastException("string -> Timestamp");
-
- ts = tmp.timestamp();
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const std:: string& value() const
- {
- return _val;
- }
-
- bool isString() const
- {
- return true;
- }
-
- std::size_t size() const
- {
- return _val.length();
- }
-
- char& operator[](std::string::size_type n)
- {
- if (n < size()) return _val.operator[](n);
-
- throw RangeException("String index out of range");
- }
-
- const char& operator[](std::string::size_type n) const
- {
- if (n < size()) return _val.operator[](n);
-
- throw RangeException("String index out of range");
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- std::string _val;
-};
-
-
-template <>
-class VarHolderImpl<UTF16String>: public VarHolder
-{
-public:
- VarHolderImpl(const char* pVal) : _val(Poco::UnicodeConverter::to<UTF16String>(pVal))
- {
- }
-
- VarHolderImpl(const Poco::UTF16String& val) : _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(Poco::UTF16String);
- }
-
- void convert(Int8& val) const
- {
- int v = NumberParser::parse(toStdString());
- convertToSmaller(v, val);
- }
-
- void convert(Int16& val) const
- {
- int v = NumberParser::parse(toStdString());
- convertToSmaller(v, val);
- }
-
- void convert(Int32& val) const
- {
- val = NumberParser::parse(toStdString());
- }
-
- void convert(Int64& val) const
- {
- val = NumberParser::parse64(toStdString());
- }
-
- void convert(UInt8& val) const
- {
- unsigned int v = NumberParser::parseUnsigned(toStdString());
- convertToSmallerUnsigned(v, val);
- }
-
- void convert(UInt16& val) const
- {
- unsigned int v = NumberParser::parseUnsigned(toStdString());
- convertToSmallerUnsigned(v, val);
- }
-
- void convert(UInt32& val) const
- {
- val = NumberParser::parseUnsigned(toStdString());
- }
-
- void convert(UInt64& val) const
- {
- val = NumberParser::parseUnsigned64(toStdString());
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- val = NumberParser::parse64(toStdString());
- }
-
- void convert(unsigned long long& val) const
- {
- val = NumberParser::parseUnsigned64(toStdString());
- }
-
-#endif
-
- void convert(bool& val) const
- {
- static const std::string VAL_FALSE("false");
- static const std::string VAL_INT_FALSE("0");
-
- if (_val.empty()) val = false;
-
- std::string str;
- UnicodeConverter::convert(_val, str);
- val = (str != VAL_INT_FALSE &&
- (icompare(str, VAL_FALSE) != 0));
- }
-
- void convert(float& val) const
- {
- double v = NumberParser::parseFloat(toStdString());
- convertToSmaller(v, val);
- }
-
- void convert(double& val) const
- {
- val = NumberParser::parseFloat(toStdString());
- }
-
- void convert(char& val) const
- {
- if (_val.empty())
- val = '\0';
- else
- {
- std::string s;
- UnicodeConverter::convert(_val, s);
- val = s[0];
- }
- }
-
- void convert(Poco::UTF16String& val) const
- {
- val = _val;
- }
-
- void convert(std::string& val) const
- {
- UnicodeConverter::convert(_val, val);
- }
-
- void convert(DateTime& val) const
- {
- int tzd = 0;
- if (!DateTimeParser::tryParse(DateTimeFormat::ISO8601_FORMAT, toStdString(), val, tzd))
- throw BadCastException("string -> DateTime");
- }
-
- void convert(LocalDateTime& ldt) const
- {
- int tzd = 0;
- DateTime tmp;
- if (!DateTimeParser::tryParse(DateTimeFormat::ISO8601_FORMAT, toStdString(), tmp, tzd))
- throw BadCastException("string -> LocalDateTime");
-
- ldt = LocalDateTime(tzd, tmp, false);
- }
-
- void convert(Timestamp& ts) const
- {
- int tzd = 0;
- DateTime tmp;
- if (!DateTimeParser::tryParse(DateTimeFormat::ISO8601_FORMAT, toStdString(), tmp, tzd))
- throw BadCastException("string -> Timestamp");
-
- ts = tmp.timestamp();
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const Poco::UTF16String& value() const
- {
- return _val;
- }
-
- bool isString() const
- {
- return true;
- }
-
- std::size_t size() const
- {
- return _val.length();
- }
-
- UTF16Char& operator[](Poco::UTF16String::size_type n)
- {
- if (n < size()) return _val.operator[](n);
-
- throw RangeException("String index out of range");
- }
-
- const UTF16Char& operator[](Poco::UTF16String::size_type n) const
- {
- if (n < size()) return _val.operator[](n);
-
- throw RangeException("String index out of range");
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- std::string toStdString() const
- {
- std::string str;
- UnicodeConverter::convert(_val, str);
- return str;
- }
-
- Poco::UTF16String _val;
-};
-
-
-#ifndef POCO_LONG_IS_64_BIT
-
-
-template <>
-class VarHolderImpl<long>: public VarHolder
-{
-public:
- VarHolderImpl(long val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(long);
- }
-
- void convert(Int8& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int16& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int32& val) const
- {
- val = static_cast<Int32>(_val);
- }
-
- void convert(Int64& val) const
- {
- val = static_cast<Int64>(_val);
- }
-
- void convert(UInt8& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt16& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt32& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt64& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(bool& val) const
- {
- val = (_val != 0);
- }
-
- void convert(float& val) const
- {
- val = static_cast<float>(_val);
- }
-
- void convert(double& val) const
- {
- val = static_cast<double>(_val);
- }
-
- void convert(char& val) const
- {
- UInt8 tmp;
- convert(tmp);
- val = static_cast<char>(tmp);
- }
-
- void convert(std::string& val) const
- {
- val = NumberFormatter::format(_val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const long& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return std::numeric_limits<long>::is_integer;
- }
-
- bool isSigned() const
- {
- return std::numeric_limits<long>::is_signed;
- }
-
- bool isNumeric() const
- {
- return std::numeric_limits<long>::is_specialized;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- long _val;
-};
-
-
-template <>
-class VarHolderImpl<unsigned long>: public VarHolder
-{
-public:
- VarHolderImpl(unsigned long val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(unsigned long);
- }
-
- void convert(Int8& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int16& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int32& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int64& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(UInt8& val) const
- {
- convertToSmallerUnsigned(_val, val);
- }
-
- void convert(UInt16& val) const
- {
- convertToSmallerUnsigned(_val, val);
- }
-
- void convert(UInt32& val) const
- {
- convertToSmallerUnsigned(_val, val);
- }
-
- void convert(UInt64& val) const
- {
- val = static_cast<UInt64>(_val);
- }
-
- void convert(bool& val) const
- {
- val = (_val != 0);
- }
-
- void convert(float& val) const
- {
- val = static_cast<float>(_val);
- }
-
- void convert(double& val) const
- {
- val = static_cast<double>(_val);
- }
-
- void convert(char& val) const
- {
- UInt8 tmp;
- convert(tmp);
- val = static_cast<char>(tmp);
- }
-
- void convert(std::string& val) const
- {
- val = NumberFormatter::format(_val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const unsigned long& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return std::numeric_limits<unsigned long>::is_integer;
- }
-
- bool isSigned() const
- {
- return std::numeric_limits<unsigned long>::is_signed;
- }
-
- bool isNumeric() const
- {
- return std::numeric_limits<unsigned long>::is_specialized;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- unsigned long _val;
-};
-
-
-#else // if defined (POCO_LONG_IS_64_BIT)
-
-
-template <>
-class VarHolderImpl<long long>: public VarHolder
-{
-public:
- VarHolderImpl(long long val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(long long);
- }
-
- void convert(Int8& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int16& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int32& val) const
- {
- convertToSmaller(_val, val);
- }
-
- void convert(Int64& val) const
- {
- val = static_cast<Int64>(_val);
- }
-
- void convert(UInt8& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt16& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt32& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(UInt64& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(long long& val) const
- {
- val = _val;
- }
-
- void convert(unsigned long long& val) const
- {
- convertSignedToUnsigned(_val, val);
- }
-
- void convert(bool& val) const
- {
- val = (_val != 0);
- }
-
- void convert(float& val) const
- {
- val = static_cast<float>(_val);
- }
-
- void convert(double& val) const
- {
- val = static_cast<double>(_val);
- }
-
- void convert(char& val) const
- {
- UInt8 tmp;
- convert(tmp);
- val = static_cast<char>(tmp);
- }
-
- void convert(std::string& val) const
- {
- val = NumberFormatter::format(_val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const long long& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return std::numeric_limits<long long>::is_integer;
- }
-
- bool isSigned() const
- {
- return std::numeric_limits<long long>::is_signed;
- }
-
- bool isNumeric() const
- {
- return std::numeric_limits<long long>::is_specialized;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- long long _val;
-};
-
-
-template <>
-class VarHolderImpl<unsigned long long>: public VarHolder
-{
-public:
- VarHolderImpl(unsigned long long val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(unsigned long long);
- }
-
- void convert(Int8& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int16& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int32& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(Int64& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(UInt8& val) const
- {
- convertToSmallerUnsigned(_val, val);
- }
-
- void convert(UInt16& val) const
- {
- convertToSmallerUnsigned(_val, val);
- }
-
- void convert(UInt32& val) const
- {
- convertToSmallerUnsigned(_val, val);
- }
-
- void convert(UInt64& val) const
- {
- val = static_cast<UInt64>(_val);
- }
-
- void convert(long long& val) const
- {
- convertUnsignedToSigned(_val, val);
- }
-
- void convert(unsigned long long& val) const
- {
- val = _val;
- }
-
- void convert(bool& val) const
- {
- val = (_val != 0);
- }
-
- void convert(float& val) const
- {
- val = static_cast<float>(_val);
- }
-
- void convert(double& val) const
- {
- val = static_cast<double>(_val);
- }
-
- void convert(char& val) const
- {
- UInt8 tmp;
- convert(tmp);
- val = static_cast<char>(tmp);
- }
-
- void convert(std::string& val) const
- {
- val = NumberFormatter::format(_val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const unsigned long long& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return std::numeric_limits<unsigned long long>::is_integer;
- }
-
- bool isSigned() const
- {
- return std::numeric_limits<unsigned long long>::is_signed;
- }
-
- bool isNumeric() const
- {
- return std::numeric_limits<unsigned long long>::is_specialized;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- unsigned long long _val;
-};
-
-
-#endif // 64bit
-
-
-template <typename T>
-class VarHolderImpl<std::vector<T> >: public VarHolder
-{
-public:
- VarHolderImpl(const std::vector<T>& val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(std::vector<T>);
- }
-
- void convert(std::string& val) const
- {
- Impl::containerToJSON(_val, val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const std::vector<T>& value() const
- {
- return _val;
- }
-
- bool isVector() const
- {
- return true;
- }
-
- std::size_t size() const
- {
- return _val.size();
- }
-
- T& operator[](typename std::vector<T>::size_type n)
- {
- if (n < size()) return _val.operator[](n);
-
- throw RangeException("List index out of range");
- }
-
- const T& operator[](typename std::vector<T>::size_type n) const
- {
- if (n < size()) return _val.operator[](n);
-
- throw RangeException("List index out of range");
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- std::vector<T> _val;
-};
-
-
-template <typename T>
-class VarHolderImpl<std::list<T> >: public VarHolder
-{
-public:
- VarHolderImpl(const std::list<T>& val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(std::list<T>);
- }
-
- void convert(std::string& val) const
- {
- Impl::containerToJSON(_val, val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const std::list<T>& value() const
- {
- return _val;
- }
-
- bool isList() const
- {
- return true;
- }
-
- std::size_t size() const
- {
- return _val.size();
- }
-
- T& operator[](typename std::list<T>::size_type n)
- {
- if (n >= size())
- throw RangeException("List index out of range");
-
- typename std::list<T>::size_type counter = 0;
- typename std::list<T>::iterator it = _val.begin();
- for (; counter < n; ++counter) ++it;
-
- return *it;
- }
-
- const T& operator[](typename std::list<T>::size_type n) const
- {
- if (n >= size())
- throw RangeException("List index out of range");
-
- typename std::list<T>::size_type counter = 0;
- typename std::list<T>::const_iterator it = _val.begin();
- for (; counter < n; ++counter) ++it;
-
- return *it;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- std::list<T> _val;
-};
-
-
-template <typename T>
-class VarHolderImpl<std::deque<T> >: public VarHolder
-{
-public:
- VarHolderImpl(const std::deque<T>& val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(std::deque<T>);
- }
-
- void convert(std::string& val) const
- {
- Impl::containerToJSON(_val, val);
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const std::deque<T>& value() const
- {
- return _val;
- }
-
- bool isDeque() const
- {
- return true;
- }
-
- std::size_t size() const
- {
- return _val.size();
- }
-
- T& operator[](typename std::deque<T>::size_type n)
- {
- if (n < size()) return _val.operator[](n);
-
- throw RangeException("List index out of range");
- }
-
- const T& operator[](typename std::deque<T>::size_type n) const
- {
- if (n < size()) return _val.operator[](n);
-
- throw RangeException("List index out of range");
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- std::deque<T> _val;
-};
-
-
-template <>
-class VarHolderImpl<DateTime>: public VarHolder
-{
-public:
- VarHolderImpl(const DateTime& val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(DateTime);
- }
-
- void convert(Int8& /*val*/) const
- {
- throw BadCastException();
- }
-
- void convert(Int16& /*val*/) const
- {
- throw BadCastException();
- }
-
- void convert(Int32& /*val*/) const
- {
- throw BadCastException();
- }
-
- void convert(Int64& val) const
- {
- val = _val.timestamp().epochMicroseconds();
- }
-
- void convert(UInt64& val) const
- {
- val = _val.timestamp().epochMicroseconds();
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- val = _val.timestamp().epochMicroseconds();
- }
-
- void convert(unsigned long long& val) const
- {
- val = _val.timestamp().epochMicroseconds();
- }
-
-#endif
-
- void convert(std::string& val) const
- {
- val = DateTimeFormatter::format(_val, Poco::DateTimeFormat::ISO8601_FORMAT);
- }
-
- void convert(DateTime& val) const
- {
- val = _val;
- }
-
- void convert(LocalDateTime& ldt) const
- {
- ldt = _val.timestamp();
- }
-
- void convert(Timestamp& ts) const
- {
- ts = _val.timestamp();
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const DateTime& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return false;
- }
-
- bool isSigned() const
- {
- return false;
- }
-
- bool isNumeric() const
- {
- return false;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
- bool isDate() const
- {
- return true;
- }
-
- bool isTime() const
- {
- return true;
- }
-
- bool isDateTime() const
- {
- return true;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- DateTime _val;
-};
-
-
-template <>
-class VarHolderImpl<LocalDateTime>: public VarHolder
-{
-public:
- VarHolderImpl(const LocalDateTime& val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(LocalDateTime);
- }
-
- void convert(Int64& val) const
- {
- val = _val.timestamp().epochMicroseconds();
- }
-
- void convert(UInt64& val) const
- {
- val = _val.timestamp().epochMicroseconds();
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- val = _val.timestamp().epochMicroseconds();
- }
-
- void convert(unsigned long long& val) const
- {
- val = _val.timestamp().epochMicroseconds();
- }
-
-#endif
-
- void convert(std::string& val) const
- {
- val = DateTimeFormatter::format(_val, Poco::DateTimeFormat::ISO8601_FORMAT);
- }
-
- void convert(DateTime& val) const
- {
- val = _val.timestamp();
- }
-
- void convert(LocalDateTime& ldt) const
- {
- ldt = _val;
- }
-
- void convert(Timestamp& ts) const
- {
- ts = _val.timestamp();
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const LocalDateTime& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return false;
- }
-
- bool isSigned() const
- {
- return false;
- }
-
- bool isNumeric() const
- {
- return false;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
- bool isDate() const
- {
- return true;
- }
-
- bool isTime() const
- {
- return true;
- }
-
- bool isDateTime() const
- {
- return true;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- LocalDateTime _val;
-};
-
-
-template <>
-class VarHolderImpl<Timestamp>: public VarHolder
-{
-public:
- VarHolderImpl(const Timestamp& val): _val(val)
- {
- }
-
- ~VarHolderImpl()
- {
- }
-
- const std::type_info& type() const
- {
- return typeid(Timestamp);
- }
-
- void convert(Int64& val) const
- {
- val = _val.epochMicroseconds();
- }
-
- void convert(UInt64& val) const
- {
- val = _val.epochMicroseconds();
- }
-
-#ifdef POCO_LONG_IS_64_BIT
-
- void convert(long long& val) const
- {
- val = _val.epochMicroseconds();
- }
-
- void convert(unsigned long long& val) const
- {
- val = _val.epochMicroseconds();
- }
-
-#endif
-
- void convert(std::string& val) const
- {
- val = DateTimeFormatter::format(_val, Poco::DateTimeFormat::ISO8601_FORMAT);
- }
-
- void convert(DateTime& val) const
- {
- val = _val;
- }
-
- void convert(LocalDateTime& ldt) const
- {
- ldt = _val;
- }
-
- void convert(Timestamp& ts) const
- {
- ts = _val;
- }
-
- VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
- {
- return cloneHolder(pVarHolder, _val);
- }
-
- const Timestamp& value() const
- {
- return _val;
- }
-
- bool isArray() const
- {
- return false;
- }
-
- bool isStruct() const
- {
- return false;
- }
-
- bool isInteger() const
- {
- return false;
- }
-
- bool isSigned() const
- {
- return false;
- }
-
- bool isNumeric() const
- {
- return false;
- }
-
- bool isBoolean() const
- {
- return false;
- }
-
- bool isString() const
- {
- return false;
- }
-
- bool isDate() const
- {
- return true;
- }
-
- bool isTime() const
- {
- return true;
- }
-
- bool isDateTime() const
- {
- return true;
- }
-
-private:
- VarHolderImpl();
- VarHolderImpl(const VarHolderImpl&);
- VarHolderImpl& operator = (const VarHolderImpl&);
-
- Timestamp _val;
-};
-
-
-typedef std::vector<Var> Vector;
-typedef std::deque<Var> Deque;
-typedef std::list<Var> List;
-typedef Vector Array;
-
-
-} } // namespace Poco::Dynamic
-
-
-#endif // Foundation_VarHolder_INCLUDED
+ to = static_cast<T>(from);
+ }
+
+private:
+
+#ifdef _MSC_VER
+#pragma warning( push )
+#pragma warning( disable : 4127 )
+#pragma warning( disable : 4018 )
+#endif
+
+ template <typename F, typename T>
+ void checkUpperLimit(const F& from) const
+ {
+ // casting to type of smaller size AND
+ // 'from' is greater than 'T' max value
+ if ((sizeof(T) < sizeof(F)) &&
+ (from > static_cast<F>(std::numeric_limits<T>::max())))
+ {
+ throw RangeException("Value too large.");
+ }
+ // casting to type of equal/bigger size AND
+ // 'F' is signed AND
+ // 'T' is unsigned AND
+ // 'from' is negative
+ else if (std::numeric_limits<F>::is_signed &&
+ !std::numeric_limits<T>::is_signed && from < 0)
+ {
+ throw RangeException("Value too small.");
+ }
+ // casting to type of equal/bigger size AND
+ // 'F' is unsigned AND
+ // 'T' is signed AND
+ // 'from' is greater than 'T' max value
+ else if (!std::numeric_limits<F>::is_signed &&
+ std::numeric_limits<T>::is_signed &&
+ static_cast<Poco::UInt64>(from) > std::numeric_limits<T>::max())
+ {
+ throw RangeException("Value too large.");
+ }
+ }
+
+#ifdef _MSC_VER
+#pragma warning( pop )
+#endif
+
+ template <typename F, typename T>
+ void checkUpperLimitFloat(const F& from) const
+ {
+ if (from > std::numeric_limits<T>::max())
+ throw RangeException("Value too large.");
+ }
+
+ template <typename F, typename T>
+ void checkLowerLimitFloat(const F& from) const
+ {
+ if (from < -std::numeric_limits<T>::max())
+ throw RangeException("Value too small.");
+ }
+
+ template <typename F, typename T>
+ void checkLowerLimit(const F& from) const
+ {
+ if (from < std::numeric_limits<T>::min())
+ throw RangeException("Value too small.");
+ }
+};
+
+
+//
+// inlines
+//
+
+
+inline void VarHolder::convert(Int8& /*val*/) const
+{
+ throw BadCastException("Can not convert to Int8");
+}
+
+
+inline void VarHolder::convert(Int16& /*val*/) const
+{
+ throw BadCastException("Can not convert to Int16");
+}
+
+
+inline void VarHolder::convert(Int32& /*val*/) const
+{
+ throw BadCastException("Can not convert to Int32");
+}
+
+
+inline void VarHolder::convert(Int64& /*val*/) const
+{
+ throw BadCastException("Can not convert to Int64");
+}
+
+
+inline void VarHolder::convert(UInt8& /*val*/) const
+{
+ throw BadCastException("Can not convert to UInt8");
+}
+
+
+inline void VarHolder::convert(UInt16& /*val*/) const
+{
+ throw BadCastException("Can not convert to UInt16");
+}
+
+
+inline void VarHolder::convert(UInt32& /*val*/) const
+{
+ throw BadCastException("Can not convert to UInt32");
+}
+
+
+inline void VarHolder::convert(UInt64& /*val*/) const
+{
+ throw BadCastException("Can not convert to UInt64");
+}
+
+
+inline void VarHolder::convert(DateTime& /*val*/) const
+{
+ throw BadCastException("Can not convert to DateTime");
+}
+
+
+inline void VarHolder::convert(LocalDateTime& /*val*/) const
+{
+ throw BadCastException("Can not convert to LocalDateTime");
+}
+
+
+inline void VarHolder::convert(Timestamp& /*val*/) const
+{
+ throw BadCastException("Can not convert to Timestamp");
+}
+
+#ifndef POCO_LONG_IS_64_BIT
+
+inline void VarHolder::convert(long& val) const
+{
+ Int32 tmp;
+ convert(tmp);
+ val = tmp;
+}
+
+
+inline void VarHolder::convert(unsigned long& val) const
+{
+ UInt32 tmp;
+ convert(tmp);
+ val = tmp;
+}
+
+#else
+
+inline void VarHolder::convert(long long& /*val*/) const
+{
+ throw BadCastException("Can not convert to long long");
+}
+
+
+inline void VarHolder::convert(unsigned long long& /*val*/) const
+{
+ throw BadCastException("Can not convert to unsigned long long");
+}
+
+#endif
+
+inline void VarHolder::convert(bool& /*val*/) const
+{
+ throw BadCastException("Can not convert to bool");
+}
+
+
+inline void VarHolder::convert(float& /*val*/) const
+{
+ throw BadCastException("Can not convert to float");
+}
+
+
+inline void VarHolder::convert(double& /*val*/) const
+{
+ throw BadCastException("Can not convert to double");
+}
+
+
+inline void VarHolder::convert(char& /*val*/) const
+{
+ throw BadCastException("Can not convert to char");
+}
+
+
+inline void VarHolder::convert(std::string& /*val*/) const
+{
+ throw BadCastException("Can not convert to std::string");
+}
+
+
+inline void VarHolder::convert(Poco::UTF16String& /*val*/) const
+{
+ throw BadCastException("Can not convert to Poco::UTF16String");
+}
+
+
+inline bool VarHolder::isArray() const
+{
+ return true;
+}
+
+
+inline bool VarHolder::isVector() const
+{
+ return false;
+}
+
+
+inline bool VarHolder::isList() const
+{
+ return false;
+}
+
+
+inline bool VarHolder::isDeque() const
+{
+ return false;
+}
+
+
+inline bool VarHolder::isStruct() const
+{
+ return false;
+}
+
+inline bool VarHolder::isInteger() const
+{
+ return false;
+}
+
+
+inline bool VarHolder::isSigned() const
+{
+ return false;
+}
+
+
+inline bool VarHolder::isNumeric() const
+{
+ return false;
+}
+
+
+inline bool VarHolder::isBoolean() const
+{
+ return false;
+}
+
+
+inline bool VarHolder::isString() const
+{
+ return false;
+}
+
+
+inline bool VarHolder::isDate() const
+{
+ return false;
+}
+
+
+inline bool VarHolder::isTime() const
+{
+ return false;
+}
+
+
+inline bool VarHolder::isDateTime() const
+{
+ return false;
+}
+
+inline std::size_t VarHolder::size() const
+{
+ return 1u;
+}
+
+
+template <typename T>
+class VarHolderImpl: public VarHolder
+ /// Template based implementation of a VarHolder.
+ /// This class provides type storage for user-defined types
+ /// that do not have VarHolderImpl specialization.
+ ///
+ /// The actual conversion work happens in the template specializations
+ /// of this class.
+ ///
+ /// VarHolderImpl throws following exceptions:
+ /// BadCastException (if the requested conversion is not implemented)
+ /// RangeException (if an attempt is made to assign a numeric value outside of the target min/max limits
+ /// SyntaxException (if an attempt is made to convert a string containing non-numeric characters to number)
+ ///
+ /// In order to support efficient direct extraction of the held value,
+ /// all specializations must additionally implement a public member function:
+ ///
+ /// const T& value() const
+ ///
+ /// returning a const reference to the actual stored value.
+{
+public:
+ VarHolderImpl(const T& val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(T);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const T& value() const
+ {
+ return _val;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ T _val;
+};
+
+
+template <>
+class VarHolderImpl<Int8>: public VarHolder
+{
+public:
+ VarHolderImpl(Int8 val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(Int8);
+ }
+
+ void convert(Int8& val) const
+ {
+ val = _val;
+ }
+
+ void convert(Int16& val) const
+ {
+ val = _val;
+ }
+
+ void convert(Int32& val) const
+ {
+ val = _val;
+ }
+
+ void convert(Int64& val) const
+ {
+ val = _val;
+ }
+
+ void convert(UInt8& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt16& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt32& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt64& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ val = _val;
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+#endif
+
+ void convert(bool& val) const
+ {
+ val = (_val != 0);
+ }
+
+ void convert(float& val) const
+ {
+ val = static_cast<float>(_val);
+ }
+
+ void convert(double& val) const
+ {
+ val = static_cast<double>(_val);
+ }
+
+ void convert(char& val) const
+ {
+ val = static_cast<char>(_val);
+ }
+
+ void convert(std::string& val) const
+ {
+ val = NumberFormatter::format(_val);
+ }
+
+ void convert(Poco::UTF16String& val) const
+ {
+ std::string str = NumberFormatter::format(_val);
+ Poco::UnicodeConverter::convert(str, val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const Int8& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return std::numeric_limits<Int8>::is_integer;
+ }
+
+ bool isSigned() const
+ {
+ return std::numeric_limits<Int8>::is_signed;
+ }
+
+ bool isNumeric() const
+ {
+ return std::numeric_limits<Int8>::is_specialized;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ Int8 _val;
+};
+
+
+template <>
+class VarHolderImpl<Int16>: public VarHolder
+{
+public:
+ VarHolderImpl(Int16 val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(Int16);
+ }
+
+ void convert(Int8& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int16& val) const
+ {
+ val = _val;
+ }
+
+ void convert(Int32& val) const
+ {
+ val = _val;
+ }
+
+ void convert(Int64& val) const
+ {
+ val = _val;
+ }
+
+ void convert(UInt8& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt16& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt32& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt64& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ val = _val;
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+#endif
+
+ void convert(bool& val) const
+ {
+ val = (_val != 0);
+ }
+
+ void convert(float& val) const
+ {
+ val = static_cast<float>(_val);
+ }
+
+ void convert(double& val) const
+ {
+ val = static_cast<double>(_val);
+ }
+
+ void convert(char& val) const
+ {
+ UInt8 tmp;
+ convert(tmp);
+ val = static_cast<char>(tmp);
+ }
+
+ void convert(std::string& val) const
+ {
+ val = NumberFormatter::format(_val);
+ }
+
+ void convert(Poco::UTF16String& val) const
+ {
+ std::string str = NumberFormatter::format(_val);
+ Poco::UnicodeConverter::convert(str, val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const Int16& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return std::numeric_limits<Int16>::is_integer;
+ }
+
+ bool isSigned() const
+ {
+ return std::numeric_limits<Int16>::is_signed;
+ }
+
+ bool isNumeric() const
+ {
+ return std::numeric_limits<Int16>::is_specialized;
+ }
+
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ Int16 _val;
+};
+
+
+template <>
+class VarHolderImpl<Int32>: public VarHolder
+{
+public:
+ VarHolderImpl(Int32 val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(Int32);
+ }
+
+ void convert(Int8& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int16& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int32& val) const
+ {
+ val = _val;
+ }
+
+ void convert(Int64& val) const
+ {
+ val = _val;
+ }
+
+ void convert(UInt8& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt16& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt32& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt64& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ val = _val;
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+#endif
+
+ void convert(bool& val) const
+ {
+ val = (_val != 0);
+ }
+
+ void convert(float& val) const
+ {
+ val = static_cast<float>(_val);
+ }
+
+ void convert(double& val) const
+ {
+ val = static_cast<double>(_val);
+ }
+
+ void convert(char& val) const
+ {
+ UInt8 tmp;
+ convert(tmp);
+ val = static_cast<char>(tmp);
+ }
+
+ void convert(std::string& val) const
+ {
+ val = NumberFormatter::format(_val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const Int32& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return std::numeric_limits<Int32>::is_integer;
+ }
+
+ bool isSigned() const
+ {
+ return std::numeric_limits<Int32>::is_signed;
+ }
+
+ bool isNumeric() const
+ {
+ return std::numeric_limits<Int32>::is_specialized;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ Int32 _val;
+};
+
+
+template <>
+class VarHolderImpl<Int64>: public VarHolder
+{
+public:
+ VarHolderImpl(Int64 val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(Int64);
+ }
+
+ void convert(Int8& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int16& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int32& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int64& val) const
+ {
+ val = _val;
+ }
+
+ void convert(UInt8& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt16& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt32& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt64& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ val = _val;
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+#endif
+
+ void convert(bool& val) const
+ {
+ val = (_val != 0);
+ }
+
+ void convert(float& val) const
+ {
+ val = static_cast<float>(_val);
+ }
+
+ void convert(double& val) const
+ {
+ val = static_cast<double>(_val);
+ }
+
+ void convert(char& val) const
+ {
+ UInt8 tmp;
+ convert(tmp);
+ val = static_cast<char>(tmp);
+ }
+
+ void convert(std::string& val) const
+ {
+ val = NumberFormatter::format(_val);
+ }
+
+ void convert(DateTime& dt) const
+ {
+ dt = Timestamp(_val);
+ }
+
+ void convert(LocalDateTime& ldt) const
+ {
+ ldt = Timestamp(_val);
+ }
+
+ void convert(Timestamp& val) const
+ {
+ val = Timestamp(_val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const Int64& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return std::numeric_limits<Int64>::is_integer;
+ }
+
+ bool isSigned() const
+ {
+ return std::numeric_limits<Int64>::is_signed;
+ }
+
+ bool isNumeric() const
+ {
+ return std::numeric_limits<Int64>::is_specialized;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ Int64 _val;
+};
+
+
+template <>
+class VarHolderImpl<UInt8>: public VarHolder
+{
+public:
+ VarHolderImpl(UInt8 val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(UInt8);
+ }
+
+ void convert(Int8& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int16& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int32& val) const
+ {
+ val = static_cast<Int32>(_val);
+ }
+
+ void convert(Int64& val) const
+ {
+ val = static_cast<Int64>(_val);
+ }
+
+ void convert(UInt8& val) const
+ {
+ val = _val;
+ }
+
+ void convert(UInt16& val) const
+ {
+ val = _val;
+ }
+
+ void convert(UInt32& val) const
+ {
+ val = _val;
+ }
+
+ void convert(UInt64& val) const
+ {
+ val = _val;
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ val = static_cast<long long>(_val);
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ val = _val;
+ }
+
+#endif
+
+ void convert(bool& val) const
+ {
+ val = (_val != 0);
+ }
+
+ void convert(float& val) const
+ {
+ val = static_cast<float>(_val);
+ }
+
+ void convert(double& val) const
+ {
+ val = static_cast<double>(_val);
+ }
+
+ void convert(char& val) const
+ {
+ UInt8 tmp;
+ convert(tmp);
+ val = static_cast<char>(tmp);
+ }
+
+ void convert(std::string& val) const
+ {
+ val = NumberFormatter::format(_val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const UInt8& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return std::numeric_limits<UInt8>::is_integer;
+ }
+
+ bool isSigned() const
+ {
+ return std::numeric_limits<UInt8>::is_signed;
+ }
+
+ bool isNumeric() const
+ {
+ return std::numeric_limits<UInt8>::is_specialized;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ UInt8 _val;
+};
+
+
+template <>
+class VarHolderImpl<UInt16>: public VarHolder
+{
+public:
+ VarHolderImpl(UInt16 val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(UInt16);
+ }
+
+ void convert(Int8& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int16& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int32& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int64& val) const
+ {
+ val = static_cast<Int64>(_val);
+ }
+
+ void convert(UInt8& val) const
+ {
+ convertToSmallerUnsigned(_val, val);
+ }
+
+ void convert(UInt16& val) const
+ {
+ val = _val;
+ }
+
+ void convert(UInt32& val) const
+ {
+ val = _val;
+ }
+
+ void convert(UInt64& val) const
+ {
+ val = _val;
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ val = static_cast<long long>(_val);
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ val = _val;
+ }
+
+#endif
+
+ void convert(bool& val) const
+ {
+ val = (_val != 0);
+ }
+
+ void convert(float& val) const
+ {
+ val = static_cast<float>(_val);
+ }
+
+ void convert(double& val) const
+ {
+ val = static_cast<double>(_val);
+ }
+
+ void convert(char& val) const
+ {
+ UInt8 tmp;
+ convert(tmp);
+ val = static_cast<char>(tmp);
+ }
+
+ void convert(std::string& val) const
+ {
+ val = NumberFormatter::format(_val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const UInt16& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return std::numeric_limits<UInt16>::is_integer;
+ }
+
+ bool isSigned() const
+ {
+ return std::numeric_limits<UInt16>::is_signed;
+ }
+
+ bool isNumeric() const
+ {
+ return std::numeric_limits<UInt16>::is_specialized;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ UInt16 _val;
+};
+
+
+template <>
+class VarHolderImpl<UInt32>: public VarHolder
+{
+public:
+ VarHolderImpl(UInt32 val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(UInt32);
+ }
+
+ void convert(Int8& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int16& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int32& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int64& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(UInt8& val) const
+ {
+ convertToSmallerUnsigned(_val, val);
+ }
+
+ void convert(UInt16& val) const
+ {
+ convertToSmallerUnsigned(_val, val);
+ }
+
+ void convert(UInt32& val) const
+ {
+ val = _val;
+ }
+
+ void convert(UInt64& val) const
+ {
+ val = _val;
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ val = _val;
+ }
+
+#endif
+
+ void convert(bool& val) const
+ {
+ val = (_val != 0);
+ }
+
+ void convert(float& val) const
+ {
+ val = static_cast<float>(_val);
+ }
+
+ void convert(double& val) const
+ {
+ val = static_cast<double>(_val);
+ }
+
+ void convert(char& val) const
+ {
+ UInt8 tmp;
+ convert(tmp);
+ val = static_cast<char>(tmp);
+ }
+
+ void convert(std::string& val) const
+ {
+ val = NumberFormatter::format(_val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const UInt32& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return std::numeric_limits<UInt32>::is_integer;
+ }
+
+ bool isSigned() const
+ {
+ return std::numeric_limits<UInt32>::is_signed;
+ }
+
+ bool isNumeric() const
+ {
+ return std::numeric_limits<UInt32>::is_specialized;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ UInt32 _val;
+};
+
+
+template <>
+class VarHolderImpl<UInt64>: public VarHolder
+{
+public:
+ VarHolderImpl(UInt64 val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(UInt64);
+ }
+
+ void convert(Int8& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int16& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int32& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int64& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(UInt8& val) const
+ {
+ convertToSmallerUnsigned(_val, val);
+ }
+
+ void convert(UInt16& val) const
+ {
+ convertToSmallerUnsigned(_val, val);
+ }
+
+ void convert(UInt32& val) const
+ {
+ convertToSmallerUnsigned(_val, val);
+ }
+
+ void convert(UInt64& val) const
+ {
+ val = _val;
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ val = _val;
+ }
+
+#endif
+
+ void convert(bool& val) const
+ {
+ val = (_val != 0);
+ }
+
+ void convert(float& val) const
+ {
+ val = static_cast<float>(_val);
+ }
+
+ void convert(double& val) const
+ {
+ val = static_cast<double>(_val);
+ }
+
+ void convert(char& val) const
+ {
+ UInt8 tmp;
+ convert(tmp);
+ val = static_cast<char>(tmp);
+ }
+
+ void convert(std::string& val) const
+ {
+ val = NumberFormatter::format(_val);
+ }
+
+ void convert(DateTime& dt) const
+ {
+ Int64 val;
+ convertUnsignedToSigned(_val, val);
+ dt = Timestamp(val);
+ }
+
+ void convert(LocalDateTime& ldt) const
+ {
+ Int64 val;
+ convertUnsignedToSigned(_val, val);
+ ldt = Timestamp(val);
+ }
+
+ void convert(Timestamp& val) const
+ {
+ Int64 tmp;
+ convertUnsignedToSigned(_val, tmp);
+ val = Timestamp(tmp);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const UInt64& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return std::numeric_limits<UInt64>::is_integer;
+ }
+
+ bool isSigned() const
+ {
+ return std::numeric_limits<UInt64>::is_signed;
+ }
+
+ bool isNumeric() const
+ {
+ return std::numeric_limits<UInt64>::is_specialized;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ UInt64 _val;
+};
+
+
+template <>
+class VarHolderImpl<bool>: public VarHolder
+{
+public:
+ VarHolderImpl(bool val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(bool);
+ }
+
+ void convert(Int8& val) const
+ {
+ val = static_cast<Int8>(_val ? 1 : 0);
+ }
+
+ void convert(Int16& val) const
+ {
+ val = static_cast<Int16>(_val ? 1 : 0);
+ }
+
+ void convert(Int32& val) const
+ {
+ val = static_cast<Int32>(_val ? 1 : 0);
+ }
+
+ void convert(Int64& val) const
+ {
+ val = static_cast<Int64>(_val ? 1 : 0);
+ }
+
+ void convert(UInt8& val) const
+ {
+ val = static_cast<UInt8>(_val ? 1 : 0);
+ }
+
+ void convert(UInt16& val) const
+ {
+ val = static_cast<UInt16>(_val ? 1 : 0);
+ }
+
+ void convert(UInt32& val) const
+ {
+ val = static_cast<UInt32>(_val ? 1 : 0);
+ }
+
+ void convert(UInt64& val) const
+ {
+ val = static_cast<UInt64>(_val ? 1 : 0);
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ val = static_cast<long long>(_val ? 1 : 0);
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ val = static_cast<unsigned long long>(_val ? 1 : 0);
+ }
+
+#endif
+
+ void convert(bool& val) const
+ {
+ val = _val;
+ }
+
+ void convert(float& val) const
+ {
+ val = (_val ? 1.0f : 0.0f);
+ }
+
+ void convert(double& val) const
+ {
+ val = (_val ? 1.0 : 0.0);
+ }
+
+ void convert(char& val) const
+ {
+ val = static_cast<char>(_val ? 1 : 0);
+ }
+
+ void convert(std::string& val) const
+ {
+ val = (_val ? "true" : "false");
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const bool& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return std::numeric_limits<bool>::is_integer;
+ }
+
+ bool isSigned() const
+ {
+ return std::numeric_limits<bool>::is_signed;
+ }
+
+ bool isNumeric() const
+ {
+ return std::numeric_limits<bool>::is_specialized;
+ }
+
+ bool isBoolean() const
+ {
+ return true;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ bool _val;
+};
+
+
+template <>
+class VarHolderImpl<float>: public VarHolder
+{
+public:
+ VarHolderImpl(float val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(float);
+ }
+
+ void convert(Int8& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int16& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int32& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int64& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(UInt8& val) const
+ {
+ convertSignedFloatToUnsigned(_val, val);
+ }
+
+ void convert(UInt16& val) const
+ {
+ convertSignedFloatToUnsigned(_val, val);
+ }
+
+ void convert(UInt32& val) const
+ {
+ convertSignedFloatToUnsigned(_val, val);
+ }
+
+ void convert(UInt64& val) const
+ {
+ convertSignedFloatToUnsigned(_val, val);
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ convertSignedFloatToUnsigned(_val, val);
+ }
+
+#endif
+
+ void convert(bool& val) const
+ {
+ val = !(_val <= std::numeric_limits<float>::min() &&
+ _val >= -1 * std::numeric_limits<float>::min());
+ }
+
+ void convert(float& val) const
+ {
+ val = _val;
+ }
+
+ void convert(double& val) const
+ {
+ val = _val;
+ }
+
+ void convert(char& val) const
+ {
+ UInt8 tmp;
+ convert(tmp);
+ val = static_cast<char>(tmp);
+ }
+
+ void convert(std::string& val) const
+ {
+ val = NumberFormatter::format(_val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const float& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return std::numeric_limits<float>::is_integer;
+ }
+
+ bool isSigned() const
+ {
+ return std::numeric_limits<float>::is_signed;
+ }
+
+ bool isNumeric() const
+ {
+ return std::numeric_limits<float>::is_specialized;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ float _val;
+};
+
+
+template <>
+class VarHolderImpl<double>: public VarHolder
+{
+public:
+ VarHolderImpl(double val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(double);
+ }
+
+ void convert(Int8& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int16& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int32& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int64& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(UInt8& val) const
+ {
+ convertSignedFloatToUnsigned(_val, val);
+ }
+
+ void convert(UInt16& val) const
+ {
+ convertSignedFloatToUnsigned(_val, val);
+ }
+
+ void convert(UInt32& val) const
+ {
+ convertSignedFloatToUnsigned(_val, val);
+ }
+
+ void convert(UInt64& val) const
+ {
+ convertSignedFloatToUnsigned(_val, val);
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ convertSignedFloatToUnsigned(_val, val);
+ }
+
+#endif
+
+ void convert(bool& val) const
+ {
+ val = !(_val <= std::numeric_limits<double>::min() &&
+ _val >= -1 * std::numeric_limits<double>::min());
+ }
+
+ void convert(float& val) const
+ {
+ double fMin = -1 * std::numeric_limits<float>::max();
+ double fMax = std::numeric_limits<float>::max();
+
+ if (_val < fMin) throw RangeException("Value too small.");
+ if (_val > fMax) throw RangeException("Value too large.");
+
+ val = static_cast<float>(_val);
+ }
+
+ void convert(double& val) const
+ {
+ val = _val;
+ }
+
+ void convert(char& val) const
+ {
+ UInt8 tmp;
+ convert(tmp);
+ val = static_cast<char>(tmp);
+ }
+
+ void convert(std::string& val) const
+ {
+ val = NumberFormatter::format(_val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const double& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return std::numeric_limits<double>::is_integer;
+ }
+
+ bool isSigned() const
+ {
+ return std::numeric_limits<double>::is_signed;
+ }
+
+ bool isNumeric() const
+ {
+ return std::numeric_limits<double>::is_specialized;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ double _val;
+};
+
+
+template <>
+class VarHolderImpl<char>: public VarHolder
+{
+public:
+ VarHolderImpl(char val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(char);
+ }
+
+ void convert(Int8& val) const
+ {
+ val = static_cast<Int8>(_val);
+ }
+
+ void convert(Int16& val) const
+ {
+ val = static_cast<UInt8>(_val);
+ }
+
+ void convert(Int32& val) const
+ {
+ val = static_cast<UInt8>(_val);
+ }
+
+ void convert(Int64& val) const
+ {
+ val = static_cast<UInt8>(_val);
+ }
+
+ void convert(UInt8& val) const
+ {
+ val = static_cast<UInt8>(_val);
+ }
+
+ void convert(UInt16& val) const
+ {
+ val = static_cast<UInt8>(_val);
+ }
+
+ void convert(UInt32& val) const
+ {
+ val = static_cast<UInt8>(_val);
+ }
+
+ void convert(UInt64& val) const
+ {
+ val = static_cast<UInt8>(_val);
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ val = static_cast<long long>(_val);
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ val = static_cast<unsigned long long>(_val);
+ }
+
+#endif
+
+ void convert(bool& val) const
+ {
+ val = (_val != '\0');
+ }
+
+ void convert(float& val) const
+ {
+ val = static_cast<float>(_val);
+ }
+
+ void convert(double& val) const
+ {
+ val = static_cast<double>(_val);
+ }
+
+ void convert(char& val) const
+ {
+ val = _val;
+ }
+
+ void convert(std::string& val) const
+ {
+ val = std::string(1, _val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const char& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return std::numeric_limits<char>::is_integer;
+ }
+
+ bool isSigned() const
+ {
+ return std::numeric_limits<char>::is_signed;
+ }
+
+ bool isNumeric() const
+ {
+ return std::numeric_limits<char>::is_specialized;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ char _val;
+};
+
+
+template <>
+class VarHolderImpl<std::string>: public VarHolder
+{
+public:
+ VarHolderImpl(const char* pVal): _val(pVal)
+ {
+ }
+
+ VarHolderImpl(const std::string& val) : _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(std::string);
+ }
+
+ void convert(Int8& val) const
+ {
+ int v = NumberParser::parse(_val);
+ convertToSmaller(v, val);
+ }
+
+ void convert(Int16& val) const
+ {
+ int v = NumberParser::parse(_val);
+ convertToSmaller(v, val);
+ }
+
+ void convert(Int32& val) const
+ {
+ val = NumberParser::parse(_val);
+ }
+
+ void convert(Int64& val) const
+ {
+ val = NumberParser::parse64(_val);
+ }
+
+ void convert(UInt8& val) const
+ {
+ unsigned int v = NumberParser::parseUnsigned(_val);
+ convertToSmallerUnsigned(v, val);
+ }
+
+ void convert(UInt16& val) const
+ {
+ unsigned int v = NumberParser::parseUnsigned(_val);
+ convertToSmallerUnsigned(v, val);
+ }
+
+ void convert(UInt32& val) const
+ {
+ val = NumberParser::parseUnsigned(_val);
+ }
+
+ void convert(UInt64& val) const
+ {
+ val = NumberParser::parseUnsigned64(_val);
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ val = NumberParser::parse64(_val);
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ val = NumberParser::parseUnsigned64(_val);
+ }
+
+#endif
+
+ void convert(bool& val) const
+ {
+ if (_val.empty())
+ {
+ val = false;
+ return;
+ }
+
+ static const std::string VAL_FALSE("false");
+ static const std::string VAL_INT_FALSE("0");
+ val = (_val != VAL_INT_FALSE &&
+ (icompare(_val, VAL_FALSE) != 0));
+ }
+
+ void convert(float& val) const
+ {
+ double v = NumberParser::parseFloat(_val);
+ convertToSmaller(v, val);
+ }
+
+ void convert(double& val) const
+ {
+ val = NumberParser::parseFloat(_val);
+ }
+
+ void convert(char& val) const
+ {
+ if (_val.empty())
+ val = '\0';
+ else
+ val = _val[0];
+ }
+
+ void convert(std::string& val) const
+ {
+ val = _val;
+ }
+
+ void convert(Poco::UTF16String& val) const
+ {
+ Poco::UnicodeConverter::convert(_val, val);
+ }
+
+ void convert(DateTime& val) const
+ {
+ int tzd = 0;
+ if (!DateTimeParser::tryParse(DateTimeFormat::ISO8601_FORMAT, _val, val, tzd))
+ throw BadCastException("string -> DateTime");
+ }
+
+ void convert(LocalDateTime& ldt) const
+ {
+ int tzd = 0;
+ DateTime tmp;
+ if (!DateTimeParser::tryParse(DateTimeFormat::ISO8601_FORMAT, _val, tmp, tzd))
+ throw BadCastException("string -> LocalDateTime");
+
+ ldt = LocalDateTime(tzd, tmp, false);
+ }
+
+ void convert(Timestamp& ts) const
+ {
+ int tzd = 0;
+ DateTime tmp;
+ if (!DateTimeParser::tryParse(DateTimeFormat::ISO8601_FORMAT, _val, tmp, tzd))
+ throw BadCastException("string -> Timestamp");
+
+ ts = tmp.timestamp();
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const std:: string& value() const
+ {
+ return _val;
+ }
+
+ bool isString() const
+ {
+ return true;
+ }
+
+ std::size_t size() const
+ {
+ return _val.length();
+ }
+
+ char& operator[](std::string::size_type n)
+ {
+ if (n < size()) return _val.operator[](n);
+
+ throw RangeException("String index out of range");
+ }
+
+ const char& operator[](std::string::size_type n) const
+ {
+ if (n < size()) return _val.operator[](n);
+
+ throw RangeException("String index out of range");
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ std::string _val;
+};
+
+
+template <>
+class VarHolderImpl<UTF16String>: public VarHolder
+{
+public:
+ VarHolderImpl(const char* pVal) : _val(Poco::UnicodeConverter::to<UTF16String>(pVal))
+ {
+ }
+
+ VarHolderImpl(const Poco::UTF16String& val) : _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(Poco::UTF16String);
+ }
+
+ void convert(Int8& val) const
+ {
+ int v = NumberParser::parse(toStdString());
+ convertToSmaller(v, val);
+ }
+
+ void convert(Int16& val) const
+ {
+ int v = NumberParser::parse(toStdString());
+ convertToSmaller(v, val);
+ }
+
+ void convert(Int32& val) const
+ {
+ val = NumberParser::parse(toStdString());
+ }
+
+ void convert(Int64& val) const
+ {
+ val = NumberParser::parse64(toStdString());
+ }
+
+ void convert(UInt8& val) const
+ {
+ unsigned int v = NumberParser::parseUnsigned(toStdString());
+ convertToSmallerUnsigned(v, val);
+ }
+
+ void convert(UInt16& val) const
+ {
+ unsigned int v = NumberParser::parseUnsigned(toStdString());
+ convertToSmallerUnsigned(v, val);
+ }
+
+ void convert(UInt32& val) const
+ {
+ val = NumberParser::parseUnsigned(toStdString());
+ }
+
+ void convert(UInt64& val) const
+ {
+ val = NumberParser::parseUnsigned64(toStdString());
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ val = NumberParser::parse64(toStdString());
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ val = NumberParser::parseUnsigned64(toStdString());
+ }
+
+#endif
+
+ void convert(bool& val) const
+ {
+ static const std::string VAL_FALSE("false");
+ static const std::string VAL_INT_FALSE("0");
+
+ if (_val.empty()) val = false;
+
+ std::string str;
+ UnicodeConverter::convert(_val, str);
+ val = (str != VAL_INT_FALSE &&
+ (icompare(str, VAL_FALSE) != 0));
+ }
+
+ void convert(float& val) const
+ {
+ double v = NumberParser::parseFloat(toStdString());
+ convertToSmaller(v, val);
+ }
+
+ void convert(double& val) const
+ {
+ val = NumberParser::parseFloat(toStdString());
+ }
+
+ void convert(char& val) const
+ {
+ if (_val.empty())
+ val = '\0';
+ else
+ {
+ std::string s;
+ UnicodeConverter::convert(_val, s);
+ val = s[0];
+ }
+ }
+
+ void convert(Poco::UTF16String& val) const
+ {
+ val = _val;
+ }
+
+ void convert(std::string& val) const
+ {
+ UnicodeConverter::convert(_val, val);
+ }
+
+ void convert(DateTime& val) const
+ {
+ int tzd = 0;
+ if (!DateTimeParser::tryParse(DateTimeFormat::ISO8601_FORMAT, toStdString(), val, tzd))
+ throw BadCastException("string -> DateTime");
+ }
+
+ void convert(LocalDateTime& ldt) const
+ {
+ int tzd = 0;
+ DateTime tmp;
+ if (!DateTimeParser::tryParse(DateTimeFormat::ISO8601_FORMAT, toStdString(), tmp, tzd))
+ throw BadCastException("string -> LocalDateTime");
+
+ ldt = LocalDateTime(tzd, tmp, false);
+ }
+
+ void convert(Timestamp& ts) const
+ {
+ int tzd = 0;
+ DateTime tmp;
+ if (!DateTimeParser::tryParse(DateTimeFormat::ISO8601_FORMAT, toStdString(), tmp, tzd))
+ throw BadCastException("string -> Timestamp");
+
+ ts = tmp.timestamp();
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const Poco::UTF16String& value() const
+ {
+ return _val;
+ }
+
+ bool isString() const
+ {
+ return true;
+ }
+
+ std::size_t size() const
+ {
+ return _val.length();
+ }
+
+ UTF16Char& operator[](Poco::UTF16String::size_type n)
+ {
+ if (n < size()) return _val.operator[](n);
+
+ throw RangeException("String index out of range");
+ }
+
+ const UTF16Char& operator[](Poco::UTF16String::size_type n) const
+ {
+ if (n < size()) return _val.operator[](n);
+
+ throw RangeException("String index out of range");
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ std::string toStdString() const
+ {
+ std::string str;
+ UnicodeConverter::convert(_val, str);
+ return str;
+ }
+
+ Poco::UTF16String _val;
+};
+
+
+#ifndef POCO_LONG_IS_64_BIT
+
+
+template <>
+class VarHolderImpl<long>: public VarHolder
+{
+public:
+ VarHolderImpl(long val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(long);
+ }
+
+ void convert(Int8& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int16& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int32& val) const
+ {
+ val = static_cast<Int32>(_val);
+ }
+
+ void convert(Int64& val) const
+ {
+ val = static_cast<Int64>(_val);
+ }
+
+ void convert(UInt8& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt16& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt32& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt64& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(bool& val) const
+ {
+ val = (_val != 0);
+ }
+
+ void convert(float& val) const
+ {
+ val = static_cast<float>(_val);
+ }
+
+ void convert(double& val) const
+ {
+ val = static_cast<double>(_val);
+ }
+
+ void convert(char& val) const
+ {
+ UInt8 tmp;
+ convert(tmp);
+ val = static_cast<char>(tmp);
+ }
+
+ void convert(std::string& val) const
+ {
+ val = NumberFormatter::format(_val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const long& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return std::numeric_limits<long>::is_integer;
+ }
+
+ bool isSigned() const
+ {
+ return std::numeric_limits<long>::is_signed;
+ }
+
+ bool isNumeric() const
+ {
+ return std::numeric_limits<long>::is_specialized;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ long _val;
+};
+
+
+template <>
+class VarHolderImpl<unsigned long>: public VarHolder
+{
+public:
+ VarHolderImpl(unsigned long val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(unsigned long);
+ }
+
+ void convert(Int8& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int16& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int32& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int64& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(UInt8& val) const
+ {
+ convertToSmallerUnsigned(_val, val);
+ }
+
+ void convert(UInt16& val) const
+ {
+ convertToSmallerUnsigned(_val, val);
+ }
+
+ void convert(UInt32& val) const
+ {
+ convertToSmallerUnsigned(_val, val);
+ }
+
+ void convert(UInt64& val) const
+ {
+ val = static_cast<UInt64>(_val);
+ }
+
+ void convert(bool& val) const
+ {
+ val = (_val != 0);
+ }
+
+ void convert(float& val) const
+ {
+ val = static_cast<float>(_val);
+ }
+
+ void convert(double& val) const
+ {
+ val = static_cast<double>(_val);
+ }
+
+ void convert(char& val) const
+ {
+ UInt8 tmp;
+ convert(tmp);
+ val = static_cast<char>(tmp);
+ }
+
+ void convert(std::string& val) const
+ {
+ val = NumberFormatter::format(_val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const unsigned long& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return std::numeric_limits<unsigned long>::is_integer;
+ }
+
+ bool isSigned() const
+ {
+ return std::numeric_limits<unsigned long>::is_signed;
+ }
+
+ bool isNumeric() const
+ {
+ return std::numeric_limits<unsigned long>::is_specialized;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ unsigned long _val;
+};
+
+
+#else // if defined (POCO_LONG_IS_64_BIT)
+
+
+template <>
+class VarHolderImpl<long long>: public VarHolder
+{
+public:
+ VarHolderImpl(long long val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(long long);
+ }
+
+ void convert(Int8& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int16& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int32& val) const
+ {
+ convertToSmaller(_val, val);
+ }
+
+ void convert(Int64& val) const
+ {
+ val = static_cast<Int64>(_val);
+ }
+
+ void convert(UInt8& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt16& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt32& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(UInt64& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(long long& val) const
+ {
+ val = _val;
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ convertSignedToUnsigned(_val, val);
+ }
+
+ void convert(bool& val) const
+ {
+ val = (_val != 0);
+ }
+
+ void convert(float& val) const
+ {
+ val = static_cast<float>(_val);
+ }
+
+ void convert(double& val) const
+ {
+ val = static_cast<double>(_val);
+ }
+
+ void convert(char& val) const
+ {
+ UInt8 tmp;
+ convert(tmp);
+ val = static_cast<char>(tmp);
+ }
+
+ void convert(std::string& val) const
+ {
+ val = NumberFormatter::format(_val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const long long& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return std::numeric_limits<long long>::is_integer;
+ }
+
+ bool isSigned() const
+ {
+ return std::numeric_limits<long long>::is_signed;
+ }
+
+ bool isNumeric() const
+ {
+ return std::numeric_limits<long long>::is_specialized;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ long long _val;
+};
+
+
+template <>
+class VarHolderImpl<unsigned long long>: public VarHolder
+{
+public:
+ VarHolderImpl(unsigned long long val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(unsigned long long);
+ }
+
+ void convert(Int8& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int16& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int32& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(Int64& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(UInt8& val) const
+ {
+ convertToSmallerUnsigned(_val, val);
+ }
+
+ void convert(UInt16& val) const
+ {
+ convertToSmallerUnsigned(_val, val);
+ }
+
+ void convert(UInt32& val) const
+ {
+ convertToSmallerUnsigned(_val, val);
+ }
+
+ void convert(UInt64& val) const
+ {
+ val = static_cast<UInt64>(_val);
+ }
+
+ void convert(long long& val) const
+ {
+ convertUnsignedToSigned(_val, val);
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ val = _val;
+ }
+
+ void convert(bool& val) const
+ {
+ val = (_val != 0);
+ }
+
+ void convert(float& val) const
+ {
+ val = static_cast<float>(_val);
+ }
+
+ void convert(double& val) const
+ {
+ val = static_cast<double>(_val);
+ }
+
+ void convert(char& val) const
+ {
+ UInt8 tmp;
+ convert(tmp);
+ val = static_cast<char>(tmp);
+ }
+
+ void convert(std::string& val) const
+ {
+ val = NumberFormatter::format(_val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const unsigned long long& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return std::numeric_limits<unsigned long long>::is_integer;
+ }
+
+ bool isSigned() const
+ {
+ return std::numeric_limits<unsigned long long>::is_signed;
+ }
+
+ bool isNumeric() const
+ {
+ return std::numeric_limits<unsigned long long>::is_specialized;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ unsigned long long _val;
+};
+
+
+#endif // 64bit
+
+
+template <typename T>
+class VarHolderImpl<std::vector<T> >: public VarHolder
+{
+public:
+ VarHolderImpl(const std::vector<T>& val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(std::vector<T>);
+ }
+
+ void convert(std::string& val) const
+ {
+ Impl::containerToJSON(_val, val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const std::vector<T>& value() const
+ {
+ return _val;
+ }
+
+ bool isVector() const
+ {
+ return true;
+ }
+
+ std::size_t size() const
+ {
+ return _val.size();
+ }
+
+ T& operator[](typename std::vector<T>::size_type n)
+ {
+ if (n < size()) return _val.operator[](n);
+
+ throw RangeException("List index out of range");
+ }
+
+ const T& operator[](typename std::vector<T>::size_type n) const
+ {
+ if (n < size()) return _val.operator[](n);
+
+ throw RangeException("List index out of range");
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ std::vector<T> _val;
+};
+
+
+template <typename T>
+class VarHolderImpl<std::list<T> >: public VarHolder
+{
+public:
+ VarHolderImpl(const std::list<T>& val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(std::list<T>);
+ }
+
+ void convert(std::string& val) const
+ {
+ Impl::containerToJSON(_val, val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const std::list<T>& value() const
+ {
+ return _val;
+ }
+
+ bool isList() const
+ {
+ return true;
+ }
+
+ std::size_t size() const
+ {
+ return _val.size();
+ }
+
+ T& operator[](typename std::list<T>::size_type n)
+ {
+ if (n >= size())
+ throw RangeException("List index out of range");
+
+ typename std::list<T>::size_type counter = 0;
+ typename std::list<T>::iterator it = _val.begin();
+ for (; counter < n; ++counter) ++it;
+
+ return *it;
+ }
+
+ const T& operator[](typename std::list<T>::size_type n) const
+ {
+ if (n >= size())
+ throw RangeException("List index out of range");
+
+ typename std::list<T>::size_type counter = 0;
+ typename std::list<T>::const_iterator it = _val.begin();
+ for (; counter < n; ++counter) ++it;
+
+ return *it;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ std::list<T> _val;
+};
+
+
+template <typename T>
+class VarHolderImpl<std::deque<T> >: public VarHolder
+{
+public:
+ VarHolderImpl(const std::deque<T>& val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(std::deque<T>);
+ }
+
+ void convert(std::string& val) const
+ {
+ Impl::containerToJSON(_val, val);
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const std::deque<T>& value() const
+ {
+ return _val;
+ }
+
+ bool isDeque() const
+ {
+ return true;
+ }
+
+ std::size_t size() const
+ {
+ return _val.size();
+ }
+
+ T& operator[](typename std::deque<T>::size_type n)
+ {
+ if (n < size()) return _val.operator[](n);
+
+ throw RangeException("List index out of range");
+ }
+
+ const T& operator[](typename std::deque<T>::size_type n) const
+ {
+ if (n < size()) return _val.operator[](n);
+
+ throw RangeException("List index out of range");
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ std::deque<T> _val;
+};
+
+
+template <>
+class VarHolderImpl<DateTime>: public VarHolder
+{
+public:
+ VarHolderImpl(const DateTime& val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(DateTime);
+ }
+
+ void convert(Int8& /*val*/) const
+ {
+ throw BadCastException();
+ }
+
+ void convert(Int16& /*val*/) const
+ {
+ throw BadCastException();
+ }
+
+ void convert(Int32& /*val*/) const
+ {
+ throw BadCastException();
+ }
+
+ void convert(Int64& val) const
+ {
+ val = _val.timestamp().epochMicroseconds();
+ }
+
+ void convert(UInt64& val) const
+ {
+ val = _val.timestamp().epochMicroseconds();
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ val = _val.timestamp().epochMicroseconds();
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ val = _val.timestamp().epochMicroseconds();
+ }
+
+#endif
+
+ void convert(std::string& val) const
+ {
+ val = DateTimeFormatter::format(_val, Poco::DateTimeFormat::ISO8601_FORMAT);
+ }
+
+ void convert(DateTime& val) const
+ {
+ val = _val;
+ }
+
+ void convert(LocalDateTime& ldt) const
+ {
+ ldt = _val.timestamp();
+ }
+
+ void convert(Timestamp& ts) const
+ {
+ ts = _val.timestamp();
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const DateTime& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return false;
+ }
+
+ bool isSigned() const
+ {
+ return false;
+ }
+
+ bool isNumeric() const
+ {
+ return false;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+ bool isDate() const
+ {
+ return true;
+ }
+
+ bool isTime() const
+ {
+ return true;
+ }
+
+ bool isDateTime() const
+ {
+ return true;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ DateTime _val;
+};
+
+
+template <>
+class VarHolderImpl<LocalDateTime>: public VarHolder
+{
+public:
+ VarHolderImpl(const LocalDateTime& val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(LocalDateTime);
+ }
+
+ void convert(Int64& val) const
+ {
+ val = _val.timestamp().epochMicroseconds();
+ }
+
+ void convert(UInt64& val) const
+ {
+ val = _val.timestamp().epochMicroseconds();
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ val = _val.timestamp().epochMicroseconds();
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ val = _val.timestamp().epochMicroseconds();
+ }
+
+#endif
+
+ void convert(std::string& val) const
+ {
+ val = DateTimeFormatter::format(_val, Poco::DateTimeFormat::ISO8601_FORMAT);
+ }
+
+ void convert(DateTime& val) const
+ {
+ val = _val.timestamp();
+ }
+
+ void convert(LocalDateTime& ldt) const
+ {
+ ldt = _val;
+ }
+
+ void convert(Timestamp& ts) const
+ {
+ ts = _val.timestamp();
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const LocalDateTime& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return false;
+ }
+
+ bool isSigned() const
+ {
+ return false;
+ }
+
+ bool isNumeric() const
+ {
+ return false;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+ bool isDate() const
+ {
+ return true;
+ }
+
+ bool isTime() const
+ {
+ return true;
+ }
+
+ bool isDateTime() const
+ {
+ return true;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ LocalDateTime _val;
+};
+
+
+template <>
+class VarHolderImpl<Timestamp>: public VarHolder
+{
+public:
+ VarHolderImpl(const Timestamp& val): _val(val)
+ {
+ }
+
+ ~VarHolderImpl()
+ {
+ }
+
+ const std::type_info& type() const
+ {
+ return typeid(Timestamp);
+ }
+
+ void convert(Int64& val) const
+ {
+ val = _val.epochMicroseconds();
+ }
+
+ void convert(UInt64& val) const
+ {
+ val = _val.epochMicroseconds();
+ }
+
+#ifdef POCO_LONG_IS_64_BIT
+
+ void convert(long long& val) const
+ {
+ val = _val.epochMicroseconds();
+ }
+
+ void convert(unsigned long long& val) const
+ {
+ val = _val.epochMicroseconds();
+ }
+
+#endif
+
+ void convert(std::string& val) const
+ {
+ val = DateTimeFormatter::format(_val, Poco::DateTimeFormat::ISO8601_FORMAT);
+ }
+
+ void convert(DateTime& val) const
+ {
+ val = _val;
+ }
+
+ void convert(LocalDateTime& ldt) const
+ {
+ ldt = _val;
+ }
+
+ void convert(Timestamp& ts) const
+ {
+ ts = _val;
+ }
+
+ VarHolder* clone(Placeholder<VarHolder>* pVarHolder = 0) const
+ {
+ return cloneHolder(pVarHolder, _val);
+ }
+
+ const Timestamp& value() const
+ {
+ return _val;
+ }
+
+ bool isArray() const
+ {
+ return false;
+ }
+
+ bool isStruct() const
+ {
+ return false;
+ }
+
+ bool isInteger() const
+ {
+ return false;
+ }
+
+ bool isSigned() const
+ {
+ return false;
+ }
+
+ bool isNumeric() const
+ {
+ return false;
+ }
+
+ bool isBoolean() const
+ {
+ return false;
+ }
+
+ bool isString() const
+ {
+ return false;
+ }
+
+ bool isDate() const
+ {
+ return true;
+ }
+
+ bool isTime() const
+ {
+ return true;
+ }
+
+ bool isDateTime() const
+ {
+ return true;
+ }
+
+private:
+ VarHolderImpl();
+ VarHolderImpl(const VarHolderImpl&);
+ VarHolderImpl& operator = (const VarHolderImpl&);
+
+ Timestamp _val;
+};
+
+
+typedef std::vector<Var> Vector;
+typedef std::deque<Var> Deque;
+typedef std::list<Var> List;
+typedef Vector Array;
+
+
+} } // namespace Poco::Dynamic
+
+
+#endif // Foundation_VarHolder_INCLUDED
diff --git a/contrib/libs/poco/Foundation/include/Poco/Dynamic/VarIterator.h b/contrib/libs/poco/Foundation/include/Poco/Dynamic/VarIterator.h
index a91bb3a6a2..20d18dd34c 100644
--- a/contrib/libs/poco/Foundation/include/Poco/Dynamic/VarIterator.h
+++ b/contrib/libs/poco/Foundation/include/Poco/Dynamic/VarIterator.h
@@ -1,150 +1,150 @@
-//
-// VarIterator.h
-//
-// Library: Foundation
-// Package: Dynamic
-// Module: VarIterator
-//
-// Definition of the VarIterator class.
-//
-// Copyright (c) 2006, Applied Informatics Software Engineering GmbH.
-// and Contributors.
-//
-// SPDX-License-Identifier: BSL-1.0
-//
-
-
-#ifndef Foundation_VarIterator_INCLUDED
-#define Foundation_VarIterator_INCLUDED
-
-
-#include "Poco/Exception.h"
-#include <iterator>
-#include <algorithm>
-
-
-namespace Poco {
-namespace Dynamic {
-
-
-class Var;
-
-
-class Foundation_API VarIterator
- /// VarIterator class.
-{
-public:
- typedef std::bidirectional_iterator_tag iterator_category;
- typedef Var value_type;
- typedef std::ptrdiff_t difference_type;
- typedef Var* pointer;
- typedef Var& reference;
-
- static const std::size_t POSITION_END;
- /// End position indicator.
-
- VarIterator(Var* pVar, bool positionEnd);
- /// Creates the VarIterator and positions it at the end of
- /// the recordset if positionEnd is true. Otherwise, it is
- /// positioned at the beginning.
-
- VarIterator(const VarIterator& other);
- /// Creates a copy of other VarIterator.
-
- ~VarIterator();
- /// Destroys the VarIterator.
-
- VarIterator& operator = (const VarIterator& other);
- /// Assigns the other VarIterator.
-
- bool operator == (const VarIterator& other) const;
- /// Equality operator.
-
- bool operator != (const VarIterator& other) const;
- /// Inequality operator.
-
- Var& operator * () const;
- /// Returns value at the current position.
-
- Var* operator -> () const;
- /// Returns pointer to the value at current position.
-
- const VarIterator& operator ++ () const;
- /// Advances by one position and returns current position.
-
- VarIterator operator ++ (int) const;
- /// Advances by one position and returns copy of the iterator with
- /// previous current position.
-
- const VarIterator& operator -- () const;
- /// Goes back by one position and returns copy of the iterator with
- /// previous current position.
-
- VarIterator operator -- (int) const;
- /// Goes back by one position and returns previous current position.
-
- VarIterator operator + (std::size_t diff) const;
- /// Returns a copy the VarIterator advanced by diff positions.
-
- VarIterator operator - (std::size_t diff) const;
- /// Returns a copy the VarIterator backed by diff positions.
- /// Throws RangeException if diff is larger than current position.
-
- void swap(VarIterator& other);
- /// Swaps the VarIterator with another one.
-
-private:
- VarIterator();
-
- void increment() const;
- /// Increments the iterator position by one.
- /// Throws RangeException if position is out of range.
-
- void decrement() const;
- /// Decrements the iterator position by one.
- /// Throws RangeException if position is out of range.
-
- void setPosition(std::size_t pos) const;
- /// Sets the iterator position.
- /// Throws RangeException if position is out of range.
-
- Var* _pVar;
- mutable std::size_t _position;
-
- friend class Var;
-};
-
-
-///
-/// inlines
-///
-
-
-inline bool VarIterator::operator == (const VarIterator& other) const
-{
- return _pVar == other._pVar && _position == other._position;
-}
-
-
-inline bool VarIterator::operator != (const VarIterator& other) const
-{
- return _pVar != other._pVar || _position != other._position;
-}
-
-
-} } // namespace Poco::Dynamic
-
-
-namespace std
-{
- template<>
- inline void swap<Poco::Dynamic::VarIterator>(Poco::Dynamic::VarIterator& s1,
- Poco::Dynamic::VarIterator& s2)
- /// Full template specialization of std:::swap for VarIterator
- {
- s1.swap(s2);
- }
-}
-
-
-#endif // Foundation_VarIterator_INCLUDED
+//
+// VarIterator.h
+//
+// Library: Foundation
+// Package: Dynamic
+// Module: VarIterator
+//
+// Definition of the VarIterator class.
+//
+// Copyright (c) 2006, Applied Informatics Software Engineering GmbH.
+// and Contributors.
+//
+// SPDX-License-Identifier: BSL-1.0
+//
+
+
+#ifndef Foundation_VarIterator_INCLUDED
+#define Foundation_VarIterator_INCLUDED
+
+
+#include "Poco/Exception.h"
+#include <iterator>
+#include <algorithm>
+
+
+namespace Poco {
+namespace Dynamic {
+
+
+class Var;
+
+
+class Foundation_API VarIterator
+ /// VarIterator class.
+{
+public:
+ typedef std::bidirectional_iterator_tag iterator_category;
+ typedef Var value_type;
+ typedef std::ptrdiff_t difference_type;
+ typedef Var* pointer;
+ typedef Var& reference;
+
+ static const std::size_t POSITION_END;
+ /// End position indicator.
+
+ VarIterator(Var* pVar, bool positionEnd);
+ /// Creates the VarIterator and positions it at the end of
+ /// the recordset if positionEnd is true. Otherwise, it is
+ /// positioned at the beginning.
+
+ VarIterator(const VarIterator& other);
+ /// Creates a copy of other VarIterator.
+
+ ~VarIterator();
+ /// Destroys the VarIterator.
+
+ VarIterator& operator = (const VarIterator& other);
+ /// Assigns the other VarIterator.
+
+ bool operator == (const VarIterator& other) const;
+ /// Equality operator.
+
+ bool operator != (const VarIterator& other) const;
+ /// Inequality operator.
+
+ Var& operator * () const;
+ /// Returns value at the current position.
+
+ Var* operator -> () const;
+ /// Returns pointer to the value at current position.
+
+ const VarIterator& operator ++ () const;
+ /// Advances by one position and returns current position.
+
+ VarIterator operator ++ (int) const;
+ /// Advances by one position and returns copy of the iterator with
+ /// previous current position.
+
+ const VarIterator& operator -- () const;
+ /// Goes back by one position and returns copy of the iterator with
+ /// previous current position.
+
+ VarIterator operator -- (int) const;
+ /// Goes back by one position and returns previous current position.
+
+ VarIterator operator + (std::size_t diff) const;
+ /// Returns a copy the VarIterator advanced by diff positions.
+
+ VarIterator operator - (std::size_t diff) const;
+ /// Returns a copy the VarIterator backed by diff positions.
+ /// Throws RangeException if diff is larger than current position.
+
+ void swap(VarIterator& other);
+ /// Swaps the VarIterator with another one.
+
+private:
+ VarIterator();
+
+ void increment() const;
+ /// Increments the iterator position by one.
+ /// Throws RangeException if position is out of range.
+
+ void decrement() const;
+ /// Decrements the iterator position by one.
+ /// Throws RangeException if position is out of range.
+
+ void setPosition(std::size_t pos) const;
+ /// Sets the iterator position.
+ /// Throws RangeException if position is out of range.
+
+ Var* _pVar;
+ mutable std::size_t _position;
+
+ friend class Var;
+};
+
+
+///
+/// inlines
+///
+
+
+inline bool VarIterator::operator == (const VarIterator& other) const
+{
+ return _pVar == other._pVar && _position == other._position;
+}
+
+
+inline bool VarIterator::operator != (const VarIterator& other) const
+{
+ return _pVar != other._pVar || _position != other._position;
+}
+
+
+} } // namespace Poco::Dynamic
+
+
+namespace std
+{
+ template<>
+ inline void swap<Poco::Dynamic::VarIterator>(Poco::Dynamic::VarIterator& s1,
+ Poco::Dynamic::VarIterator& s2)
+ /// Full template specialization of std:::swap for VarIterator
+ {
+ s1.swap(s2);
+ }
+}
+
+
+#endif // Foundation_VarIterator_INCLUDED