Commit 3c656691 authored by Maciej Suminski's avatar Maciej Suminski

Fixed POINT_EDITOR crash on GAL change / board reload.

parent f87f12e2
...@@ -96,6 +96,12 @@ POINT_EDITOR::POINT_EDITOR() : ...@@ -96,6 +96,12 @@ POINT_EDITOR::POINT_EDITOR() :
} }
void POINT_EDITOR::Reset( RESET_REASON aReason )
{
m_editPoints.reset();
}
bool POINT_EDITOR::Init() bool POINT_EDITOR::Init()
{ {
// Find the selection tool, so they can cooperate // Find the selection tool, so they can cooperate
...@@ -130,6 +136,14 @@ int POINT_EDITOR::OnSelectionChange( TOOL_EVENT& aEvent ) ...@@ -130,6 +136,14 @@ int POINT_EDITOR::OnSelectionChange( TOOL_EVENT& aEvent )
// Main loop: keep receiving events // Main loop: keep receiving events
while( OPT_TOOL_EVENT evt = Wait() ) while( OPT_TOOL_EVENT evt = Wait() )
{ {
if( !m_editPoints || evt->IsCancel() ||
evt->Matches( m_selectionTool->ClearedEvent ) ||
evt->Matches( m_selectionTool->DeselectedEvent ) ||
evt->Matches( m_selectionTool->SelectedEvent ) )
{
break;
}
if( evt->IsMotion() ) if( evt->IsMotion() )
{ {
EDIT_POINT* point = m_editPoints->FindPoint( evt->Position() ); EDIT_POINT* point = m_editPoints->FindPoint( evt->Position() );
...@@ -168,23 +182,18 @@ int POINT_EDITOR::OnSelectionChange( TOOL_EVENT& aEvent ) ...@@ -168,23 +182,18 @@ int POINT_EDITOR::OnSelectionChange( TOOL_EVENT& aEvent )
updatePoints(); updatePoints();
} }
else if( evt->IsCancel() ||
evt->Matches( m_selectionTool->ClearedEvent ) ||
evt->Matches( m_selectionTool->DeselectedEvent ) ||
evt->Matches( m_selectionTool->SelectedEvent ) )
{
break;
}
else else
{ {
m_toolMgr->PassEvent(); m_toolMgr->PassEvent();
} }
} }
m_toolMgr->GetView()->Remove( m_editPoints.get() ); if( m_editPoints )
m_editPoints.reset(); {
item->ViewUpdate( KIGFX::VIEW_ITEM::GEOMETRY ); item->ViewUpdate( KIGFX::VIEW_ITEM::GEOMETRY );
m_toolMgr->GetView()->Remove( m_editPoints.get() );
m_editPoints.reset();
}
} }
controls->ShowCursor( false ); controls->ShowCursor( false );
...@@ -265,9 +274,6 @@ void POINT_EDITOR::updateItem() const ...@@ -265,9 +274,6 @@ void POINT_EDITOR::updateItem() const
void POINT_EDITOR::updatePoints() const void POINT_EDITOR::updatePoints() const
{ {
if( !m_editPoints )
return;
EDA_ITEM* item = m_editPoints->GetParent(); EDA_ITEM* item = m_editPoints->GetParent();
switch( item->Type() ) switch( item->Type() )
......
...@@ -44,7 +44,7 @@ public: ...@@ -44,7 +44,7 @@ public:
POINT_EDITOR(); POINT_EDITOR();
/// @copydoc TOOL_INTERACTIVE::Reset() /// @copydoc TOOL_INTERACTIVE::Reset()
void Reset( RESET_REASON aReason ) {}; void Reset( RESET_REASON aReason );
/// @copydoc TOOL_INTERACTIVE::Init() /// @copydoc TOOL_INTERACTIVE::Init()
bool Init(); bool Init();
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment