Validate dimensions while reading multisize measurements.

This commit is contained in:
Roman Telezhynskyi 2023-03-23 08:36:11 +02:00
parent 3f2806a695
commit 2334a04fbd
3 changed files with 42 additions and 19 deletions

View File

@ -204,10 +204,12 @@ auto VAbstartMeasurementDimension::ValidBases(qreal min, qreal max, qreal step,
} }
//--------------------------------------------------------------------------------------------------------------------- //---------------------------------------------------------------------------------------------------------------------
auto VAbstartMeasurementDimension::IsRangeValid() -> bool auto VAbstartMeasurementDimension::IsRangeValid() const -> bool
{ {
bool valid = m_minValue > 0 && m_maxValue > 0 && m_minValue >= RangeMin() && m_minValue <= RangeMax() bool valid = m_minValue > 0 && m_maxValue > 0 &&
&& m_minValue <= m_maxValue; (m_minValue > RangeMin() || VFuzzyComparePossibleNulls(m_minValue, RangeMin())) &&
(m_maxValue < RangeMax() || VFuzzyComparePossibleNulls(m_maxValue, RangeMax())) &&
(m_minValue < m_maxValue || VFuzzyComparePossibleNulls(m_minValue, m_maxValue));
if (not valid) if (not valid)
{ {
@ -218,7 +220,7 @@ auto VAbstartMeasurementDimension::IsRangeValid() -> bool
} }
//--------------------------------------------------------------------------------------------------------------------- //---------------------------------------------------------------------------------------------------------------------
auto VAbstartMeasurementDimension::IsStepValid() -> bool auto VAbstartMeasurementDimension::IsStepValid() const -> bool
{ {
bool valid = ValidSteps().indexOf(m_step) != -1; bool valid = ValidSteps().indexOf(m_step) != -1;
if (not valid) if (not valid)
@ -230,7 +232,7 @@ auto VAbstartMeasurementDimension::IsStepValid() -> bool
} }
//--------------------------------------------------------------------------------------------------------------------- //---------------------------------------------------------------------------------------------------------------------
auto VAbstartMeasurementDimension::IsBaseValid() -> bool auto VAbstartMeasurementDimension::IsBaseValid() const -> bool
{ {
bool valid = ValidBases().indexOf(m_baseValue) != -1; bool valid = ValidBases().indexOf(m_baseValue) != -1;
if (not valid) if (not valid)
@ -244,7 +246,14 @@ auto VAbstartMeasurementDimension::IsBaseValid() -> bool
//--------------------------------------------------------------------------------------------------------------------- //---------------------------------------------------------------------------------------------------------------------
auto VAbstartMeasurementDimension::IsUnitsValid() const -> bool auto VAbstartMeasurementDimension::IsUnitsValid() const -> bool
{ {
return m_units == Unit::Cm || m_units == Unit::Mm || m_units == Unit::Inch; bool valid = (m_units == Unit::Cm || m_units == Unit::Mm || m_units == Unit::Inch);
if (not valid)
{
m_error = QCoreApplication::translate("VAbstartMeasurementDimension", "Units are invalid");
}
return valid;
} }
//--------------------------------------------------------------------------------------------------------------------- //---------------------------------------------------------------------------------------------------------------------

View File

@ -107,23 +107,23 @@ public:
void SetCustomName(const QString &newCustomName); void SetCustomName(const QString &newCustomName);
protected: protected:
auto IsRangeValid() -> bool; auto IsRangeValid() const -> bool;
auto IsStepValid() -> bool; auto IsStepValid() const -> bool;
auto IsBaseValid() -> bool; auto IsBaseValid() const -> bool;
auto IsUnitsValid() const -> bool; auto IsUnitsValid() const -> bool;
private: private:
Q_DISABLE_COPY_MOVE(VAbstartMeasurementDimension) // NOLINT Q_DISABLE_COPY_MOVE(VAbstartMeasurementDimension) // NOLINT
Unit m_units{Unit::Cm}; Unit m_units{Unit::Cm};
qreal m_minValue{0}; qreal m_minValue{0};
qreal m_maxValue{0}; qreal m_maxValue{0};
qreal m_step{-1}; qreal m_step{-1};
qreal m_baseValue{0}; qreal m_baseValue{0};
QString m_error{}; mutable QString m_error{};
DimesionLabels m_labels{}; DimesionLabels m_labels{};
bool m_measurement{true}; bool m_measurement{true};
QString m_customName{}; QString m_customName{};
}; };
//--------------------------------------------------------------------------------------------------------------------- //---------------------------------------------------------------------------------------------------------------------

View File

@ -41,6 +41,7 @@
#include <QGlobalStatic> #include <QGlobalStatic>
#include "../ifc/exception/vexceptionemptyparameter.h" #include "../ifc/exception/vexceptionemptyparameter.h"
#include "../ifc/exception/vexceptionobjecterror.h"
#include "../ifc/xml/vvitconverter.h" #include "../ifc/xml/vvitconverter.h"
#include "../ifc/xml/vvstconverter.h" #include "../ifc/xml/vvstconverter.h"
#include "../ifc/ifcdef.h" #include "../ifc/ifcdef.h"
@ -153,7 +154,12 @@ void VMeasurements::setXMLContent(const QString &fileName)
VDomDocument::setXMLContent(fileName); VDomDocument::setXMLContent(fileName);
type = ReadType(); type = ReadType();
m_units = ReadUnits(); m_units = ReadUnits();
m_dimensions = ReadDimensions();
if (type == MeasurementsType::Multisize &&
VVSTConverter::MeasurementMaxVer == GetFormatVersion(GetFormatVersionStr()))
{
m_dimensions = ReadDimensions();
}
} }
//--------------------------------------------------------------------------------------------------------------------- //---------------------------------------------------------------------------------------------------------------------
@ -1427,6 +1433,14 @@ auto VMeasurements::ReadDimensions() const -> VDimensions
dimension->SetBodyMeasurement(GetParametrBool(dom, AttrMeasurement, trueStr)); dimension->SetBodyMeasurement(GetParametrBool(dom, AttrMeasurement, trueStr));
dimension->SetCustomName(GetParametrEmptyString(dom, AttrCustomName)); dimension->SetCustomName(GetParametrEmptyString(dom, AttrCustomName));
dimension->SetLabels(ReadDimensionLabels(dom)); dimension->SetLabels(ReadDimensionLabels(dom));
if (not dimension->IsValid())
{
VExceptionObjectError excep(tr("Dimension is not valid"), dom);
excep.AddMoreInformation(dimension->Error());
throw excep;
}
dimensions.insert(type, dimension); dimensions.insert(type, dimension);
} }