/* Copyright (C) 2018 Daniel Vrátil This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; see the file COPYING. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #ifndef UTILS_H_ #define UTILS_H_ #include #include #include template inline QList setToList(QSet &&set) { QList rv; rv.reserve(set.size()); std::copy(set.cbegin(), set.cend(), std::back_inserter(rv)); return rv; } template inline QList setToList(const QSet &set) { QList rv; rv.reserve(set.size()); std::copy(set.cbegin(), set.cend(), std::back_inserter(rv)); return rv; } template inline QSet listToSet(QList &&list) { QSet rv; rv.reserve(list.size()); for (auto t : list) { rv.insert(std::move(t)); } return rv; } #if QT_VERSION < QT_VERSION_CHECK(5, 14, 0) namespace std { template<> struct hash { inline size_t operator()(const QString &str) const { return qHash(str); } }; } #endif #endif