/************************************************************************ ** ** @file varc_p.h ** @author Roman Telezhynskyi ** @date 20 8, 2014 ** ** @brief ** @copyright ** This source code is part of the Valentine project, a pattern making ** program, whose allow create and modeling patterns of clothing. ** Copyright (C) 2013-2015 Valentina project ** All Rights Reserved. ** ** Valentina 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. ** ** Valentina 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 Valentina. If not, see . ** *************************************************************************/ #ifndef VARC_P_H #define VARC_P_H #include #include "vgeometrydef.h" #include "../vmisc/vabstractapplication.h" #ifdef Q_CC_GNU #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Weffc++" #endif class VArcData : public QSharedData { public: VArcData(); VArcData(qreal radius, QString formulaRadius); VArcData(qreal radius); VArcData(const VArcData &arc); virtual ~VArcData(); /** @brief radius arc radius. */ qreal radius; /** @brief formulaRadius formula for arc radius. */ QString formulaRadius; private: VArcData &operator=(const VArcData &) Q_DECL_EQ_DELETE; }; //--------------------------------------------------------------------------------------------------------------------- VArcData::VArcData() : radius(0), formulaRadius(QString()) {} //--------------------------------------------------------------------------------------------------------------------- VArcData::VArcData(qreal radius, QString formulaRadius) : radius(radius), formulaRadius(formulaRadius) {} //--------------------------------------------------------------------------------------------------------------------- VArcData::VArcData(qreal radius) : radius(radius), formulaRadius(QString().number(qApp->fromPixel(radius))) {} //--------------------------------------------------------------------------------------------------------------------- VArcData::VArcData(const VArcData &arc) : QSharedData(arc), radius(arc.radius), formulaRadius(arc.formulaRadius) {} //--------------------------------------------------------------------------------------------------------------------- VArcData::~VArcData() {} #ifdef Q_CC_GNU #pragma GCC diagnostic pop #endif #endif // VARC_P_H