Pcbnew: fix Bug #1366701 (Module position file (.pos) generation fails for F.Cu layer)

This commit is contained in:
jean-pierre charras 2014-09-08 13:07:54 +02:00
parent 3e861db371
commit ded4bf6477
1 changed files with 26 additions and 10 deletions

View File

@ -38,6 +38,7 @@
#include <pgm_base.h>
#include <build_version.h>
#include <macros.h>
#include <reporter.h>
#include <class_board.h>
#include <class_module.h>
@ -45,6 +46,7 @@
#include <legacy_plugin.h>
#include <pcbnew.h>
#include <pcbplot.h>
#include <pcb_plot_params.h>
#include <wildcards_and_files_ext.h>
@ -204,8 +206,22 @@ bool DIALOG_GEN_MODULE_POSITION::CreateFiles()
return false;
}
// Create output directory if it does not exist (also transform it in
// absolute form). Bail if it fails
wxFileName outputDir = wxFileName::DirName( m_plotOpts.GetOutputDirectory() );
wxString boardFilename = m_parent->GetBoard()->GetFileName();
WX_TEXT_CTRL_REPORTER reporter( m_messagesBox );
if( !EnsureOutputDirectory( &outputDir, boardFilename, &reporter ) )
{
msg.Printf( _( "Could not write plot files to folder \"%s\"." ),
GetChars( outputDir.GetPath() ) );
DisplayError( this, msg );
return false;
}
fn = m_parent->GetBoard()->GetFileName();
fn.SetPath( GetOutputDirectory() );
fn.SetPath( outputDir.GetPath() );
frontLayerName = brd->GetLayerName( F_Cu );
backLayerName = brd->GetLayerName( B_Cu );
@ -227,16 +243,16 @@ bool DIALOG_GEN_MODULE_POSITION::CreateFiles()
ForceAllSmd(), side );
if( fpcount < 0 )
{
msg.Printf( _( "Unable to create <%s>" ), GetChars( fn.GetFullPath() ) );
AddMessage( msg + wxT("\n") );
msg.Printf( _( "Unable to create '%s'" ), GetChars( fn.GetFullPath() ) );
wxMessageBox( msg );
AddMessage( msg + wxT("\n") );
return false;
}
if( singleFile )
msg.Printf( _( "Place file: <%s>\n" ), GetChars( fn.GetFullPath() ) );
msg.Printf( _( "Place file: '%s'\n" ), GetChars( fn.GetFullPath() ) );
else
msg.Printf( _( "Front side (top side) place file: <%s>\n" ),
msg.Printf( _( "Front side (top side) place file: '%s'\n" ),
GetChars( fn.GetFullPath() ) );
AddMessage( msg );
@ -250,7 +266,7 @@ bool DIALOG_GEN_MODULE_POSITION::CreateFiles()
fullcount = fpcount;
side = 0;
fn = brd->GetFileName();
fn.SetPath( GetOutputDirectory() );
fn.SetPath( outputDir.GetPath() );
fn.SetName( fn.GetName() + wxT( "-" ) + backLayerName );
fn.SetExt( wxT( "pos" ) );
@ -259,7 +275,7 @@ bool DIALOG_GEN_MODULE_POSITION::CreateFiles()
if( fpcount < 0 )
{
msg.Printf( _( "Unable to create <%s>" ), GetChars( fn.GetFullPath() ) );
msg.Printf( _( "Unable to create '%s'" ), GetChars( fn.GetFullPath() ) );
AddMessage( msg + wxT("\n") );
wxMessageBox( msg );
return false;
@ -268,7 +284,7 @@ bool DIALOG_GEN_MODULE_POSITION::CreateFiles()
// Display results
if( !singleFile )
{
msg.Printf( _( "Back side (bottom side) place file: <%s>\n" ), GetChars( fn.GetFullPath() ) );
msg.Printf( _( "Back side (bottom side) place file: '%s'\n" ), GetChars( fn.GetFullPath() ) );
AddMessage( msg );
msg.Printf( _( "Footprint count %d\n" ), fpcount );
AddMessage( msg );
@ -538,14 +554,14 @@ void PCB_EDIT_FRAME::GenFootprintsReport( wxCommandEvent& event )
wxString msg;
if( success )
{
msg.Printf( _( "Module report file created:\n<%s>" ),
msg.Printf( _( "Module report file created:\n'%s'" ),
GetChars( fn.GetFullPath() ) );
wxMessageBox( msg, _( "Module Report" ), wxICON_INFORMATION );
}
else
{
msg.Printf( _( "Unable to create <%s>" ), GetChars( fn.GetFullPath() ) );
msg.Printf( _( "Unable to create '%s'" ), GetChars( fn.GetFullPath() ) );
DisplayError( this, msg );
}
}