Improve clarity.
This commit is contained in:
parent
5b70508624
commit
ed61440d2a
|
@ -1,7 +1,8 @@
|
||||||
/*
|
/*
|
||||||
* This program source code file is part of KiCad, a free EDA CAD application.
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
||||||
*
|
*
|
||||||
* Copyright (C) 2016 CERN
|
* Copyright (C) 2016-2021 CERN
|
||||||
|
* Copyright (C) 2016-2021 KiCad Developers, see CHANGELOG.TXT for contributors.
|
||||||
* @author Maciej Suminski <maciej.suminski@cern.ch>
|
* @author Maciej Suminski <maciej.suminski@cern.ch>
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or
|
* This program is free software; you can redistribute it and/or
|
||||||
|
@ -41,8 +42,22 @@ static bool empty( const wxTextEntryBase* aCtrl )
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
DIALOG_SIM_SETTINGS::DIALOG_SIM_SETTINGS( wxWindow* aParent )
|
static void setStringSelection( wxRadioBox* aCtrl, const wxString& aStr )
|
||||||
: DIALOG_SIM_SETTINGS_BASE( aParent ), m_exporter( nullptr ), m_spiceEmptyValidator( true )
|
{
|
||||||
|
aCtrl->SetSelection( aCtrl->FindString( aStr ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static wxString getStringSelection( const wxRadioBox* aCtrl )
|
||||||
|
{
|
||||||
|
return aCtrl->GetString( aCtrl->GetSelection() );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
DIALOG_SIM_SETTINGS::DIALOG_SIM_SETTINGS( wxWindow* aParent ) :
|
||||||
|
DIALOG_SIM_SETTINGS_BASE( aParent ),
|
||||||
|
m_exporter( nullptr ),
|
||||||
|
m_spiceEmptyValidator( true )
|
||||||
{
|
{
|
||||||
m_posIntValidator.SetMin( 1 );
|
m_posIntValidator.SetMin( 1 );
|
||||||
|
|
||||||
|
@ -148,7 +163,7 @@ bool DIALOG_SIM_SETTINGS::TransferDataFromWindow()
|
||||||
if( !m_pgAC->Validate() )
|
if( !m_pgAC->Validate() )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
m_simCommand = wxString::Format( ".ac %s %s %s %s",
|
m_simCommand.Printf( ".ac %s %s %s %s",
|
||||||
scaleToString( m_acScale->GetSelection() ),
|
scaleToString( m_acScale->GetSelection() ),
|
||||||
m_acPointsNumber->GetValue(),
|
m_acPointsNumber->GetValue(),
|
||||||
SPICE_VALUE( m_acFreqStart->GetValue() ).ToSpiceString(),
|
SPICE_VALUE( m_acFreqStart->GetValue() ).ToSpiceString(),
|
||||||
|
@ -162,6 +177,7 @@ bool DIALOG_SIM_SETTINGS::TransferDataFromWindow()
|
||||||
wxString simCmd = wxString( ".dc " );
|
wxString simCmd = wxString( ".dc " );
|
||||||
|
|
||||||
wxString src1 = evaluateDCControls( m_dcSource1, m_dcStart1, m_dcStop1, m_dcIncr1 );
|
wxString src1 = evaluateDCControls( m_dcSource1, m_dcStart1, m_dcStop1, m_dcIncr1 );
|
||||||
|
|
||||||
if( src1.IsEmpty() )
|
if( src1.IsEmpty() )
|
||||||
return false;
|
return false;
|
||||||
else
|
else
|
||||||
|
@ -170,6 +186,7 @@ bool DIALOG_SIM_SETTINGS::TransferDataFromWindow()
|
||||||
if( m_dcEnable2->IsChecked() )
|
if( m_dcEnable2->IsChecked() )
|
||||||
{
|
{
|
||||||
wxString src2 = evaluateDCControls( m_dcSource2, m_dcStart2, m_dcStop2, m_dcIncr2 );
|
wxString src2 = evaluateDCControls( m_dcSource2, m_dcStart2, m_dcStop2, m_dcIncr2 );
|
||||||
|
|
||||||
if( src2.IsEmpty() )
|
if( src2.IsEmpty() )
|
||||||
return false;
|
return false;
|
||||||
else
|
else
|
||||||
|
@ -193,10 +210,14 @@ bool DIALOG_SIM_SETTINGS::TransferDataFromWindow()
|
||||||
|
|
||||||
if( empty( m_noiseMeas ) || empty( m_noiseSrc ) || empty( m_noisePointsNumber )
|
if( empty( m_noiseMeas ) || empty( m_noiseSrc ) || empty( m_noisePointsNumber )
|
||||||
|| empty( m_noiseFreqStart ) || empty( m_noiseFreqStop ) )
|
|| empty( m_noiseFreqStart ) || empty( m_noiseFreqStop ) )
|
||||||
|
{
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
wxString ref = empty( m_noiseRef )
|
wxString ref;
|
||||||
? wxString() : wxString::Format( ", %d", netMap.at( m_noiseRef->GetValue() ) );
|
|
||||||
|
if( !empty( m_noiseRef ) )
|
||||||
|
ref = wxString::Format( ", %d", netMap.at( m_noiseRef->GetValue() ) );
|
||||||
|
|
||||||
wxString noiseSource = m_exporter->GetSpiceDevice( m_noiseSrc->GetValue() );
|
wxString noiseSource = m_exporter->GetSpiceDevice( m_noiseSrc->GetValue() );
|
||||||
|
|
||||||
|
@ -204,7 +225,7 @@ bool DIALOG_SIM_SETTINGS::TransferDataFromWindow()
|
||||||
if( noiseSource[0] != 'v' && noiseSource[0] != 'V' )
|
if( noiseSource[0] != 'v' && noiseSource[0] != 'V' )
|
||||||
noiseSource += 'v' + noiseSource;
|
noiseSource += 'v' + noiseSource;
|
||||||
|
|
||||||
m_simCommand = wxString::Format( ".noise v(%d%s) %s %s %s %s %s",
|
m_simCommand.Printf( ".noise v(%d%s) %s %s %s %s %s",
|
||||||
netMap.at( m_noiseMeas->GetValue() ), ref,
|
netMap.at( m_noiseMeas->GetValue() ), ref,
|
||||||
noiseSource, scaleToString( m_noiseScale->GetSelection() ),
|
noiseSource, scaleToString( m_noiseScale->GetSelection() ),
|
||||||
m_noisePointsNumber->GetValue(),
|
m_noisePointsNumber->GetValue(),
|
||||||
|
@ -226,10 +247,12 @@ bool DIALOG_SIM_SETTINGS::TransferDataFromWindow()
|
||||||
if( !m_pgTransient->Validate() )
|
if( !m_pgTransient->Validate() )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
wxString initial = empty( m_transInitial )
|
wxString initial;
|
||||||
? "" : SPICE_VALUE( m_transInitial->GetValue() ).ToSpiceString();
|
|
||||||
|
|
||||||
m_simCommand = wxString::Format( ".tran %s %s %s",
|
if( !empty( m_transInitial ) )
|
||||||
|
initial = SPICE_VALUE( m_transInitial->GetValue() ).ToSpiceString();
|
||||||
|
|
||||||
|
m_simCommand.Printf( ".tran %s %s %s",
|
||||||
SPICE_VALUE( m_transStep->GetValue() ).ToSpiceString(),
|
SPICE_VALUE( m_transStep->GetValue() ).ToSpiceString(),
|
||||||
SPICE_VALUE( m_transFinal->GetValue() ).ToSpiceString(),
|
SPICE_VALUE( m_transFinal->GetValue() ).ToSpiceString(),
|
||||||
initial );
|
initial );
|
||||||
|
@ -309,10 +332,8 @@ void DIALOG_SIM_SETTINGS::updateDCSources( wxChar aType, wxChoice* aSource )
|
||||||
for( const auto& item : m_exporter->GetSpiceItems() )
|
for( const auto& item : m_exporter->GetSpiceItems() )
|
||||||
{
|
{
|
||||||
if( item.m_primitive == aType )
|
if( item.m_primitive == aType )
|
||||||
{
|
|
||||||
sourcesList.push_back( item.m_refName );
|
sourcesList.push_back( item.m_refName );
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
std::sort( sourcesList.begin(), sourcesList.end(),
|
std::sort( sourcesList.begin(), sourcesList.end(),
|
||||||
[](wxString& a, wxString& b) -> bool
|
[](wxString& a, wxString& b) -> bool
|
||||||
|
@ -333,14 +354,12 @@ void DIALOG_SIM_SETTINGS::updateDCSources( wxChar aType, wxChoice* aSource )
|
||||||
aSource->Enable( enableSrcSelection );
|
aSource->Enable( enableSrcSelection );
|
||||||
|
|
||||||
aSource->Clear();
|
aSource->Clear();
|
||||||
|
|
||||||
for( auto& src : sourcesList )
|
for( auto& src : sourcesList )
|
||||||
aSource->Append( src );
|
aSource->Append( src );
|
||||||
|
|
||||||
// Try to restore the previous selection, if possible
|
// Try to restore the previous selection, if possible
|
||||||
int idx = aSource->FindString( prevSelection );
|
aSource->SetStringSelection( prevSelection );
|
||||||
|
|
||||||
if( idx != wxNOT_FOUND )
|
|
||||||
aSource->SetSelection( idx );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -352,7 +371,8 @@ bool DIALOG_SIM_SETTINGS::parseCommand( const wxString& aCommand )
|
||||||
wxStringTokenizer tokenizer( aCommand, " " );
|
wxStringTokenizer tokenizer( aCommand, " " );
|
||||||
wxString tkn = tokenizer.GetNextToken().Lower();
|
wxString tkn = tokenizer.GetNextToken().Lower();
|
||||||
|
|
||||||
try {
|
try
|
||||||
|
{
|
||||||
if( tkn == ".ac" )
|
if( tkn == ".ac" )
|
||||||
{
|
{
|
||||||
m_simPages->SetSelection( m_simPages->FindPage( m_pgAC ) );
|
m_simPages->SetSelection( m_simPages->FindPage( m_pgAC ) );
|
||||||
|
@ -378,33 +398,32 @@ bool DIALOG_SIM_SETTINGS::parseCommand( const wxString& aCommand )
|
||||||
{
|
{
|
||||||
SPICE_DC_PARAMS src1, src2;
|
SPICE_DC_PARAMS src1, src2;
|
||||||
src2.m_vincrement = SPICE_VALUE( -1 );
|
src2.m_vincrement = SPICE_VALUE( -1 );
|
||||||
|
|
||||||
if( !m_exporter->ParseDCCommand( aCommand, &src1, &src2 ) )
|
if( !m_exporter->ParseDCCommand( aCommand, &src1, &src2 ) )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
m_simPages->SetSelection( m_simPages->FindPage( m_pgDC ) );
|
m_simPages->SetSelection( m_simPages->FindPage( m_pgDC ) );
|
||||||
|
|
||||||
if( !src1.m_source.IsSameAs( wxT( "TEMP" ), false ) == 0 )
|
if( src1.m_source.IsSameAs( wxT( "TEMP" ), false ) )
|
||||||
m_dcSourceType1->SetSelection( m_dcSourceType1->FindString( src1.m_source ) );
|
setStringSelection( m_dcSourceType1, wxT( "TEMP" ) );
|
||||||
else
|
else
|
||||||
m_dcSourceType1->SetSelection(
|
setStringSelection( m_dcSourceType1, src1.m_source.GetChar( 0 ) );
|
||||||
m_dcSourceType1->FindString( src1.m_source.GetChar( 0 ) ) );
|
|
||||||
|
|
||||||
updateDCSources( src1.m_source.GetChar( 0 ), m_dcSource1 );
|
updateDCSources( src1.m_source.GetChar( 0 ), m_dcSource1 );
|
||||||
m_dcSource1->SetSelection( m_dcSource1->FindString( src1.m_source ) );
|
m_dcSource1->SetStringSelection( src1.m_source );
|
||||||
m_dcStart1->SetValue( src1.m_vstart.ToSpiceString() );
|
m_dcStart1->SetValue( src1.m_vstart.ToSpiceString() );
|
||||||
m_dcStop1->SetValue( src1.m_vend.ToSpiceString() );
|
m_dcStop1->SetValue( src1.m_vend.ToSpiceString() );
|
||||||
m_dcIncr1->SetValue( src1.m_vincrement.ToSpiceString() );
|
m_dcIncr1->SetValue( src1.m_vincrement.ToSpiceString() );
|
||||||
|
|
||||||
if( src2.m_vincrement.ToDouble() != -1 )
|
if( src2.m_vincrement.ToDouble() != -1 )
|
||||||
{
|
{
|
||||||
if( !src2.m_source.IsSameAs( wxT( "TEMP" ), false ) == 0 )
|
if( src2.m_source.IsSameAs( wxT( "TEMP" ), false ) )
|
||||||
m_dcSourceType2->SetSelection( m_dcSourceType2->FindString( src2.m_source ) );
|
setStringSelection( m_dcSourceType2, wxT( "TEMP" ) );
|
||||||
else
|
else
|
||||||
m_dcSourceType2->SetSelection(
|
setStringSelection( m_dcSourceType2, src2.m_source.GetChar( 0 ) );
|
||||||
m_dcSourceType2->FindString( src2.m_source.GetChar( 0 ) ) );
|
|
||||||
|
|
||||||
updateDCSources( src2.m_source.GetChar( 0 ), m_dcSource2 );
|
updateDCSources( src2.m_source.GetChar( 0 ), m_dcSource2 );
|
||||||
m_dcSource2->SetSelection( m_dcSource2->FindString( src2.m_source ) );
|
m_dcSource2->SetStringSelection( src2.m_source );
|
||||||
m_dcStart2->SetValue( src2.m_vstart.ToSpiceString() );
|
m_dcStart2->SetValue( src2.m_vstart.ToSpiceString() );
|
||||||
m_dcStop2->SetValue( src2.m_vend.ToSpiceString() );
|
m_dcStop2->SetValue( src2.m_vend.ToSpiceString() );
|
||||||
m_dcIncr2->SetValue( src2.m_vincrement.ToSpiceString() );
|
m_dcIncr2->SetValue( src2.m_vincrement.ToSpiceString() );
|
||||||
|
@ -471,11 +490,9 @@ void DIALOG_SIM_SETTINGS::onSwapDCSources( wxCommandEvent& event )
|
||||||
m_dcSourceType1->SetSelection( m_dcSourceType2->GetSelection() );
|
m_dcSourceType1->SetSelection( m_dcSourceType2->GetSelection() );
|
||||||
m_dcSourceType2->SetSelection( sel );
|
m_dcSourceType2->SetSelection( sel );
|
||||||
|
|
||||||
wxChar type1 =
|
wxChar type1 = getStringSelection( m_dcSourceType1 ).Upper().GetChar( 0 );
|
||||||
m_dcSourceType1->GetString( m_dcSourceType1->GetSelection() ).Upper().GetChar( 0 );
|
|
||||||
updateDCSources( type1, m_dcSource1 );
|
updateDCSources( type1, m_dcSource1 );
|
||||||
wxChar type2 =
|
wxChar type2 = getStringSelection( m_dcSourceType2 ).Upper().GetChar( 0 );
|
||||||
m_dcSourceType2->GetString( m_dcSourceType2->GetSelection() ).Upper().GetChar( 0 );
|
|
||||||
updateDCSources( type2, m_dcSource2 );
|
updateDCSources( type2, m_dcSource2 );
|
||||||
|
|
||||||
m_dcSource1->SetSelection( src2 );
|
m_dcSource1->SetSelection( src2 );
|
||||||
|
@ -489,8 +506,7 @@ void DIALOG_SIM_SETTINGS::onSwapDCSources( wxCommandEvent& event )
|
||||||
void DIALOG_SIM_SETTINGS::onDCEnableSecondSource( wxCommandEvent& event )
|
void DIALOG_SIM_SETTINGS::onDCEnableSecondSource( wxCommandEvent& event )
|
||||||
{
|
{
|
||||||
bool is2ndSrcEnabled = m_dcEnable2->IsChecked();
|
bool is2ndSrcEnabled = m_dcEnable2->IsChecked();
|
||||||
wxChar type =
|
wxChar type = getStringSelection( m_dcSourceType2 ).Upper().GetChar( 0 );
|
||||||
m_dcSourceType2->GetString( m_dcSourceType2->GetSelection() ).Upper().GetChar( 0 );
|
|
||||||
|
|
||||||
m_dcSourceType2->Enable( is2ndSrcEnabled );
|
m_dcSourceType2->Enable( is2ndSrcEnabled );
|
||||||
m_dcSource2->Enable( is2ndSrcEnabled && type != 'T' );
|
m_dcSource2->Enable( is2ndSrcEnabled && type != 'T' );
|
||||||
|
@ -513,6 +529,7 @@ void DIALOG_SIM_SETTINGS::updateDCUnits( wxChar aType, wxChoice* aSource,
|
||||||
case 'R': unit = _( "Ohms" ); break;
|
case 'R': unit = _( "Ohms" ); break;
|
||||||
case 'T': unit = wxT( "\u00B0C" ); break;
|
case 'T': unit = wxT( "\u00B0C" ); break;
|
||||||
}
|
}
|
||||||
|
|
||||||
aStartValUnit->SetLabel( unit );
|
aStartValUnit->SetLabel( unit );
|
||||||
aEndValUnit->SetLabel( unit );
|
aEndValUnit->SetLabel( unit );
|
||||||
aStepUnit->SetLabel( unit );
|
aStepUnit->SetLabel( unit );
|
||||||
|
|
Loading…
Reference in New Issue