Exercise more care when comparing doubles.

Fixes https://gitlab.com/kicad/code/kicad/-/issues/17249

(cherry picked from commit 62d4bd7c1d)
This commit is contained in:
Jeff Young 2024-05-05 17:32:07 +01:00
parent cb93d2940c
commit cc75d8c0af
3 changed files with 10 additions and 23 deletions

View File

@ -266,8 +266,8 @@ bool padNeedsUpdate( const PAD* a, const PAD* b, REPORTER* aReporter )
wxString::Format( _( "%s fabrication property differs." ), PAD_DESC( a ) ) ); wxString::Format( _( "%s fabrication property differs." ), PAD_DESC( a ) ) );
// The pad orientation, for historical reasons is the pad rotation + parent rotation. // The pad orientation, for historical reasons is the pad rotation + parent rotation.
TEST_D( ( a->GetOrientation() - a->GetParentFootprint()->GetOrientation() ).Normalize().AsDegrees(), TEST_D( a->GetFPRelativeOrientation().Normalize().AsDegrees(),
( b->GetOrientation() - b->GetParentFootprint()->GetOrientation() ).Normalize().AsDegrees(), b->GetFPRelativeOrientation().Normalize().AsDegrees(),
wxString::Format( _( "%s orientation differs." ), PAD_DESC( a ) ) ); wxString::Format( _( "%s orientation differs." ), PAD_DESC( a ) ) );
TEST( a->GetSize(), b->GetSize(), TEST( a->GetSize(), b->GetSize(),
@ -275,27 +275,14 @@ bool padNeedsUpdate( const PAD* a, const PAD* b, REPORTER* aReporter )
TEST( a->GetDelta(), b->GetDelta(), TEST( a->GetDelta(), b->GetDelta(),
wxString::Format( _( "%s trapezoid delta differs." ), PAD_DESC( a ) ) ); wxString::Format( _( "%s trapezoid delta differs." ), PAD_DESC( a ) ) );
if( a->GetRoundRectCornerRadius() != b->GetRoundRectCornerRadius() TEST_D( a->GetRoundRectRadiusRatio(), b->GetRoundRectRadiusRatio(),
|| a->GetRoundRectRadiusRatio() != b->GetRoundRectRadiusRatio() ) wxString::Format( _( "%s rounded corners differ." ), PAD_DESC( a ) ) );
{
diff = true;
if( aReporter ) TEST_D( a->GetChamferRectRatio(), b->GetChamferRectRatio(),
aReporter->Report( wxString::Format( _( "%s rounded corners differ." ), PAD_DESC( a ) ) ); wxString::Format( _( "%s chamfered corner sizes differ." ), PAD_DESC( a ) ) );
else
return true;
}
if( a->GetChamferRectRatio() != b->GetChamferRectRatio() TEST( a->GetChamferPositions(), b->GetChamferPositions(),
|| a->GetChamferPositions() != b->GetChamferPositions() ) wxString::Format( _( "%s chamfered corners differ." ), PAD_DESC( a ) ) );
{
diff = true;
if( aReporter )
aReporter->Report( wxString::Format( _( "%s chamfered corners differ." ), PAD_DESC( a ) ) );
else
return true;
}
TEST_PT( a->GetOffset(), b->GetOffset(), TEST_PT( a->GetOffset(), b->GetOffset(),
wxString::Format( _( "%s shape offset from hole differs." ), PAD_DESC( a ) ) ); wxString::Format( _( "%s shape offset from hole differs." ), PAD_DESC( a ) ) );

View File

@ -719,7 +719,7 @@ void PAD::SetFPRelativeOrientation( const EDA_ANGLE& aAngle )
} }
EDA_ANGLE PAD::GetFPRelativeOrientation() EDA_ANGLE PAD::GetFPRelativeOrientation() const
{ {
if( FOOTPRINT* parentFP = GetParentFootprint() ) if( FOOTPRINT* parentFP = GetParentFootprint() )
return GetOrientation() - parentFP->GetOrientation(); return GetOrientation() - parentFP->GetOrientation();

View File

@ -340,7 +340,7 @@ public:
* Return the rotation angle of the pad. * Return the rotation angle of the pad.
*/ */
EDA_ANGLE GetOrientation() const { return m_orient; } EDA_ANGLE GetOrientation() const { return m_orient; }
EDA_ANGLE GetFPRelativeOrientation(); EDA_ANGLE GetFPRelativeOrientation() const;
// For property system // For property system
void SetOrientationDegrees( double aOrientation ) void SetOrientationDegrees( double aOrientation )