KiCad PCB EDA Suite
Loading...
Searching...
No Matches
sch_base_frame.cpp
Go to the documentation of this file.
1/*
2 * This program source code file is part of KiCad, a free EDA CAD application.
3 *
4 * Copyright (C) 2012 SoftPLC Corporation, Dick Hollenbeck <[email protected]>
5 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
6 *
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation; either version 2
10 * of the License, or (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, you may find one here:
19 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
20 * or you may search the http://www.gnu.org website for the version 2 license,
21 * or you may write to the Free Software Foundation, Inc.,
22 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
23 */
24
25#include <advanced_config.h>
26#include <base_units.h>
28#include <kiway.h>
30#include <pgm_base.h>
31#include <eda_list_dialog.h>
34#include <eeschema_settings.h>
38#include <sch_draw_panel.h>
40#include <sch_group.h>
41#include <sch_view.h>
42#include <sch_painter.h>
43#include <sch_shape.h>
45#include <confirm.h>
47#include <project_sch.h>
50#include <sch_base_frame.h>
52#include <design_block.h>
53#include <thread_pool.h>
54#include <tool/actions.h>
55#include <tool/action_toolbar.h>
56#include <tool/tool_manager.h>
59#include <trace_helpers.h>
60#include <view/view_controls.h>
61#include <widgets/kistatusbar.h>
62#include <wx/choicdlg.h>
63#include <wx/evtloop.h>
64#include <wx/fswatcher.h>
65#include <wx/log.h>
66#include <wx/msgdlg.h>
67#include <trace_helpers.h>
68
69#ifndef __linux__
71#include <wx/fdrepdlg.h>
72#else
74#endif
75
76
78 LEGACY_SYMBOL_LIB* aCacheLib, wxWindow* aParent, bool aShowErrorMsg )
79{
80 wxCHECK_MSG( aLibMgr, nullptr, wxS( "Invalid symbol library manager adapter." ) );
81
82 LIB_SYMBOL* symbol = nullptr;
83
84 try
85 {
86 symbol = aLibMgr->LoadSymbol( aLibId );
87
88 if( !symbol && aCacheLib )
89 {
90 wxCHECK_MSG( aCacheLib->IsCache(), nullptr, wxS( "Invalid cache library." ) );
91
92 wxString cacheName = aLibId.GetLibNickname().wx_str();
93 cacheName << "_" << aLibId.GetLibItemName();
94 symbol = aCacheLib->FindSymbol( cacheName );
95 }
96 }
97 catch( const IO_ERROR& ioe )
98 {
99 if( aShowErrorMsg )
100 {
101 wxString msg = wxString::Format( _( "Error loading symbol %s from library '%s'." ),
102 aLibId.GetLibItemName().wx_str(),
103 aLibId.GetLibNickname().wx_str() );
104 DisplayErrorMessage( aParent, msg, ioe.What() );
105 }
106 }
107
108 return symbol;
109}
110
111
112SCH_BASE_FRAME::SCH_BASE_FRAME( KIWAY* aKiway, wxWindow* aParent, FRAME_T aWindowType,
113 const wxString& aTitle, const wxPoint& aPosition,
114 const wxSize& aSize, long aStyle, const wxString& aFrameName ) :
115 EDA_DRAW_FRAME( aKiway, aParent, aWindowType, aTitle, aPosition, aSize, aStyle,
116 aFrameName, schIUScale ),
117 m_selectionFilterPanel( nullptr ),
118 m_findReplaceDialog( nullptr ),
119 m_base_frame_defaults( nullptr, "base_Frame_defaults" ),
121{
122 m_findReplaceData = std::make_unique<SCH_SEARCH_DATA>();
123
124 if( ( aStyle & wxFRAME_NO_TASKBAR ) == 0 )
125 createCanvas();
126
127 Bind( wxEVT_IDLE,
128 [this]( wxIdleEvent& aEvent )
129 {
130 // Handle cursor adjustments. While we can get motion and key events through
131 // wxWidgets, we can't get modifier-key-up events.
132 if( m_toolManager )
133 {
135
136 if( selTool )
137 selTool->OnIdle( aEvent );
138 }
139 } );
140
141 Pgm().GetBackgroundJobMonitor().RegisterStatusBar( static_cast<KISTATUSBAR*>( GetStatusBar() ) );
142
144}
145
146
149{
150 Pgm().GetBackgroundJobMonitor().UnregisterStatusBar( static_cast<KISTATUSBAR*>( GetStatusBar() ) );
151}
152
153
155{
156 GetCanvas()->SetEvtHandlerEnabled( false );
158
159 // Shutdown all running tools
160 if( m_toolManager )
161 m_toolManager->ShutdownAllTools();
162
163 // Close the find dialog and preserve its setting if it is displayed.
165 {
167 m_replaceStringHistoryList = m_findReplaceDialog->GetReplaceEntries();
168
169 m_findReplaceDialog->Destroy();
170 m_findReplaceDialog = nullptr;
171 }
172
173 // This class is pure virtual. Derived class will finish shutdown and Destroy().
174}
175
176
181
182
184{
185 return dynamic_cast<EESCHEMA_SETTINGS*>( config() );
186}
187
188
193
194
196{
197 switch( GetFrameType() )
198 {
199 case FRAME_SCH:
200 default:
201 return GetAppSettings<EESCHEMA_SETTINGS>( "eeschema" );
202
204 case FRAME_SCH_VIEWER:
206 return GetAppSettings<SYMBOL_EDITOR_SETTINGS>( "symbol_editor" );
207 }
208}
209
210
211void SCH_BASE_FRAME::SetPageSettings( const PAGE_INFO& aPageSettings )
212{
213 GetScreen()->SetPageSettings( aPageSettings );
214}
215
216
218{
219 return GetScreen()->GetPageSettings();
220}
221
222
224{
225 // GetSizeIU is compile time dependent:
226 return GetScreen()->GetPageSettings().GetSizeIU( schIUScale.IU_PER_MILS );
227}
228
229
231{
232 wxASSERT( GetScreen() );
233 return GetScreen()->GetTitleBlock();
234}
235
236
238{
239 wxASSERT( GetScreen() );
240 GetScreen()->SetTitleBlock( aTitleBlock );
241}
242
243
245{
246 wxString line;
247 BASE_SCREEN* screen = GetScreen();
248
249 if( !screen )
250 return;
251
253
254 // Display absolute and relative coordinates
256 VECTOR2D d = cursorPos - screen->m_LocalOrigin;
257
258 line.Printf( wxS( "X %s Y %s" ),
259 MessageTextFromValue( cursorPos.x, false ),
260 MessageTextFromValue( cursorPos.y, false ) );
261 SetStatusText( line, 2 );
262
263 line.Printf( wxS( "dx %s dy %s dist %s" ),
264 MessageTextFromValue( d.x, false ),
265 MessageTextFromValue( d.y, false ),
266 MessageTextFromValue( hypot( d.x, d.y ), false ) );
267 SetStatusText( line, 3 );
268
271}
272
273
274LIB_SYMBOL* SCH_BASE_FRAME::GetLibSymbol( const LIB_ID& aLibId, bool aUseCacheLib,
275 bool aShowErrorMsg )
276{
277 LEGACY_SYMBOL_LIB* cache =
278 ( aUseCacheLib ) ? PROJECT_SCH::LegacySchLibs( &Prj() )->GetCacheLibrary() : nullptr;
279
280 return SchGetLibSymbol( aLibId, PROJECT_SCH::SymbolLibAdapter( &Prj() ), cache, this,
281 aShowErrorMsg );
282}
283
284
285void SCH_BASE_FRAME::RedrawScreen( const VECTOR2I& aCenterPoint, bool aWarpPointer )
286{
287 GetCanvas()->GetView()->SetCenter( aCenterPoint );
288
289 if( aWarpPointer )
291
292 GetCanvas()->Refresh();
293}
294
295
297{
298 if( GetCanvas() && GetCanvas()->GetView() )
299 {
302 }
303}
304
305
310
311
313{
314 if( GetCanvas() && GetCanvas()->GetView() )
315 {
316 if( KIGFX::PAINTER* painter = GetCanvas()->GetView()->GetPainter() )
317 return static_cast<SCH_RENDER_SETTINGS*>( painter->GetSettings() );
318 }
319
320 return nullptr;
321}
322
323
325{
327
328 SetCanvas( new SCH_DRAW_PANEL( this, wxID_ANY, wxPoint( 0, 0 ), m_frameSize,
331}
332
333
335{
337
338 try
339 {
340 if( !m_spaceMouse )
341 {
342#ifndef __linux__
343 m_spaceMouse = std::make_unique<NL_SCHEMATIC_PLUGIN>();
344#else
345 m_spaceMouse = std::make_unique<SPNAV_2D_PLUGIN>( GetCanvas() );
346 m_spaceMouse->SetScale( schIUScale.IU_PER_MILS / pcbIUScale.IU_PER_MILS );
347#endif
348 }
349
350 m_spaceMouse->SetCanvas( GetCanvas() );
351 }
352 catch( const std::system_error& e )
353 {
354 wxLogTrace( wxT( "KI_TRACE_NAVLIB" ), e.what() );
355 }
356}
357
358
359void SCH_BASE_FRAME::UpdateItem( EDA_ITEM* aItem, bool isAddOrDelete, bool aUpdateRtree )
360{
361 EDA_ITEM* parent = aItem->GetParent();
362
363 if( aItem->Type() == SCH_SHEET_PIN_T )
364 {
365 // Sheet pins aren't in the view. Refresh their parent.
366 if( parent )
367 GetCanvas()->GetView()->Update( parent );
368 }
369 else
370 {
371 if( aItem->Type() == SCH_SHAPE_T )
372 static_cast<SCH_SHAPE*>( aItem )->UpdateHatching();
373
374 if( !isAddOrDelete )
375 GetCanvas()->GetView()->Update( aItem );
376
377 // Some children are drawn from their parents. Mark them for re-paint.
378 if( parent && ( parent->Type() == SCH_SYMBOL_T
379 || parent->Type() == SCH_SHEET_T
380 || parent->Type() == SCH_LABEL_LOCATE_ANY_T
381 || parent->Type() == SCH_TABLE_T ) )
382 {
383 GetCanvas()->GetView()->Update( parent, KIGFX::REPAINT );
384 }
385 }
386
387 /*
388 * Be careful when calling this. Update will invalidate RTree iterators, so you cannot
389 * call this while doing things like `for( SCH_ITEM* item : screen->Items() )`
390 */
391 if( aUpdateRtree && dynamic_cast<SCH_ITEM*>( aItem ) )
392 {
393 GetScreen()->Update( static_cast<SCH_ITEM*>( aItem ) );
394
395 /*
396 * If we are updating the group, we also need to update all the children otherwise
397 * their positions will remain stale in the RTree
398 */
399 if( SCH_GROUP* group = dynamic_cast<SCH_GROUP*>( aItem ) )
400 {
401 group->RunOnChildren(
402 [&]( SCH_ITEM* item )
403 {
404 GetScreen()->Update( item );
405 },
407 }
408 }
409
410 // Calling Refresh() here introduces a bi-stable state: when doing operations on a
411 // large number of items if at some point the refresh timer times out and does a
412 // refresh it will take long enough that the next item will also time out, and the
413 // next, and the next, etc.
414 // GetCanvas()->Refresh();
415}
416
417
419{
420 // We currently have two zoom-dependent renderings: text, which is rendered as bitmap text
421 // when too small to see the difference, and selection shadows.
422 //
423 // Because non-selected text is cached by OpenGL, we only apply the bitmap performance hack
424 // to selected text items.
425 //
426 // Thus, as it currently stands, all zoom-dependent items can be found in the list of selected
427 // items.
428 if( m_toolManager )
429 {
430 SCH_SELECTION_TOOL* selectionTool = m_toolManager->GetTool<SCH_SELECTION_TOOL>();
431 SELECTION& selection = selectionTool->GetSelection();
432 KIGFX::SCH_VIEW* view = GetCanvas()->GetView();
433
434 for( EDA_ITEM* item : selection )
435 {
436 if( item->RenderAsBitmap( view->GetGAL()->GetWorldScale() ) != item->IsShownAsBitmap()
438 {
439 view->Update( item, KIGFX::REPAINT );
440
441 EDA_ITEM* parent = item->GetParent();
442
443 // Symbol children are drawn from their parents. Mark them for re-paint.
444 if( parent && parent->Type() == SCH_SYMBOL_T )
445 GetCanvas()->GetView()->Update( parent, KIGFX::REPAINT );
446 }
447 }
448 }
449}
450
451
453{
454 // Null pointers will cause boost::ptr_vector to raise a boost::bad_pointer exception which
455 // will be unhandled. There is no valid reason to pass an invalid EDA_ITEM pointer to the
456 // screen append function.
457 wxCHECK( aItem, /* void */ );
458
459 SCH_SCREEN* screen = aScreen;
460
461 if( aScreen == nullptr )
462 screen = GetScreen();
463
464 if( aItem->Type() != SCH_TABLECELL_T )
465 screen->Append( (SCH_ITEM*) aItem );
466
467 if( screen == GetScreen() )
468 {
469 GetCanvas()->GetView()->Add( aItem );
470 UpdateItem( aItem, true ); // handle any additional parent semantics
471 }
472}
473
474
476{
477 auto screen = aScreen;
478
479 if( aScreen == nullptr )
480 screen = GetScreen();
481
482 if( screen == GetScreen() )
483 GetCanvas()->GetView()->Remove( aItem );
484
485 if( aItem->Type() != SCH_TABLECELL_T )
486 screen->Remove( (SCH_ITEM*) aItem );
487
488 if( screen == GetScreen() )
489 UpdateItem( aItem, true ); // handle any additional parent semantics
490}
491
492
494{
495 // Let tools add things to the view if necessary
496 if( m_toolManager )
498
500}
501
502
507
508
510{
511 wxString findString;
512
513 SCH_SELECTION& selection = m_toolManager->GetTool<SCH_SELECTION_TOOL>()->GetSelection();
514
515 if( selection.Size() == 1 )
516 {
517 EDA_ITEM* front = selection.Front();
518
519 switch( front->Type() )
520 {
521 case SCH_SYMBOL_T:
522 {
523 SCH_SYMBOL* symbol = static_cast<SCH_SYMBOL*>( front );
524 findString = UnescapeString( symbol->GetField( FIELD_T::VALUE )->GetText() );
525 break;
526 }
527
528 case SCH_FIELD_T:
529 findString = UnescapeString( static_cast<SCH_FIELD*>( front )->GetText() );
530 break;
531
532 case SCH_LABEL_T:
534 case SCH_HIER_LABEL_T:
535 case SCH_SHEET_PIN_T:
536 findString = UnescapeString( static_cast<SCH_LABEL_BASE*>( front )->GetText() );
537 break;
538
539 case SCH_TEXT_T:
540 findString = UnescapeString( static_cast<SCH_TEXT*>( front )->GetText() );
541
542 if( findString.Contains( wxT( "\n" ) ) )
543 findString = findString.Before( '\n' );
544
545 break;
546
547 default:
548 break;
549 }
550 }
551
553 m_findReplaceDialog->Destroy();
554
555 m_findReplaceDialog = new DIALOG_SCH_FIND( this, static_cast<SCH_SEARCH_DATA*>( m_findReplaceData.get() ),
556 wxDefaultPosition, wxDefaultSize, aReplace ? wxFR_REPLACEDIALOG : 0 );
557
558 m_findReplaceDialog->SetFindEntries( m_findStringHistoryList, findString );
560 m_findReplaceDialog->Show( true );
561}
562
563
564void SCH_BASE_FRAME::ShowFindReplaceStatus( const wxString& aMsg, int aStatusTime )
565{
566 // Prepare the infobar, since we don't know its state
567 m_infoBar->RemoveAllButtons();
568 m_infoBar->AddCloseButton();
569
570 m_infoBar->ShowMessageFor( aMsg, aStatusTime, wxICON_INFORMATION );
571}
572
573
575{
576 m_infoBar->Dismiss();
577}
578
579
581{
583 m_replaceStringHistoryList = m_findReplaceDialog->GetReplaceEntries();
584
585 m_findReplaceDialog->Destroy();
586 m_findReplaceDialog = nullptr;
587
589}
590
591
605
606
608{
609 if( !m_colorSettings || aForceRefresh )
610 {
612 wxString colorTheme = cfg ? cfg->m_ColorTheme : wxString( "" );
613
615 {
616 if( SYMBOL_EDITOR_SETTINGS* sym_edit_cfg = GetAppSettings<SYMBOL_EDITOR_SETTINGS>( "symbol_editor" ) )
617 {
618 if( !sym_edit_cfg->m_UseEeschemaColorSettings )
619 colorTheme = sym_edit_cfg->m_ColorTheme;
620 }
621 }
622
623 const_cast<SCH_BASE_FRAME*>( this )->m_colorSettings = ::GetColorSettings( colorTheme );
624 }
625
626 return m_colorSettings;
627}
628
629
634
635
636void SCH_BASE_FRAME::handleActivateEvent( wxActivateEvent& aEvent )
637{
639
640 if( m_spaceMouse )
641 m_spaceMouse->SetFocus( aEvent.GetActive() );
642}
643
644
645void SCH_BASE_FRAME::handleIconizeEvent( wxIconizeEvent& aEvent )
646{
648
649 if( m_spaceMouse )
650 m_spaceMouse->SetFocus( false );
651}
652
653
655 std::vector<wxArrayString>& aItemsToDisplay )
656{
657 aHeaders.Add( _( "Library" ) );
658 aHeaders.Add( _( "Description" ) );
659
663 std::vector<wxString> libNicknames = adapter->GetLibraryNames();
664 std::vector<wxArrayString> unpinned;
665
666 for( const wxString& nickname : libNicknames )
667 {
668 wxArrayString item;
669 wxString description = adapter->GetLibraryDescription( nickname ).value_or( wxEmptyString );
670
671 if( alg::contains( project.m_PinnedSymbolLibs, nickname )
672 || alg::contains( cfg->m_Session.pinned_symbol_libs, nickname ) )
673 {
674 item.Add( LIB_TREE_MODEL_ADAPTER::GetPinningSymbol() + nickname );
675 item.Add( description );
676 aItemsToDisplay.push_back( item );
677 }
678 else
679 {
680 item.Add( nickname );
681 item.Add( description );
682 unpinned.push_back( item );
683 }
684 }
685
686 std::ranges::copy( unpinned, std::back_inserter( aItemsToDisplay ) );
687}
688
689
690wxString SCH_BASE_FRAME::SelectLibrary( const wxString& aDialogTitle, const wxString& aListLabel,
691 const std::vector<std::pair<wxString, bool*>>& aExtraCheckboxes )
692{
693 static const int ID_MAKE_NEW_LIBRARY = wxID_HIGHEST;
694
695 // Keep asking the user for a new name until they give a valid one or cancel the operation
696 while( true )
697 {
698 wxArrayString headers;
699 std::vector<wxArrayString> itemsToDisplay;
700
701 GetLibraryItemsForListDialog( headers, itemsToDisplay );
702
703 wxString libraryName = Prj().GetRString( PROJECT::SCH_LIB_SELECT );
704
705 EDA_LIST_DIALOG dlg( this, aDialogTitle, headers, itemsToDisplay, libraryName, false );
706 dlg.SetListLabel( aListLabel );
707
708 for( const auto& [label, val] : aExtraCheckboxes )
709 dlg.AddExtraCheckbox( label, val );
710
711 wxButton* newLibraryButton = new wxButton( &dlg, ID_MAKE_NEW_LIBRARY, _( "New Library..." ) );
712 dlg.m_ButtonsSizer->Prepend( 80, 20 );
713 dlg.m_ButtonsSizer->Prepend( newLibraryButton, 0, wxALIGN_CENTER_VERTICAL|wxLEFT|wxRIGHT, 10 );
714
715 newLibraryButton->Bind( wxEVT_BUTTON,
716 [&dlg]( wxCommandEvent& )
717 {
718 dlg.EndModal( ID_MAKE_NEW_LIBRARY );
720
721 dlg.Layout();
722 dlg.GetSizer()->Fit( &dlg );
723
724 int ret = dlg.ShowModal();
725
726 switch( ret )
727 {
728 case wxID_CANCEL:
729 return wxEmptyString;
730
731 case wxID_OK:
732 libraryName = dlg.GetTextSelection();
733 Prj().SetRString( PROJECT::SCH_LIB_SELECT, libraryName );
735 return libraryName;
736
738 {
739 SYMBOL_LIBRARY_MANAGER mgr( *this );
740 wxFileName fn( Prj().GetRString( PROJECT::SCH_LIB_PATH ) );
741 bool useGlobalTable = false;
742 FILEDLG_HOOK_NEW_LIBRARY tableChooser( useGlobalTable );
743
744 if( !LibraryFileBrowser( _( "Create New Library" ), false, fn, FILEEXT::KiCadSymbolLibFileWildcard(),
745 FILEEXT::KiCadSymbolLibFileExtension, false, &tableChooser ) )
746 {
747 break;
748 }
749
750 libraryName = fn.GetName();
751 Prj().SetRString( PROJECT::SCH_LIB_PATH, fn.GetPath() );
752
756
757 if( adapter->HasLibrary( libraryName, false ) )
758 {
759 DisplayError( this, wxString::Format( _( "Library '%s' already exists." ), libraryName ) );
760 break;
761 }
762
763 if( !mgr.CreateLibrary( fn.GetFullPath(), scope ) )
764 DisplayError( this, wxString::Format( _( "Could not add library '%s'." ), libraryName ) );
765
766 break;
767 }
768
769 default:
770 break;
771 }
772 }
773}
774
775
777{
778 Unbind( wxEVT_FSWATCHER, &SCH_BASE_FRAME::OnSymChange, this );
779
780 if( m_watcher )
781 {
782 wxLogTrace( traceLibWatch, "Remove watch" );
783 m_watcher->RemoveAll();
784 m_watcher->SetOwner( nullptr );
785 m_watcher.reset();
786 }
787
788 if( !aID )
789 return;
790
792 std::optional<wxString> uri = manager.GetFullURI( LIBRARY_TABLE_TYPE::SYMBOL,
793 aID->GetLibNickname() );
794
795 if( !uri )
796 {
797 wxLogTrace( traceLibWatch, "Could not get URI for library %s",
798 wxString( aID->GetLibNickname().c_str() ) );
799 return;
800 }
801
802 wxString tmp = ExpandEnvVarSubstitutions( *uri, &Prj() );
803
804 wxLogTrace( traceLibWatch, "Setting up watcher for %s", tmp );
805 m_watcherFileName.Assign( tmp );
806
807 if( !m_watcherFileName.FileExists() )
808 return;
809
810 wxLog::EnableLogging( false );
811 m_watcherLastModified = m_watcherFileName.GetModificationTime();
812 wxLog::EnableLogging( true );
813
814 // File system watcher requires an active event loop. If we're being called during
815 // library enumeration before the main event loop is running, skip watcher creation.
816 if( !wxEventLoopBase::GetActive() )
817 return;
818
819 Bind( wxEVT_FSWATCHER, &SCH_BASE_FRAME::OnSymChange, this );
820 m_watcher = std::make_unique<wxFileSystemWatcher>();
821 m_watcher->SetOwner( this );
822
823 wxFileName fn;
824 fn.AssignDir( m_watcherFileName.GetPath() );
825 fn.DontFollowLink();
826
827 {
828 // Silence OS errors that come from the watcher
829 wxLogNull silence;
830 m_watcher->Add( fn );
831 }
832}
833
834
835void SCH_BASE_FRAME::OnSymChange( wxFileSystemWatcherEvent& aEvent )
836{
838
839 wxLogTrace( traceLibWatch, "OnSymChange: %s, watcher file: %s",
840 aEvent.GetPath().GetFullPath(), m_watcherFileName.GetFullPath() );
841
842 if( !libs || !m_watcher || !m_watcher.get() || m_watcherFileName.GetPath().IsEmpty() )
843 return;
844
845 if( aEvent.GetPath() != m_watcherFileName )
846 return;
847
848 // Start the debounce timer (set to 1 second)
849 if( !m_watcherDebounceTimer.StartOnce( 1000 ) )
850 {
851 wxLogTrace( traceLibWatch, "Failed to start the debounce timer" );
852 return;
853 }
854}
855
856
858{
859 if( aEvent.GetId() != m_watcherDebounceTimer.GetId() )
860 {
861 aEvent.Skip();
862 return;
863 }
864
866 {
867 wxLogTrace( traceLibWatch, "Restarting debounce timer" );
868 m_watcherDebounceTimer.StartOnce( 3000 );
869 }
870
871 wxLogTrace( traceLibWatch, "OnSymChangeDebounceTimer" );
872
873 // Disable logging to avoid spurious messages and check if the file has changed
874 wxLog::EnableLogging( false );
875 wxDateTime lastModified = m_watcherFileName.GetModificationTime();
876 wxLog::EnableLogging( true );
877
878 if( lastModified == m_watcherLastModified || !lastModified.IsValid() )
879 return;
880
881 m_watcherLastModified = lastModified;
882
884
886 || IsOK( this, _( "The library containing the current symbol has changed.\n"
887 "Do you want to reload the library?" ) ) )
888 {
889 wxLogTrace( traceLibWatch, "Sending refresh symbol mail" );
890 std::string libName = m_watcherFileName.GetFullPath().ToStdString();
893 }
894
896}
897
898
900{
901 if( m_toolManager )
902 return m_toolManager->GetTool<SCH_SELECTION_TOOL>();
903
904 return nullptr;
905}
906
907
909{
910 SCH_SELECTION_FILTER_EVENT evt( aOptions );
911 wxPostEvent( this, evt );
912}
constexpr EDA_IU_SCALE schIUScale
Definition base_units.h:114
constexpr EDA_IU_SCALE pcbIUScale
Definition base_units.h:112
static TOOL_ACTION updateFind
Definition actions.h:124
APP_SETTINGS_BASE is a settings class that should be derived for each standalone KiCad application.
wxString m_ColorTheme
Active color theme name.
void UnregisterStatusBar(KISTATUSBAR *aStatusBar)
Removes status bar from handling.
void RegisterStatusBar(KISTATUSBAR *aStatusBar)
Add a status bar for handling.
Handles how to draw a screen (a board, a schematic ...)
Definition base_screen.h:41
VECTOR2D m_LocalOrigin
Relative Screen cursor coordinate (on grid) in user units.
Definition base_screen.h:90
Color settings are a bit different than most of the settings objects in that there can be more than o...
COLOR4D GetColor(int aLayer) const
int ShowModal() override
FRAME_T GetFrameType() const
virtual APP_SETTINGS_BASE * config() const
Return the settings object used in SaveSettings(), and is overloaded in KICAD_MANAGER_FRAME.
virtual void handleIconizeEvent(wxIconizeEvent &aEvent)
Handle a window iconize event.
WX_INFOBAR * m_infoBar
virtual bool IsContentModified() const
Get if the contents of the frame have been modified since the last save.
bool IsType(FRAME_T aType) const
wxArrayString m_replaceStringHistoryList
virtual void ActivateGalCanvas()
Use to start up the GAL drawing canvas.
COLOR_SETTINGS * m_colorSettings
EDA_DRAW_PANEL_GAL::GAL_TYPE m_canvasType
The current canvas type.
virtual BASE_SCREEN * GetScreen() const
Return a pointer to a BASE_SCREEN or one of its derivatives.
void DisplayUnitsMsg()
Display current unit pane in the status bar.
GAL_DISPLAY_OPTIONS_IMPL & GetGalDisplayOptions()
Return a reference to the gal rendering options used by GAL for rendering.
void SetCanvas(EDA_DRAW_PANEL_GAL *aPanel)
EDA_DRAW_FRAME(KIWAY *aKiway, wxWindow *aParent, FRAME_T aFrameType, const wxString &aTitle, const wxPoint &aPos, const wxSize &aSize, long aStyle, const wxString &aFrameName, const EDA_IU_SCALE &aIuScale)
bool LibraryFileBrowser(const wxString &aTitle, bool doOpen, wxFileName &aFilename, const wxString &wildcard, const wxString &ext, bool isDirectory, FILEDLG_HOOK_NEW_LIBRARY *aFileDlgHook=nullptr)
virtual void handleActivateEvent(wxActivateEvent &aEvent)
Handle a window activation event.
void UpdateStatusBar() override
Update the status bar information.
virtual EDA_DRAW_PANEL_GAL * GetCanvas() const
Return a pointer to GAL-based canvas of given EDA draw frame.
virtual void DisplayGridMsg()
Display current grid size in the status bar.
EDA_DRAW_PANEL_GAL::GAL_TYPE loadCanvasTypeSetting()
Return the canvas type stored in the application settings.
wxArrayString m_findStringHistoryList
std::unique_ptr< EDA_SEARCH_DATA > m_findReplaceData
void CommonSettingsChanged(int aFlags) override
Notification event that some of the common (suite-wide) settings have changed.
void StopDrawing()
Prevent the GAL canvas from further drawing until it is recreated or StartDrawing() is called.
KIGFX::VIEW_CONTROLS * GetViewControls() const
Return a pointer to the #VIEW_CONTROLS instance used in the panel.
void ForceRefresh()
Force a redraw.
virtual void Refresh(bool aEraseBackground=true, const wxRect *aRect=nullptr) override
KIGFX::GAL * GetGAL() const
Return a pointer to the GAL instance used in the panel.
A base class for most all the KiCad significant classes used in schematics and boards.
Definition eda_item.h:98
KICAD_T Type() const
Returns the type of object.
Definition eda_item.h:110
EDA_ITEM * GetParent() const
Definition eda_item.h:112
A dialog which shows:
wxString GetTextSelection(int aColumn=0)
Return the selected text from aColumn in the wxListCtrl in the dialog.
void SetListLabel(const wxString &aLabel)
void AddExtraCheckbox(const wxString &aLabel, bool *aValuePtr)
Add a checkbox value to the dialog.
void GetExtraCheckboxValues()
Fills in the value pointers from the checkboxes after the dialog has run.
Hold an error message and may be used when throwing exceptions containing meaningful error messages.
virtual const wxString What() const
A composite of Problem() and Where()
A color representation with 4 components: red, green, blue, alpha.
Definition color4d.h:105
void SetAxesColor(const COLOR4D &aAxesColor)
Set the axes color.
double GetWorldScale() const
Get the world scale.
Contains all the knowledge about how to draw graphical object onto any particular output device.
Definition painter.h:59
virtual RENDER_SETTINGS * GetSettings()=0
Return a pointer to current settings that are going to be used when drawing items.
virtual void LoadColors(const COLOR_SETTINGS *aSettings)
static std::vector< KICAD_T > g_ScaledSelectionTypes
void Update(const KIGFX::VIEW_ITEM *aItem, int aUpdateFlags) const override
For dynamic VIEWs, inform the associated VIEW that the graphical representation of this item has chan...
Definition sch_view.cpp:60
virtual void CenterOnCursor()=0
Set the viewport center to the current cursor position and warps the cursor to the screen center.
VECTOR2D GetCursorPosition() const
Return the current cursor position in world coordinates.
virtual void Add(VIEW_ITEM *aItem, int aDrawPriority=-1)
Add a VIEW_ITEM to the view.
Definition view.cpp:298
virtual void Remove(VIEW_ITEM *aItem)
Remove a VIEW_ITEM from the view.
Definition view.cpp:341
GAL * GetGAL() const
Return the GAL this view is using to draw graphical primitives.
Definition view.h:202
void RecacheAllItems()
Rebuild GAL display lists.
Definition view.cpp:1462
void UpdateAllItems(int aUpdateFlags)
Update all items in the view according to the given flags.
Definition view.cpp:1572
PAINTER * GetPainter() const
Return the painter object used by the view for drawing #VIEW_ITEMS.
Definition view.h:220
void SetCenter(const VECTOR2D &aCenter)
Set the center point of the VIEW (i.e.
Definition view.cpp:597
void MarkTargetDirty(int aTarget)
Set or clear target 'dirty' flag.
Definition view.h:639
PROJECT & Prj() const
Return a reference to the PROJECT associated with this KIWAY.
A minimalistic software bus for communications between various DLLs/DSOs (DSOs) within the same KiCad...
Definition kiway.h:294
virtual void ExpressMail(FRAME_T aDestination, MAIL_T aCommand, std::string &aPayload, wxWindow *aSource=nullptr, bool aFromOtherThread=false)
Send aPayload to aDestination from aSource.
Definition kiway.cpp:507
A collection of #SYMBOL_LIB objects.
Object used to load, save, search, and otherwise manipulate symbol library files.
LIB_SYMBOL * FindSymbol(const wxString &aName) const
Find LIB_SYMBOL by aName.
std::optional< wxString > GetLibraryDescription(const wxString &aNickname) const
bool HasLibrary(const wxString &aNickname, bool aCheckEnabled=false) const
Test for the existence of aNickname in the library tables.
std::vector< wxString > GetLibraryNames() const
Returns a list of library nicknames that are available (skips any that failed to load)
std::optional< wxString > GetFullURI(LIBRARY_TABLE_TYPE aType, const wxString &aNickname, bool aSubstituted=false) const
Return the full location specifying URI for the LIB, either in original UI form or in environment var...
A logical library item identifier and consists of various portions much like a URI.
Definition lib_id.h:49
const UTF8 & GetLibItemName() const
Definition lib_id.h:102
const UTF8 & GetLibNickname() const
Return the logical library name portion of a LIB_ID.
Definition lib_id.h:87
Define a library symbol object.
Definition lib_symbol.h:83
static const wxString GetPinningSymbol()
Describe the page size and margins of a paper page on which to eventually print or plot.
Definition page_info.h:79
const VECTOR2D GetSizeIU(double aIUScale) const
Gets the page size in internal units.
Definition page_info.h:177
virtual COMMON_SETTINGS * GetCommonSettings() const
Definition pgm_base.cpp:535
virtual BACKGROUND_JOBS_MONITOR & GetBackgroundJobMonitor() const
Definition pgm_base.h:138
virtual LIBRARY_MANAGER & GetLibraryManager() const
Definition pgm_base.h:134
The backing store for a PROJECT, in JSON format.
static SYMBOL_LIBRARY_ADAPTER * SymbolLibAdapter(PROJECT *aProject)
Accessor for project symbol library manager adapter.
static LEGACY_SYMBOL_LIBS * LegacySchLibs(PROJECT *aProject)
Returns the list of symbol libraries from a legacy (pre-5.x) design This is only used from the remapp...
@ SCH_LIB_SELECT
Definition project.h:220
@ SCH_LIB_PATH
Definition project.h:219
virtual PROJECT_FILE & GetProjectFile() const
Definition project.h:203
virtual void SetRString(RSTRING_T aStringId, const wxString &aString)
Store a "retained string", which is any session and project specific string identified in enum RSTRIN...
Definition project.cpp:340
virtual const wxString & GetRString(RSTRING_T aStringId)
Return a "retained string", which is any session and project specific string identified in enum RSTRI...
Definition project.cpp:351
virtual void RedrawScreen(const VECTOR2I &aCenterPoint, bool aWarpPointer)
SCH_BASE_FRAME(KIWAY *aKiway, wxWindow *aParent, FRAME_T aWindowType, const wxString &aTitle, const wxPoint &aPosition, const wxSize &aSize, long aStyle, const wxString &aFrameName)
void UpdateStatusBar() override
Update the status bar information.
void RemoveFromScreen(EDA_ITEM *aItem, SCH_SCREEN *aScreen) override
Remove an item from the screen (and view) aScreen is the screen the item is located on,...
SCH_RENDER_SETTINGS * GetRenderSettings()
void doCloseWindow() override
void ActivateGalCanvas() override
Use to start up the GAL drawing canvas.
const VECTOR2I GetPageSizeIU() const override
Works off of GetPageSettings() to return the size of the paper page in the internal units of this par...
void SetPageSettings(const PAGE_INFO &aPageSettings) override
void handleIconizeEvent(wxIconizeEvent &aEvent) override
Handle a window iconize event.
void OnSymChange(wxFileSystemWatcherEvent &aEvent)
Handler for Symbol change events.
SCH_SCREEN * GetScreen() const override
Return a pointer to a BASE_SCREEN or one of its derivatives.
SYMBOL_EDITOR_SETTINGS * libeditconfig() const
SCH_DRAW_PANEL * GetCanvas() const override
Return a pointer to GAL-based canvas of given EDA draw frame.
APP_SETTINGS_BASE * GetViewerSettingsBase() const
void HighlightSelectionFilter(const SCH_SELECTION_FILTER_OPTIONS &aOptions)
void HardRedraw() override
Rebuild the GAL and redraws the screen.
DIALOG_SCH_FIND * m_findReplaceDialog
SCHEMATIC_SETTINGS m_base_frame_defaults
Only used by symbol_editor. Eeschema should be using the one inside the SCHEMATIC.
wxTimer m_watcherDebounceTimer
void CommonSettingsChanged(int aFlags) override
Notification event that some of the common (suite-wide) settings have changed.
void ShowFindReplaceDialog(bool aReplace)
Run the Find or Find & Replace dialog.
SCH_SELECTION_TOOL * GetSelectionTool() override
void SyncView()
Mark all items for refresh.
std::unique_ptr< NL_SCHEMATIC_PLUGIN > m_spaceMouse
void GetLibraryItemsForListDialog(wxArrayString &aHeaders, std::vector< wxArrayString > &aItemsToDisplay)
wxDateTime m_watcherLastModified
std::unique_ptr< wxFileSystemWatcher > m_watcher
These are file watchers for the symbol library tables.
wxString SelectLibrary(const wxString &aDialogTitle, const wxString &aListLabel, const std::vector< std::pair< wxString, bool * > > &aExtraCheckboxes={})
Display a list of loaded libraries and allows the user to select a library.
virtual ~SCH_BASE_FRAME()
Needs to be in the cpp file to encode the sizeof() for std::unique_ptr.
const TITLE_BLOCK & GetTitleBlock() const override
void RefreshZoomDependentItems()
Mark selected items for refresh.
EESCHEMA_SETTINGS * eeconfig() const
void SetTitleBlock(const TITLE_BLOCK &aTitleBlock) override
PANEL_SCH_SELECTION_FILTER * m_selectionFilterPanel
LIB_SYMBOL * GetLibSymbol(const LIB_ID &aLibId, bool aUseCacheLib=false, bool aShowErrorMsg=false)
Load symbol from symbol library table.
virtual void UpdateItem(EDA_ITEM *aItem, bool isAddOrDelete=false, bool aUpdateRtree=false)
Mark an item for refresh.
void handleActivateEvent(wxActivateEvent &aEvent) override
Handle a window activation event.
COLOR_SETTINGS * GetColorSettings(bool aForceRefresh=false) const override
Returns a pointer to the active color theme settings.
void OnFindDialogClose()
Notification that the Find dialog has closed.
wxFileName m_watcherFileName
void setSymWatcher(const LIB_ID *aSymbol)
Creates (or removes) a watcher on the specified symbol library.
void AddToScreen(EDA_ITEM *aItem, SCH_SCREEN *aScreen=nullptr) override
Add an item to the screen (and view) aScreen is the screen the item is located on,...
const PAGE_INFO & GetPageSettings() const override
void ShowFindReplaceStatus(const wxString &aMsg, int aStatusTime)
COLOR4D GetDrawBgColor() const override
void OnSymChangeDebounceTimer(wxTimerEvent &aEvent)
Handler for the filesystem watcher debounce timer.
void ClearFindReplaceStatus()
COLOR4D GetLayerColor(SCH_LAYER_ID aLayer)
Helper to retrieve a layer color from the global color settings.
KIGFX::SCH_VIEW * GetView() const override
Return a pointer to the #VIEW instance used in the panel.
virtual const wxString & GetText() const override
Return the string associated with the text object.
Definition sch_field.h:116
A set of SCH_ITEMs (i.e., without duplicates).
Definition sch_group.h:52
Base class for any item which can be embedded within the SCHEMATIC container class,...
Definition sch_item.h:167
const PAGE_INFO & GetPageSettings() const
Definition sch_screen.h:140
void SetTitleBlock(const TITLE_BLOCK &aTitleBlock)
Definition sch_screen.h:166
void Append(SCH_ITEM *aItem, bool aUpdateLibSymbol=true)
void SetPageSettings(const PAGE_INFO &aPageSettings)
Definition sch_screen.h:141
const TITLE_BLOCK & GetTitleBlock() const
Definition sch_screen.h:164
void Update(SCH_ITEM *aItem, bool aUpdateLibSymbol=true)
Update aItem's bounding box in the tree.
SCH_SELECTION & GetSelection()
void OnIdle(wxIdleEvent &aEvent)
Zoom the screen to fit the bounding box for cross probing/selection sync.
Schematic symbol object.
Definition sch_symbol.h:76
SCH_FIELD * GetField(FIELD_T aFieldType)
Return a mandatory field in this symbol.
EDA_ITEM * Front() const
Definition selection.h:177
int Size() const
Returns the number of selected parts.
Definition selection.h:121
An interface to the global shared library manager that is schematic-specific and linked to one projec...
LIB_SYMBOL * LoadSymbol(const wxString &aNickname, const wxString &aName)
Load a LIB_SYMBOL having aName from the library given by aNickname.
Class to handle modifications to the symbol libraries.
bool CreateLibrary(const wxString &aFilePath, LIBRARY_TABLE_SCOPE aScope)
Create an empty library and adds it to the library table.
Hold the information shown in the lower right corner of a plot, printout, or editing view.
Definition title_block.h:41
TOOL_MANAGER * m_toolManager
@ MODEL_RELOAD
Model changes (the sheet for a schematic)
Definition tool_base.h:80
wxString MessageTextFromValue(double aValue, bool aAddUnitLabel=true, EDA_DATA_TYPE aType=EDA_DATA_TYPE::DISTANCE) const
A lower-precision version of StringFromValue().
const char * c_str() const
Definition utf8.h:108
wxString wx_str() const
Definition utf8.cpp:45
const wxString ExpandEnvVarSubstitutions(const wxString &aString, const PROJECT *aProject)
Replace any environment variable & text variable references with their values.
Definition common.cpp:558
bool IsOK(wxWindow *aParent, const wxString &aMessage)
Display a yes/no dialog with aMessage and returns the user response.
Definition confirm.cpp:259
void DisplayErrorMessage(wxWindow *aParent, const wxString &aText, const wxString &aExtraInfo)
Display an error message with aMessage.
Definition confirm.cpp:202
void DisplayError(wxWindow *aParent, const wxString &aText)
Display an error or warning message box with aMessage.
Definition confirm.cpp:177
This file is part of the common library.
#define _(s)
@ RECURSE
Definition eda_item.h:51
FRAME_T
The set of EDA_BASE_FRAME derivatives, typically stored in EDA_BASE_FRAME::m_Ident.
Definition frame_type.h:33
@ FRAME_SCH_SYMBOL_EDITOR
Definition frame_type.h:35
@ FRAME_SCH_VIEWER
Definition frame_type.h:36
@ FRAME_SCH
Definition frame_type.h:34
@ FRAME_SYMBOL_CHOOSER
Definition frame_type.h:37
static const std::string KiCadSymbolLibFileExtension
static wxString KiCadSymbolLibFileWildcard()
const wxChar *const traceLibWatch
Flag to enable debug output for library file watch refreshes.
SCH_LAYER_ID
Eeschema drawing layers.
Definition layer_ids.h:449
@ LAYER_SCHEMATIC_GRID_AXES
Definition layer_ids.h:487
@ LAYER_SCHEMATIC_BACKGROUND
Definition layer_ids.h:488
LIBRARY_TABLE_SCOPE
@ MAIL_REFRESH_SYMBOL
Definition mail_type.h:59
@ REPAINT
Item needs to be redrawn.
Definition view_item.h:58
@ ALL
All except INITIAL_ADD.
Definition view_item.h:59
@ TARGET_NONCACHED
Auxiliary rendering target (noncached)
Definition definitions.h:38
bool contains(const _Container &__container, _Value __value)
Returns true if the container contains the given value.
Definition kicad_algo.h:100
Declaration of the NL_SCHEMATIC_PLUGIN class.
PGM_BASE & Pgm()
The global program "get" accessor.
see class PGM_BASE
LIB_SYMBOL * SchGetLibSymbol(const LIB_ID &aLibId, SYMBOL_LIBRARY_ADAPTER *aLibMgr, LEGACY_SYMBOL_LIB *aCacheLib, wxWindow *aParent, bool aShowErrorMsg)
Load symbol from symbol library table.
LIB_SYMBOL * SchGetLibSymbol(const LIB_ID &aLibId, SYMBOL_LIBRARY_ADAPTER *aLibMgr, LEGACY_SYMBOL_LIB *aCacheLib=nullptr, wxWindow *aParent=nullptr, bool aShowErrorMsg=false)
Load symbol from symbol library table.
Class to handle a set of SCH_ITEMs.
T * GetAppSettings(const char *aFilename)
KIWAY Kiway(KFCTL_STANDALONE)
wxString UnescapeString(const wxString &aSource)
std::vector< wxString > pinned_symbol_libs
@ ID_MAKE_NEW_LIBRARY
@ VALUE
Field Value of part, i.e. "3.3K".
wxLogTrace helper definitions.
@ SCH_TABLE_T
Definition typeinfo.h:169
@ SCH_SYMBOL_T
Definition typeinfo.h:176
@ SCH_TABLECELL_T
Definition typeinfo.h:170
@ SCH_FIELD_T
Definition typeinfo.h:154
@ SCH_LABEL_T
Definition typeinfo.h:171
@ SCH_SHEET_T
Definition typeinfo.h:179
@ SCH_SHAPE_T
Definition typeinfo.h:153
@ SCH_HIER_LABEL_T
Definition typeinfo.h:173
@ SCH_LABEL_LOCATE_ANY_T
Definition typeinfo.h:195
@ SCH_SHEET_PIN_T
Definition typeinfo.h:178
@ SCH_TEXT_T
Definition typeinfo.h:155
@ SCH_GLOBAL_LABEL_T
Definition typeinfo.h:172
VECTOR2< int32_t > VECTOR2I
Definition vector2d.h:695
VECTOR2< double > VECTOR2D
Definition vector2d.h:694