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:
parent
cb93d2940c
commit
cc75d8c0af
|
@ -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 ) ) );
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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 )
|
||||||
|
|
Loading…
Reference in New Issue