1
0
mirror of https://github.com/KDE/latte-dock.git synced 2025-01-12 01:17:55 +03:00
latte-dock/liblatte2/extras.h
2019-08-18 19:59:09 +03:00

103 lines
2.9 KiB
C++

/*
* Copyright 2018 Michail Vourlakos <mvourlakos@gmail.com>
*
* This file is part of Latte-Dock
*
* Latte-Dock 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.
*
* Latte-Dock 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. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef EXTRAS_H
#define EXTRAS_H
// local
#include "../liblatte2/config-latte-lib.h"
// C++
#include <type_traits>
#include <numeric>
#include <memory>
#include <cmath>
// Qt
#include <QObject>
#include <QString>
#include <QStringBuilder>
#include <QRect>
#include <QMetaEnum>
#include <QMetaType>
// Plasma
#include <Plasma>
//! There are gcc versions that don't support yet that function even though they
//! publish themselves as C++14 compatible. Such a case is gcc 4.8.x that openSUSE
//! LEAP 42.2-3 is using. By enabling this flag such systems can be build correctly.
#if ENABLE_MAKE_UNIQUE
namespace std {
template<class T, class... Args>
unique_ptr<T> make_unique(Args &&... args)
{
return std::unique_ptr<T>(new T(std::forward<Args>(args)...));
}
}
#endif
/*!
* @brief convert a QRect to a QString with format `(<x>, <y>) <width>x<height>`
*/
inline QString qRectToStr(const QRect &r)
{
return "(" % QString::number(r.x()) % ", " % QString::number(r.y()) % ") "
% QString::number(r.width()) % "x" % QString::number(r.height());
}
/*!
* @brief convert a `Q_ENUM` to c-string
*/
template<typename EnumType>
inline const char *qEnumToStr(EnumType value)
{
return QMetaEnum::fromType<EnumType>().valueToKey(value);
}
/*!
* @brief convert a `Q_ENUMS` of `Plasma::Types::Location` to c-string
*/
inline const char *qEnumToStr(Plasma::Types::Location Enum)
{
static const int Index = Plasma::Types::staticMetaObject.indexOfEnumerator("Location");
return Plasma::Types::staticMetaObject.enumerator(Index).valueToKey(Enum);
}
/*!
* @brief convert a `Q_ENUMS` of `Plasma::Types::FormFactor` to c-string
*/
inline const char *qEnumToStr(Plasma::Types::FormFactor Enum)
{
static const int Index = Plasma::Types::staticMetaObject.indexOfEnumerator("FormFactor");
return Plasma::Types::staticMetaObject.enumerator(Index).valueToKey(Enum);
}
/*!
* @brief machine epsilon
*/
template<class T>
typename std::enable_if < !std::is_integral<T>(), bool >::type almost_equal(T x, T y, int ulp)
{
return std::abs(x - y) < std::numeric_limits<T>::epsilon() * std::abs(x + y) * ulp
|| std::abs(x - y) < std::numeric_limits<T>::min();
}
#endif // EXTRAS_H