Update target length/skew to std::optional.
Also fixes a bug in the router where the target length would get trashed if set to maxLongLongInt. (We'd add the default tolerance to it sending it negative.)
This commit is contained in:
parent
e62b4f8ff4
commit
ecbe1df7c1
|
@ -391,11 +391,49 @@ public:
|
||||||
int GetSpacing() const { return m_settings.m_spacing; }
|
int GetSpacing() const { return m_settings.m_spacing; }
|
||||||
void SetSpacing( int aValue ) { m_settings.m_spacing = aValue; }
|
void SetSpacing( int aValue ) { m_settings.m_spacing = aValue; }
|
||||||
|
|
||||||
long long int GetTargetLength() const { return m_settings.m_targetLength.Opt(); }
|
std::optional<int> GetTargetLength() const
|
||||||
void SetTargetLength( long long int aValue ) { m_settings.SetTargetLength( aValue ); }
|
{
|
||||||
|
if( m_unconstrained )
|
||||||
|
return std::optional<int>();
|
||||||
|
else
|
||||||
|
return m_settings.m_targetLength.Opt();
|
||||||
|
}
|
||||||
|
|
||||||
int GetTargetSkew() const { return m_settings.m_targetSkew.Opt(); }
|
void SetTargetLength( std::optional<int> aValue )
|
||||||
void SetTargetSkew( int aValue ) { m_settings.SetTargetSkew( aValue ); }
|
{
|
||||||
|
if( aValue.has_value() )
|
||||||
|
{
|
||||||
|
m_unconstrained = false;
|
||||||
|
m_settings.SetTargetLength( aValue.value() );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_unconstrained = true;
|
||||||
|
m_settings.SetTargetLength( std::numeric_limits<long long int>::max() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
std::optional<int> GetTargetSkew() const
|
||||||
|
{
|
||||||
|
if( m_unconstrained )
|
||||||
|
return std::optional<int>();
|
||||||
|
else
|
||||||
|
return m_settings.m_targetSkew.Opt();
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetTargetSkew( std::optional<int> aValue )
|
||||||
|
{
|
||||||
|
if( aValue.has_value() )
|
||||||
|
{
|
||||||
|
m_unconstrained = false;
|
||||||
|
m_settings.SetTargetSkew( aValue.value() );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_unconstrained = true;
|
||||||
|
m_settings.SetTargetSkew( std::numeric_limits<int>::max() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bool GetOverrideCustomRules() const { return m_settings.m_overrideCustomRules; }
|
bool GetOverrideCustomRules() const { return m_settings.m_overrideCustomRules; }
|
||||||
void SetOverrideCustomRules( bool aOverride ) { m_settings.m_overrideCustomRules = aOverride; }
|
void SetOverrideCustomRules( bool aOverride ) { m_settings.m_overrideCustomRules = aOverride; }
|
||||||
|
@ -2371,7 +2409,7 @@ static struct PCB_TUNING_PATTERN_DESC
|
||||||
return !isSkew( aItem );
|
return !isSkew( aItem );
|
||||||
};
|
};
|
||||||
|
|
||||||
propMgr.AddProperty( new PROPERTY<PCB_TUNING_PATTERN, long long int>(
|
propMgr.AddProperty( new PROPERTY<PCB_TUNING_PATTERN, std::optional<int>>(
|
||||||
_HKI( "Target Length" ),
|
_HKI( "Target Length" ),
|
||||||
&PCB_TUNING_PATTERN::SetTargetLength,
|
&PCB_TUNING_PATTERN::SetTargetLength,
|
||||||
&PCB_TUNING_PATTERN::GetTargetLength,
|
&PCB_TUNING_PATTERN::GetTargetLength,
|
||||||
|
@ -2380,7 +2418,7 @@ static struct PCB_TUNING_PATTERN_DESC
|
||||||
.SetAvailableFunc( notIsSkew );
|
.SetAvailableFunc( notIsSkew );
|
||||||
|
|
||||||
|
|
||||||
propMgr.AddProperty( new PROPERTY<PCB_TUNING_PATTERN, int>(
|
propMgr.AddProperty( new PROPERTY<PCB_TUNING_PATTERN, std::optional<int>>(
|
||||||
_HKI( "Target Skew" ), &PCB_TUNING_PATTERN::SetTargetSkew,
|
_HKI( "Target Skew" ), &PCB_TUNING_PATTERN::SetTargetSkew,
|
||||||
&PCB_TUNING_PATTERN::GetTargetSkew,
|
&PCB_TUNING_PATTERN::GetTargetSkew,
|
||||||
PROPERTY_DISPLAY::PT_SIZE, ORIGIN_TRANSFORMS::ABS_X_COORD ),
|
PROPERTY_DISPLAY::PT_SIZE, ORIGIN_TRANSFORMS::ABS_X_COORD ),
|
||||||
|
|
|
@ -91,9 +91,18 @@ public:
|
||||||
void SetTargetLength( long long int aOpt )
|
void SetTargetLength( long long int aOpt )
|
||||||
{
|
{
|
||||||
m_targetLength.SetOpt( aOpt );
|
m_targetLength.SetOpt( aOpt );
|
||||||
|
|
||||||
|
if( aOpt == std::numeric_limits<long long int>::max() )
|
||||||
|
{
|
||||||
|
m_targetLength.SetMin( 0 );
|
||||||
|
m_targetLength.SetMax( aOpt );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
m_targetLength.SetMin( aOpt - DEFAULT_TOLERANCE );
|
m_targetLength.SetMin( aOpt - DEFAULT_TOLERANCE );
|
||||||
m_targetLength.SetMax( aOpt + DEFAULT_TOLERANCE );
|
m_targetLength.SetMax( aOpt + DEFAULT_TOLERANCE );
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void SetTargetLength( const MINOPTMAX<int>& aConstraint )
|
void SetTargetLength( const MINOPTMAX<int>& aConstraint )
|
||||||
{
|
{
|
||||||
|
@ -109,9 +118,18 @@ public:
|
||||||
void SetTargetSkew( int aOpt )
|
void SetTargetSkew( int aOpt )
|
||||||
{
|
{
|
||||||
m_targetSkew.SetOpt( aOpt );
|
m_targetSkew.SetOpt( aOpt );
|
||||||
|
|
||||||
|
if( aOpt == std::numeric_limits<int>::max() )
|
||||||
|
{
|
||||||
|
m_targetSkew.SetMin( 0 );
|
||||||
|
m_targetSkew.SetMax( aOpt );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
m_targetSkew.SetMin( aOpt - DEFAULT_TOLERANCE );
|
m_targetSkew.SetMin( aOpt - DEFAULT_TOLERANCE );
|
||||||
m_targetSkew.SetMax( aOpt + DEFAULT_TOLERANCE );
|
m_targetSkew.SetMax( aOpt + DEFAULT_TOLERANCE );
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void SetTargetSkew( const MINOPTMAX<int>& aConstraint )
|
void SetTargetSkew( const MINOPTMAX<int>& aConstraint )
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue