Thu, 20 Jun 2019 08:54:35 +0300
uuid things
/* * LDForge: LDraw parts authoring CAD * Copyright (C) 2013 - 2018 Teemu Piippo * * 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 3 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. If not, see <http://www.gnu.org/licenses/>. */ #pragma once #include <cstdio> #include <cstdlib> #include <memory> #include <QDate> #include <QFile> #include <QLineF> #include <QMatrix4x4> #include <QMetaType> #include <QObject> #include <QPointF> #include <QSet> #include <QString> #include <QStringList> #include <QVariant> #include <QVector> #include <QVector3D> #include "generics/functions.h" #ifndef __GNUC__ # define __attribute__(X) #endif #define DEFINE_CLASS(SELF, SUPER) \ public: \ using Self = SELF; \ using Super = SUPER; class LDObject; class Uuid { public: constexpr Uuid() : a{0}, b{0} {} Uuid(Uuid&&) = default; Uuid(const Uuid&) = default; QString toString() const; Uuid& operator++(); private: quint64 a; quint64 b; }; constexpr Uuid NULL_UUID = {}; enum Axis { X, Y, Z }; enum Winding { NoWinding, CounterClockwise, Clockwise, }; struct CircularSection { int segments = 16; int divisions = 16; }; Q_DECLARE_METATYPE(CircularSection) bool operator==(const CircularSection& one, const CircularSection& other); bool operator!=(const CircularSection& one, const CircularSection& other); /* * Special operator definition that implements the XOR operator for windings. * However, if either winding is NoWinding, then this function returns NoWinding. */ Winding constexpr operator^(Winding one, Winding other) { if (one == NoWinding or other == NoWinding) return NoWinding; else return static_cast<Winding>(static_cast<int>(one) ^ static_cast<int>(other)); } inline Winding& operator^=(Winding& one, Winding other) { one = one ^ other; return one; } constexpr double pi = 3.14159265358979323846; constexpr double inf = std::numeric_limits<double>::infinity(); template<typename T> unsigned int qHash(const std::unique_ptr<T>& pointer) { return qHash(pointer.get()); } inline void offset(QMatrix4x4& matrix, const QVector3D& vector) { matrix(0, 3) += vector.x(); matrix(1, 3) += vector.y(); matrix(2, 3) += vector.z(); } template<typename... Ts> inline void ignore(Ts&&...) {} qreal determinant(qreal a, qreal b, qreal c, qreal d); qreal determinant(qreal a, qreal b, qreal c, qreal d, qreal e, qreal f, qreal g, qreal h, qreal i); qreal determinant(const QMatrix2x2& matrix); qreal determinant(const QMatrix3x3& matrix); qreal determinant(const QMatrix4x4& matrix); QString formatFileSize(qint64 size); int gcd(int a, int b); QString joinStrings(const QVector<class StringFormatArg>& values, QString delimeter = " "); QString largeNumberRep(int number); double log1000(double x); double roundToDecimals(double value, int decimals); class QSettings& settingsObject(); void simplify(int& numerator, int& denominator); QString superscript(int number); QString subscript(int number); QString fractionRep(int numerator, int denominator); qreal vectorAngle(const QVector3D& vec_1, const QVector3D& vec_2); void withSignalsBlocked(QObject* object, std::function<void()> function);