/**************************************************************************** ** ** https://www.qxorm.com/ ** Copyright (C) 2013 Lionel Marty (contact@qxorm.com) ** ** This file is part of the QxOrm library ** ** This software is provided 'as-is', without any express or implied ** warranty. In no event will the authors be held liable for any ** damages arising from the use of this software ** ** Commercial Usage ** Licensees holding valid commercial QxOrm licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and Lionel Marty ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3.0 as published by the Free Software ** Foundation and appearing in the file 'license.gpl3.txt' included in the ** packaging of this file. Please review the following information to ** ensure the GNU General Public License version 3.0 requirements will be ** met : http://www.gnu.org/copyleft/gpl.html ** ** If you are unsure which license is appropriate for your use, or ** if you have questions regarding the use of this file, please contact : ** contact@qxorm.com ** ****************************************************************************/ #ifndef _QX_NO_JSON #ifdef _QX_ENABLE_BOOST #ifndef _QX_SERIALIZE_QJSON_BOOST_UNORDERED_SET_H_ #define _QX_SERIALIZE_QJSON_BOOST_UNORDERED_SET_H_ #ifdef _MSC_VER #pragma once #endif /*! * \file QxSerializeQJson_boost_unordered_set.h * \author Lionel Marty * \ingroup QxSerialize * \brief Provide a Qt QJson serialization method (save/load) for type boost::unordered_set and boost::unordered_multiset */ #include #include #include #include #include namespace qx { namespace cvt { namespace detail { template struct QxConvert_ToJson< boost::unordered_set > { static inline QJsonValue toJson(const boost::unordered_set & t, const QString & format) { QJsonArray arr; typedef typename boost::unordered_set::const_iterator type_itr; for (type_itr itr = t.begin(); itr != t.end(); ++itr) { arr.append(qx::cvt::to_json((* itr), format)); } return QJsonValue(arr); } }; template struct QxConvert_FromJson< boost::unordered_set > { static inline qx_bool fromJson(const QJsonValue & j, boost::unordered_set & t, const QString & format) { t.clear(); if (! j.isArray()) { return qx_bool(true); } QJsonArray arr = j.toArray(); t.reserve(static_cast::size_type>(arr.count())); for (int i = 0; i < arr.count(); i++) { T tmp; qx::cvt::from_json(arr.at(i), tmp, format); t.insert(tmp); } return qx_bool(true); } }; template struct QxConvert_ToJson< boost::unordered_multiset > { static inline QJsonValue toJson(const boost::unordered_multiset & t, const QString & format) { QJsonArray arr; typedef typename boost::unordered_multiset::const_iterator type_itr; for (type_itr itr = t.begin(); itr != t.end(); ++itr) { arr.append(qx::cvt::to_json((* itr), format)); } return QJsonValue(arr); } }; template struct QxConvert_FromJson< boost::unordered_multiset > { static inline qx_bool fromJson(const QJsonValue & j, boost::unordered_multiset & t, const QString & format) { t.clear(); if (! j.isArray()) { return qx_bool(true); } QJsonArray arr = j.toArray(); t.reserve(static_cast::size_type>(arr.count())); for (int i = 0; i < arr.count(); i++) { T tmp; qx::cvt::from_json(arr.at(i), tmp, format); t.insert(tmp); } return qx_bool(true); } }; } // namespace detail } // namespace cvt } // namespace qx #endif // _QX_SERIALIZE_QJSON_BOOST_UNORDERED_SET_H_ #endif // _QX_ENABLE_BOOST #endif // _QX_NO_JSON