/************************************************************************ ** ** @file vcontainer.h ** @author Roman Telezhynskyi ** @date November 15, 2013 ** ** @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 VCONTAINER_H #define VCONTAINER_H #include "variables.h" #include "../geometry/vdetail.h" #include "../libs/vgeometry/vgobject.h" #include "../libs/ifc/exception/vexceptionbadid.h" #include "../libs/vgeometry/vabstractcurve.h" #include #include #include #include class VTranslateVars; #ifdef Q_CC_GNU #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Weffc++" #endif class VContainerData : public QSharedData { public: VContainerData(const VTranslateVars *trVars, const Unit *patternUnit) :sizeName(size_M), heightName(height_M), gObjects(QHash >()), variables(QHash > ()), details(QHash()), trVars(trVars), patternUnit(patternUnit) {} VContainerData(const VContainerData &data) :QSharedData(data), sizeName(data.sizeName), heightName(data.heightName), gObjects(data.gObjects), variables(data.variables), details(data.details), trVars(data.trVars), patternUnit(data.patternUnit) {} virtual ~VContainerData(); QString sizeName; QString heightName; /** * @brief gObjects graphicals objects of pattern. */ QHash > gObjects; /** * @brief variables container for measurements, increments, lines lengths, lines angles, arcs lengths, curve lengths */ QHash> variables; /** * @brief details container of details */ QHash details; const VTranslateVars *trVars; const Unit *patternUnit; }; #ifdef Q_CC_GNU #pragma GCC diagnostic pop #endif /** * @brief The VContainer class container of all variables. */ class VContainer { Q_DECLARE_TR_FUNCTIONS(VContainer) public: VContainer(const VTranslateVars *trVars, const Unit *patternUnit); VContainer &operator=(const VContainer &data); VContainer(const VContainer &data); ~VContainer(); template const QSharedPointer GeometricObject(const quint32 &id) const; const QSharedPointer GetGObject(quint32 id) const; const VDetail GetDetail(quint32 id) const; qreal GetTableValue(const QString& name, MeasurementsType patternType) const; template QSharedPointer GetVariable(QString name) const; static quint32 getId(); static quint32 getNextId(); static void UpdateId(quint32 newId); quint32 AddGObject(VGObject *obj); quint32 AddDetail(VDetail detail); void AddLine(const quint32 &firstPointId, const quint32 &secondPointId); void AddArc(const quint32 &arcId, const quint32 &parentId = 0); template void AddCurve(const quint32 &id, const quint32 &parentId = 0); template void AddVariable(const QString& name, T *var); void UpdateGObject(quint32 id, VGObject* obj); void UpdateDetail(quint32 id, const VDetail &detail); void Clear(); void ClearGObjects(); void ClearCalculationGObjects(); void ClearVariables(const VarType &type = VarType::Unknown); void ClearDetails(); static void ClearUniqueNames(); static void SetSize(qreal size); void SetSizeName(const QString &name); static void SetHeight(qreal height); void SetHeightName(const QString &name); static qreal size(); QString SizeName() const; static qreal height(); QString HeightName()const; bool VariableExist(const QString& name); void RemoveIncrement(const QString& name); const QHash > *DataGObjects() const; const QHash *DataDetails() const; const QHash> *DataVariables() const; const QMap > DataMeasurements() const; const QMap > DataIncrements() const; const QMap > DataLengthLines() const; const QMap > DataLengthSplines() const; const QMap > DataLengthArcs() const; const QMap > DataAngleLines() const; const QMap > DataRadiusesArcs() const; const QMap > DataAnglesArcs() const; const QMap > DataAnglesCurves() const; static bool IsUnique(const QString &name); const Unit *GetPatternUnit() const; private: /** * @brief _id current id. New object will have value +1. For empty class equal 0. */ static quint32 _id; static qreal _size; static qreal _height; static QSet uniqueNames; QSharedDataPointer d; template uint qHash( const QSharedPointer &p ); template // cppcheck-suppress functionStatic const val GetObject(const QHash &obj, key id) const; template void UpdateObject(QHash &obj, const quint32 &id, val point); template static quint32 AddObject(QHash &obj, val value); template const QMap > DataVar(const VarType &type) const; }; /* * Defintion of templated member functions of VContainer */ //--------------------------------------------------------------------------------------------------------------------- template const QSharedPointer VContainer::GeometricObject(const quint32 &id) const { QSharedPointer gObj = QSharedPointer(); if (d->gObjects.contains(id)) { gObj = d->gObjects.value(id); } else { throw VExceptionBadId(tr("Can't find object"), id); } try { QSharedPointer obj = qSharedPointerDynamicCast(gObj); SCASSERT(obj.isNull() == false); return obj; } catch (const std::bad_alloc &) { throw VExceptionBadId(tr("Can't cast object"), id); } } //--------------------------------------------------------------------------------------------------------------------- /** * @brief GetVariable return varible by name * @param name variable's name * @return variable */ template QSharedPointer VContainer::GetVariable(QString name) const { SCASSERT(name.isEmpty()==false); if (d->variables.contains(name)) { try { QSharedPointer value = qSharedPointerDynamicCast(d->variables.value(name)); SCASSERT(value.isNull() == false); return value; } catch (const std::bad_alloc &) { throw VExceptionBadId(tr("Can't cast object"), name); } } else { throw VExceptionBadId(tr("Can't find object"), name); } } //--------------------------------------------------------------------------------------------------------------------- template void VContainer::AddCurve(const quint32 &id, const quint32 &parentId) { const QSharedPointer curve = GeometricObject(id); VSplineLength *length = new VSplineLength(id, parentId, curve.data()); AddVariable(length->GetName(), length); VSplineAngle *startAngle = new VSplineAngle(id, parentId, curve.data(), CurveAngle::StartAngle); AddVariable(startAngle->GetName(), startAngle); VSplineAngle *endAngle = new VSplineAngle(id, parentId, curve.data(), CurveAngle::EndAngle); AddVariable(endAngle->GetName(), endAngle); } //--------------------------------------------------------------------------------------------------------------------- template void VContainer::AddVariable(const QString& name, T *var) { if (d->variables.contains(name)) { if (d->variables.value(name)->GetType() == var->GetType()) { d->variables[name].clear(); } else { throw VExceptionBadId(tr("Can't find object. Type mismatch."), name); } } d->variables[name] = QSharedPointer(var); uniqueNames.insert(name); } //--------------------------------------------------------------------------------------------------------------------- template uint VContainer::qHash( const QSharedPointer &p ) { return qHash( p.data() ); } #endif // VCONTAINER_H