router: feature to save debug event log & board dump for easier recreation of router bugs and misbehaviours

This commit is contained in:
Tomasz Wlostowski 2021-02-11 23:08:46 +01:00
parent ebdc68ac1d
commit b67e5768a6
2 changed files with 75 additions and 43 deletions

View File

@ -21,6 +21,8 @@
*/ */
#include <wx/hyperlink.h> #include <wx/hyperlink.h>
#include <advanced_config.h>
#include <functional> #include <functional>
using namespace std::placeholders; using namespace std::placeholders;
#include <board.h> #include <board.h>
@ -51,9 +53,7 @@ using namespace std::placeholders;
#include "pns_kicad_iface.h" #include "pns_kicad_iface.h"
#ifdef DEBUG
#include <plugins/kicad/kicad_plugin.h> #include <plugins/kicad/kicad_plugin.h>
#endif
using namespace KIGFX; using namespace KIGFX;
@ -480,30 +480,45 @@ void ROUTER_TOOL::Reset( RESET_REASON aReason )
TOOL_BASE::Reset( aReason ); TOOL_BASE::Reset( aReason );
} }
// Saves the complete event log and the dump of the PCB, allowing us to
// recreate hard-to-find P&S quirks and bugs.
void ROUTER_TOOL::handleCommonEvents( const TOOL_EVENT& aEvent ) void ROUTER_TOOL::saveRouterDebugLog()
{ {
#ifdef DEBUG
if( aEvent.IsKeyPressed() )
{
switch( aEvent.KeyCode() )
{
case '0':
{
auto logger = m_router->Logger(); auto logger = m_router->Logger();
if( ! logger ) if( ! logger )
return; return;
FILE *f = fopen("/tmp/pns.log", "wb"); wxString cwd = wxGetCwd();
wxLogTrace( "PNS", "saving drag/route log...\n" );
wxFileName fname_log( cwd );
fname_log.SetName( "pns.log" );
wxFileName fname_dump( cwd );
fname_dump.SetName( "pns.dump" );
wxString msg = wxString::Format( _( "Event file: %s\nBoard dump: %s" ), fname_log.GetFullPath(), fname_log.GetFullPath() );
int rv = OKOrCancelDialog( nullptr, _("Save router log"), _("Would you like to save the router\nevent log for debugging purposes?"), msg, _("OK"), _("Cancel") );
if( !rv )
return;
FILE *f = fopen( fname_log.GetFullPath().c_str(), "wb" );
// save base router configuration (mode, etc.)
fprintf(f, "config %d %d %d\n",
m_router->Settings().Mode(),
m_router->Settings().RemoveLoops() ? 1 : 0,
m_router->Settings().GetFixAllSegments() ? 1 : 0
);
const auto& events = logger->GetEvents(); const auto& events = logger->GetEvents();
for( auto evt : events) for( auto evt : events)
{ {
wxString id = "null"; wxString id = "null";
if( evt.item && evt.item->Parent() ) if( evt.item && evt.item->Parent() )
id = evt.item->Parent()->m_Uuid.AsString(); id = evt.item->Parent()->m_Uuid.AsString();
@ -518,13 +533,27 @@ void ROUTER_TOOL::handleCommonEvents( const TOOL_EVENT& aEvent )
PCB_IO pcb_io; PCB_IO pcb_io;
pcb_io.Save( "/tmp/pns.dump", m_iface->GetBoard(), nullptr ); pcb_io.Save( fname_dump.GetFullPath(), m_iface->GetBoard(), nullptr );
}
void ROUTER_TOOL::handleCommonEvents( TOOL_EVENT& aEvent )
{
if( !aEvent.IsKeyPressed() )
return;
switch( aEvent.KeyCode() )
{
case '0':
if( !ADVANCED_CFG::GetCfg().m_ShowRouterDebugGraphics )
return;
saveRouterDebugLog();
aEvent.SetPassEvent( false );
break;
default:
break; break;
} }
}
}
#endif
} }
@ -1684,6 +1713,8 @@ int ROUTER_TOOL::InlineDrag( const TOOL_EVENT& aEvent )
{ {
evt->SetPassEvent(); evt->SetPassEvent();
} }
handleCommonEvents( *evt );
} }
if( footprint ) if( footprint )

View File

@ -59,7 +59,7 @@ private:
void performDragging( int aMode = PNS::DM_ANY ); void performDragging( int aMode = PNS::DM_ANY );
void breakTrack(); void breakTrack();
void handleCommonEvents( const TOOL_EVENT& evt ); void handleCommonEvents( TOOL_EVENT& evt );
int handleLayerSwitch( const TOOL_EVENT& aEvent, bool aForceVia ); int handleLayerSwitch( const TOOL_EVENT& aEvent, bool aForceVia );
int getStartLayer( const PNS::ITEM* aItem ); int getStartLayer( const PNS::ITEM* aItem );
@ -71,6 +71,7 @@ private:
bool prepareInteractive(); bool prepareInteractive();
bool finishInteractive(); bool finishInteractive();
void saveRouterDebugLog();
private: private:
std::shared_ptr<ACTION_MENU> m_diffPairMenu; std::shared_ptr<ACTION_MENU> m_diffPairMenu;