Check return value for zone fill in VRML exporter
If the zone fill failed, then don't add the zone to the exported VRML because it might not be correct. Also test that the Python command in DIALOG_SCRIPTING worked. This dialog actually isn't used anywhere currently, so it could in theory be removed - but it is simple enough and it provides a decent testing dialog that it is more work to remove it.
This commit is contained in:
parent
70a7d1bc7c
commit
b1160660d9
|
@ -48,7 +48,8 @@ DIALOG_SCRIPTING::DIALOG_SCRIPTING( wxWindow* parent )
|
||||||
void DIALOG_SCRIPTING::OnRunButtonClick( wxCommandEvent& event )
|
void DIALOG_SCRIPTING::OnRunButtonClick( wxCommandEvent& event )
|
||||||
{
|
{
|
||||||
wxCharBuffer buffer = m_txScript->GetValue().ToUTF8();
|
wxCharBuffer buffer = m_txScript->GetValue().ToUTF8();
|
||||||
PyRun_SimpleString(buffer.data());
|
int retv = PyRun_SimpleString( buffer.data()) ;
|
||||||
|
|
||||||
|
if( retv != 0 )
|
||||||
|
wxLogError( "Python error %d occurred running command:\n\n`%s`", retv, buffer );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1017,7 +1017,10 @@ static void export_vrml_zones( MODEL_VRML& aModel, BOARD* aPcb, COMMIT* aCommit
|
||||||
{
|
{
|
||||||
ZONE_FILLER filler( aPcb, aCommit );
|
ZONE_FILLER filler( aPcb, aCommit );
|
||||||
zone->SetFillMode( ZONE_FILL_MODE::POLYGONS ); // use filled polygons
|
zone->SetFillMode( ZONE_FILL_MODE::POLYGONS ); // use filled polygons
|
||||||
filler.Fill( { zone } );
|
|
||||||
|
// If the zone fill failed, don't try adding it to the export
|
||||||
|
if( !filler.Fill( { zone } ) )
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
const SHAPE_POLY_SET& poly = zone->GetFilledPolysList( layer );
|
const SHAPE_POLY_SET& poly = zone->GetFilledPolysList( layer );
|
||||||
|
@ -1032,8 +1035,10 @@ static void export_vrml_zones( MODEL_VRML& aModel, BOARD* aPcb, COMMIT* aCommit
|
||||||
{
|
{
|
||||||
if( !vl->AddVertex( seg, (double) outline.CPoint( j ).x * BOARD_SCALE,
|
if( !vl->AddVertex( seg, (double) outline.CPoint( j ).x * BOARD_SCALE,
|
||||||
-( (double) outline.CPoint( j ).y * BOARD_SCALE ) ) )
|
-( (double) outline.CPoint( j ).y * BOARD_SCALE ) ) )
|
||||||
|
{
|
||||||
throw( std::runtime_error( vl->GetError() ) );
|
throw( std::runtime_error( vl->GetError() ) );
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
vl->EnsureWinding( seg, false );
|
vl->EnsureWinding( seg, false );
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue