Browse Source

Fix two more FPID empty string parsing bugs.

pull/1/head
Wayne Stambaugh 12 years ago
parent
commit
6fb731189c
  1. 13
      cvpcb/readwrite_dlgs.cpp
  2. 7
      pcbnew/legacy_plugin.cpp

13
cvpcb/readwrite_dlgs.cpp

@ -74,17 +74,16 @@ void CVPCB_MAINFRAME::SetNewPkg( const wxString& aFootprintName )
// Check to see if the component has already a footprint set.
hasFootprint = !component->GetFPID().empty();
#if defined( USE_FP_LIB_TABLE )
FPID fpid;
wxCHECK_RET( fpid.Parse( aFootprintName ) < 0,
wxString::Format( wxT( "<%s> is not a valid FPID." ),
GetChars( aFootprintName ) ) );
if( !aFootprintName.IsEmpty() )
{
wxCHECK_RET( fpid.Parse( aFootprintName ) < 0,
wxString::Format( wxT( "<%s> is not a valid FPID." ),
GetChars( aFootprintName ) ) );
}
component->SetFPID( fpid );
#else
component->SetFPID( FPID( aFootprintName ) );
#endif
// create the new component description
description.Printf( CMP_FORMAT, componentIndex + 1,

7
pcbnew/legacy_plugin.cpp

@ -278,8 +278,13 @@ void LEGACY_PLUGIN::loadAllSections( bool doAppend )
{
auto_ptr<MODULE> module( new MODULE( m_board ) );
FPID fpid;
std::string fpName = StrPurge( line + SZ( "$MODULE" ) );
module->SetFPID( FPID( fpName ) );
if( !fpName.empty() )
fpid = FPID( fpName );
module->SetFPID( fpid );
LoadMODULE( module.get() );
m_board->Add( module.release(), ADD_APPEND );

Loading…
Cancel
Save