2007-05-06 16:03:28 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: dialog_netlist.cpp
|
|
|
|
// Author: jean-pierre Charras
|
2009-04-24 07:36:36 +00:00
|
|
|
// Licence: GPL
|
2007-05-06 16:03:28 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2012-01-23 04:33:36 +00:00
|
|
|
#include <fctsys.h>
|
|
|
|
#include <appl_wxstruct.h>
|
|
|
|
#include <confirm.h>
|
|
|
|
#include <pcbnew.h>
|
|
|
|
#include <wxPcbStruct.h>
|
|
|
|
#include <macros.h>
|
|
|
|
#include <pcbcommon.h>
|
2011-09-23 13:57:12 +00:00
|
|
|
|
2012-01-23 04:33:36 +00:00
|
|
|
#include <pcbnew_config.h>
|
|
|
|
#include <class_board_design_settings.h>
|
2012-02-16 20:03:33 +00:00
|
|
|
#include <wildcards_and_files_ext.h>
|
2007-05-06 16:03:28 +00:00
|
|
|
|
2012-01-23 04:33:36 +00:00
|
|
|
#include <dialog_netlist.h>
|
2007-05-06 16:03:28 +00:00
|
|
|
|
2011-05-03 12:57:44 +00:00
|
|
|
void PCB_EDIT_FRAME::InstallNetlistFrame( wxDC* DC )
|
2007-05-06 16:03:28 +00:00
|
|
|
{
|
2010-04-23 14:46:00 +00:00
|
|
|
/* Setup the netlist file name to the last net list file read or the board file
|
|
|
|
* name if no last file read is not set.
|
|
|
|
*/
|
|
|
|
wxFileName fn = GetLastNetListRead();
|
2011-03-22 17:58:58 +00:00
|
|
|
wxString lastNetlistName = GetLastNetListRead();
|
2007-05-06 16:03:28 +00:00
|
|
|
|
2010-04-23 14:46:00 +00:00
|
|
|
if( !fn.FileExists() )
|
|
|
|
{
|
2011-01-20 16:34:57 +00:00
|
|
|
fn = GetScreen()->GetFileName();
|
2012-03-08 17:47:23 +00:00
|
|
|
fn.SetExt( NetlistFileExtension );
|
2011-08-19 13:08:24 +00:00
|
|
|
lastNetlistName = fn.GetFullPath();
|
2010-04-23 14:46:00 +00:00
|
|
|
}
|
2008-03-22 18:08:44 +00:00
|
|
|
|
2011-03-22 17:58:58 +00:00
|
|
|
DIALOG_NETLIST frame( this, DC, lastNetlistName );
|
2007-05-06 16:03:28 +00:00
|
|
|
|
2009-04-24 07:36:36 +00:00
|
|
|
frame.ShowModal();
|
2011-03-22 17:58:58 +00:00
|
|
|
|
|
|
|
// Save project settings if needed.
|
|
|
|
// Project settings are saved in the corresponding <board name>.pro file
|
|
|
|
if( lastNetlistName != GetLastNetListRead() &&
|
|
|
|
!GetScreen()->GetFileName().IsEmpty() &&
|
|
|
|
IsOK(NULL, _("Project config has changed. Save it ?") ) )
|
|
|
|
{
|
|
|
|
wxFileName fn = GetScreen()->GetFileName();
|
|
|
|
fn.SetExt( ProjectFileExtension );
|
|
|
|
wxGetApp().WriteProjectConfig( fn.GetFullPath(), GROUP,
|
|
|
|
GetProjectFileParameters() );
|
|
|
|
}
|
2007-05-06 16:03:28 +00:00
|
|
|
}
|
|
|
|
|
2008-03-22 18:08:44 +00:00
|
|
|
|
2011-03-01 19:26:17 +00:00
|
|
|
DIALOG_NETLIST::DIALOG_NETLIST( PCB_EDIT_FRAME* aParent, wxDC * aDC,
|
2010-04-23 14:46:00 +00:00
|
|
|
const wxString & aNetlistFull_Filename )
|
|
|
|
: DIALOG_NETLIST_FBP( aParent )
|
2008-03-22 18:08:44 +00:00
|
|
|
{
|
2009-04-24 07:36:36 +00:00
|
|
|
m_Parent = aParent;
|
|
|
|
m_DC = aDC;
|
2010-04-23 14:46:00 +00:00
|
|
|
m_NetlistFilenameCtrl->SetValue( aNetlistFull_Filename );
|
2008-03-22 18:08:44 +00:00
|
|
|
|
2009-04-24 07:36:36 +00:00
|
|
|
Init();
|
2008-03-22 18:08:44 +00:00
|
|
|
|
2011-05-03 12:57:44 +00:00
|
|
|
GetSizer()->SetSizeHints( this );
|
2007-05-06 16:03:28 +00:00
|
|
|
}
|
|
|
|
|
2008-03-22 18:08:44 +00:00
|
|
|
|
2009-04-24 07:36:36 +00:00
|
|
|
void DIALOG_NETLIST::Init()
|
2007-05-06 16:03:28 +00:00
|
|
|
{
|
2009-04-24 07:36:36 +00:00
|
|
|
SetFocus();
|
2007-05-06 16:03:28 +00:00
|
|
|
}
|
|
|
|
|
2009-04-24 07:36:36 +00:00
|
|
|
void DIALOG_NETLIST::OnOpenNelistClick( wxCommandEvent& event )
|
2007-05-06 16:03:28 +00:00
|
|
|
{
|
2010-04-23 14:46:00 +00:00
|
|
|
wxString lastPath = wxFileName::GetCwd();
|
|
|
|
wxString lastNetlistRead = m_Parent->GetLastNetListRead();
|
|
|
|
|
|
|
|
if( !lastNetlistRead.IsEmpty() && !wxFileName::FileExists( lastNetlistRead ) )
|
|
|
|
{
|
|
|
|
lastNetlistRead = wxEmptyString;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
wxFileName fn = lastNetlistRead;
|
|
|
|
lastPath = fn.GetPath();
|
2010-04-24 09:03:35 +00:00
|
|
|
lastNetlistRead = fn.GetFullName();
|
2010-04-23 14:46:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
wxLogDebug( wxT( "Last net list read path <%s>, file name <%s>." ),
|
|
|
|
GetChars( lastPath ), GetChars( lastNetlistRead ) );
|
|
|
|
|
|
|
|
wxFileDialog FilesDialog( this, _( "Select Netlist" ), lastPath, lastNetlistRead,
|
|
|
|
NetlistFileWildcard, wxFD_DEFAULT_STYLE | wxFD_FILE_MUST_EXIST );
|
2008-03-22 18:08:44 +00:00
|
|
|
|
2009-04-24 07:36:36 +00:00
|
|
|
if( FilesDialog.ShowModal() != wxID_OK )
|
|
|
|
return;
|
2008-03-22 18:08:44 +00:00
|
|
|
|
2010-04-23 14:46:00 +00:00
|
|
|
m_NetlistFilenameCtrl->SetValue( FilesDialog.GetPath() );
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
2008-03-22 18:08:44 +00:00
|
|
|
|
2009-04-24 07:36:36 +00:00
|
|
|
void DIALOG_NETLIST::OnReadNetlistFileClick( wxCommandEvent& event )
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2009-04-05 20:49:15 +00:00
|
|
|
wxFileName fn = m_NetlistFilenameCtrl->GetValue();
|
2012-03-08 17:47:23 +00:00
|
|
|
fn.SetExt( ComponentFileExtension );
|
2008-03-22 18:08:44 +00:00
|
|
|
|
2010-04-16 16:28:35 +00:00
|
|
|
m_Parent->ReadPcbNetlist( m_NetlistFilenameCtrl->GetValue(),
|
2010-04-23 14:46:00 +00:00
|
|
|
fn.GetFullPath(), m_MessageWindow,
|
2012-01-22 17:20:22 +00:00
|
|
|
m_ChangeExistingFootprintCtrl->GetSelection() == 1 ? true : false,
|
|
|
|
m_DeleteBadTracks->GetSelection() == 1 ? true : false,
|
|
|
|
m_RemoveExtraFootprintsCtrl->GetSelection() == 1 ? true : false,
|
|
|
|
m_Select_By_Timestamp->GetSelection() == 1 ? true : false );
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
2008-03-22 18:08:44 +00:00
|
|
|
|
2009-04-24 07:36:36 +00:00
|
|
|
void DIALOG_NETLIST::OnTestFootprintsClick( wxCommandEvent& event )
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2011-05-03 12:57:44 +00:00
|
|
|
m_Parent->Test_Duplicate_Missing_And_Extra_Footprints( m_NetlistFilenameCtrl->GetValue() );
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
2008-03-22 18:08:44 +00:00
|
|
|
|
2007-06-05 12:10:51 +00:00
|
|
|
/*!
|
|
|
|
* wxEVT_COMMAND_BUTTON_CLICKED event handler for ID_COMPILE_RATSNEST
|
|
|
|
*/
|
|
|
|
|
2009-04-24 07:36:36 +00:00
|
|
|
void DIALOG_NETLIST::OnCompileRatsnestClick( wxCommandEvent& event )
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2012-01-22 17:20:22 +00:00
|
|
|
m_Parent->Compile_Ratsnest( m_DC, true );
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|
|
|
|
|
2008-03-22 18:08:44 +00:00
|
|
|
|
2007-06-05 12:10:51 +00:00
|
|
|
/*!
|
2007-11-13 09:35:39 +00:00
|
|
|
* wxEVT_COMMAND_BUTTON_CLICKED event handler for wxID_CANCEL
|
2007-06-05 12:10:51 +00:00
|
|
|
*/
|
|
|
|
|
2009-04-24 07:36:36 +00:00
|
|
|
void DIALOG_NETLIST::OnCancelClick( wxCommandEvent& event )
|
2007-06-05 12:10:51 +00:00
|
|
|
{
|
2007-11-13 09:35:39 +00:00
|
|
|
EndModal( -1 );
|
2007-06-05 12:10:51 +00:00
|
|
|
}
|