Files
qt-creator/src/libs/utils/predicates.h
Kai Köhne 56baf8c058 Remove GPL-3.0+ from license identifiers
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>
2023-01-06 11:15:13 +00:00

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