forked from qt-creator/qt-creator
Since we also license under GPL-3.0 WITH Qt-GPL-exception-1.0,
this applies only to a hypothetical newer version of GPL, that doesn't
exist yet. If such a version emerges, we can still decide to relicense...
While at it, replace (deprecated) GPL-3.0 with more explicit GPL-3.0-only
Change was done by running
find . -type f -exec perl -pi -e "s/LicenseRef-Qt-Commercial OR GPL-3.0\+ OR GPL-3.0 WITH Qt-GPL-exception-1.0/LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0/g" {} \;
Change-Id: I5097e6ce8d10233993ee30d7e25120e2659eb10b
Reviewed-by: Eike Ziller <eike.ziller@qt.io>
111 lines
3.5 KiB
C++
111 lines
3.5 KiB
C++
// Copyright (C) 2017 The Qt Company Ltd.
|
|
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
|
|
|
|
#pragma once
|
|
|
|
#include <functional>
|
|
#include <type_traits>
|
|
#include <utility>
|
|
|
|
namespace Utils
|
|
{
|
|
|
|
//////////////////
|
|
// find helpers
|
|
//////////////////
|
|
template<typename R, typename S, typename T>
|
|
decltype(auto) equal(R (S::*function)() const, T value)
|
|
{
|
|
// This should use std::equal_to<> instead of std::equal_to<T>,
|
|
// but that's not supported everywhere yet, since it is C++14
|
|
return std::bind<bool>(std::equal_to<T>(), value, std::bind(function, std::placeholders::_1));
|
|
}
|
|
|
|
template<typename R, typename S, typename T>
|
|
decltype(auto) equal(R S::*member, T value)
|
|
{
|
|
return std::bind<bool>(std::equal_to<T>(), value, std::bind(member, std::placeholders::_1));
|
|
}
|
|
|
|
//////////////////
|
|
// comparison predicates
|
|
//////////////////
|
|
template <typename Type>
|
|
auto equalTo(Type &&value)
|
|
{
|
|
return [value = std::forward<Type>(value)] (const auto &entry)
|
|
{
|
|
static_assert(std::is_same<std::decay_t<Type>,
|
|
std::decay_t<decltype(entry)>>::value,
|
|
"The container and predicate type of equalTo should be the same to prevent "
|
|
"unnecessary conversion.");
|
|
return entry == value;
|
|
};
|
|
}
|
|
|
|
template <typename Type>
|
|
auto unequalTo(Type &&value)
|
|
{
|
|
return [value = std::forward<Type>(value)] (const auto &entry)
|
|
{
|
|
static_assert(std::is_same<std::decay_t<Type>,
|
|
std::decay_t<decltype(entry)>>::value,
|
|
"The container and predicate type of unequalTo should be the same to prevent "
|
|
"unnecessary conversion.");
|
|
return !(entry == value);
|
|
};
|
|
}
|
|
|
|
template <typename Type>
|
|
auto lessThan(Type &&value)
|
|
{
|
|
return [value = std::forward<Type>(value)] (const auto &entry)
|
|
{
|
|
static_assert(std::is_same<std::decay_t<Type>,
|
|
std::decay_t<decltype(entry)>>::value,
|
|
"The container and predicate type of unequalTo should be the same to prevent "
|
|
"unnecessary conversion.");
|
|
return entry < value;
|
|
};
|
|
}
|
|
|
|
template <typename Type>
|
|
auto lessEqualThan(Type &&value)
|
|
{
|
|
return [value = std::forward<Type>(value)] (const auto &entry)
|
|
{
|
|
static_assert(std::is_same<std::decay_t<Type>,
|
|
std::decay_t<decltype(entry)>>::value,
|
|
"The container and predicate type of lessEqualThan should be the same to "
|
|
"prevent unnecessary conversion.");
|
|
return !(value < entry);
|
|
};
|
|
}
|
|
|
|
template <typename Type>
|
|
auto greaterThan(Type &&value)
|
|
{
|
|
return [value = std::forward<Type>(value)] (const auto &entry)
|
|
{
|
|
static_assert(std::is_same<std::decay_t<Type>,
|
|
std::decay_t<decltype(entry)>>::value,
|
|
"The container and predicate type of greaterThan should be the same to "
|
|
"prevent unnecessary conversion.");
|
|
return value < entry;
|
|
};
|
|
}
|
|
|
|
template <typename Type>
|
|
auto greaterEqualThan(Type &&value)
|
|
{
|
|
return [value = std::forward<Type>(value)] (const auto &entry)
|
|
{
|
|
static_assert(std::is_same<std::decay_t<Type>,
|
|
std::decay_t<decltype(entry)>>::value,
|
|
"The container and predicate type of greaterEqualThan should be the same to "
|
|
"prevent unnecessary conversion.");
|
|
return !(entry < value);
|
|
};
|
|
}
|
|
} // namespace Utils
|