KiCad PCB EDA Suite
Loading...
Searching...
No Matches
sch_commit.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 The KiCad Developers, see AUTHORS.txt for contributors.
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * as published by the Free Software Foundation; either version 2
9 * of the License, or (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, you may find one here:
18 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
19 * or you may search the http://www.gnu.org website for the version 2 license,
20 * or you may write to the Free Software Foundation, Inc.,
21 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
22 */
23
24#include <macros.h>
25#include <tool/tool_manager.h>
26#include <tools/sch_tool_base.h>
27
28#include <lib_symbol.h>
29
30#include <sch_group.h>
31#include <sch_screen.h>
32#include <schematic.h>
33
34#include <view/view.h>
35#include <sch_commit.h>
36#include <connection_graph.h>
37
38#include <functional>
39#include <wx/log.h>
40
41
43 COMMIT(),
44 m_toolMgr( aToolMgr ),
45 m_isLibEditor( false )
46{
47 SCH_BASE_FRAME* frame = static_cast<SCH_BASE_FRAME*>( m_toolMgr->GetToolHolder() );
48 m_isLibEditor = frame && frame->IsType( FRAME_SCH_SYMBOL_EDITOR );
49}
50
51
57
58
64
65
69
70
72 RECURSE_MODE aRecurse )
73{
74 wxCHECK( aItem, *this );
75
76 if( aRecurse == RECURSE_MODE::RECURSE )
77 {
78 if( SCH_GROUP* group = dynamic_cast<SCH_GROUP*>( aItem ) )
79 {
80 for( EDA_ITEM* member : group->GetItems() )
81 Stage( member, aChangeType, aScreen, aRecurse );
82 }
83 }
84
85 // IS_SELECTED flag should not be set on undo items which were added for a drag operation.
86 if( aItem->IsSelected() && aItem->HasFlag( SELECTED_BY_DRAG ) )
87 {
88 aItem->ClearSelected();
89 COMMIT::Stage( aItem, aChangeType, aScreen );
90 aItem->SetSelected();
91 }
92 else
93 {
94 COMMIT::Stage( aItem, aChangeType, aScreen );
95 }
96
97 return *this;
98}
99
100
101COMMIT& SCH_COMMIT::Stage( std::vector<EDA_ITEM*> &container, CHANGE_TYPE aChangeType,
102 BASE_SCREEN *aScreen )
103{
104 for( EDA_ITEM* item : container )
105 Stage( item, aChangeType, aScreen );
106
107 return *this;
108}
109
110
111void SCH_COMMIT::pushLibEdit( const wxString& aMessage, int aCommitFlags )
112{
113 // Symbol editor just saves copies of the whole symbol, so grab the first and discard the rest
114 LIB_SYMBOL* symbol = dynamic_cast<LIB_SYMBOL*>( m_entries.front().m_item );
115 LIB_SYMBOL* copy = dynamic_cast<LIB_SYMBOL*>( m_entries.front().m_copy );
116
117 if( symbol )
118 {
119 if( KIGFX::VIEW* view = m_toolMgr->GetView() )
120 {
121 view->Update( symbol );
122
123 symbol->RunOnChildren(
124 [&]( SCH_ITEM* aChild )
125 {
126 view->Update( aChild );
127 },
129 }
130
131 if( SYMBOL_EDIT_FRAME* frame = static_cast<SYMBOL_EDIT_FRAME*>( m_toolMgr->GetToolHolder() ) )
132 {
133 if( !( aCommitFlags & SKIP_UNDO ) )
134 {
135 if( copy )
136 {
137 frame->PushSymbolToUndoList( aMessage, copy );
138 copy = nullptr; // we've transferred ownership to the undo stack
139 }
140 }
141 }
142
143 if( copy )
144 {
145 // if no undo entry was needed, the copy would create a memory leak
146 delete copy;
147 copy = nullptr;
148 }
149 }
150
151 m_toolMgr->PostEvent( { TC_MESSAGE, TA_MODEL_CHANGE, AS_GLOBAL } );
153}
154
155
156void SCH_COMMIT::pushSchEdit( const wxString& aMessage, int aCommitFlags )
157{
158 // Objects potentially interested in changes:
159 PICKED_ITEMS_LIST undoList;
160 KIGFX::VIEW* view = m_toolMgr->GetView();
161
162 SCH_EDIT_FRAME* frame = static_cast<SCH_EDIT_FRAME*>( m_toolMgr->GetToolHolder() );
163 SCH_SELECTION_TOOL* selTool = m_toolMgr->GetTool<SCH_SELECTION_TOOL>();
164 SCH_GROUP* enteredGroup = selTool ? selTool->GetEnteredGroup() : nullptr;
165 bool itemsDeselected = false;
166 bool selectedModified = false;
167 bool dirtyConnectivity = false;
168 bool refreshHierarchy = false;
169 SCH_CLEANUP_FLAGS connectivityCleanUp = NO_CLEANUP;
170
171 if( Empty() )
172 return;
173
174 undoList.SetDescription( aMessage );
175
176 SCHEMATIC* schematic = nullptr;
177 std::vector<SCH_ITEM*> bulkAddedItems;
178 std::vector<SCH_ITEM*> bulkRemovedItems;
179 std::vector<SCH_ITEM*> itemsChanged;
180
181 auto updateConnectivityFlag =
182 [&]( SCH_ITEM* schItem )
183 {
184 if( schItem->IsConnectable() || ( schItem->Type() == SCH_RULE_AREA_T ) )
185 {
186 dirtyConnectivity = true;
187
188 // Do a local clean up if there are any connectable objects in the commit.
189 if( connectivityCleanUp == NO_CLEANUP )
190 connectivityCleanUp = LOCAL_CLEANUP;
191
192 // Do a full rebuild of the connectivity if there is a sheet in the commit.
193 if( schItem->Type() == SCH_SHEET_T )
194 connectivityCleanUp = GLOBAL_CLEANUP;
195 }
196 };
197
198 // We don't know that anything will be added to the entered group, but it does no harm to
199 // add it to the commit anyway.
200 if( enteredGroup )
201 Modify( enteredGroup, frame->GetScreen() );
202
203 // Handle wires with Hop Over shapes:
204 for( COMMIT_LINE& entry : m_entries )
205 {
206 SCH_ITEM* schCopyItem = dynamic_cast<SCH_ITEM*>( entry.m_copy );
207 SCH_ITEM* schItem = dynamic_cast<SCH_ITEM*>( entry.m_item );
208
209 if( schCopyItem && schCopyItem->Type() == SCH_LINE_T )
210 frame->UpdateHopOveredWires( schCopyItem );
211
212 if( schItem && schItem->Type() == SCH_LINE_T )
213 frame->UpdateHopOveredWires( schItem );
214 }
215
216
217 for( COMMIT_LINE& entry : m_entries )
218 {
219 SCH_ITEM* schItem = dynamic_cast<SCH_ITEM*>( entry.m_item );
220 int changeType = entry.m_type & CHT_TYPE;
221
222 wxCHECK2( schItem, continue );
223
224 if( changeType == CHT_REMOVE && schItem->GetParentGroup() )
225 Modify( schItem->GetParentGroup()->AsEdaItem(), entry.m_screen );
226 }
227
228 for( COMMIT_LINE& entry : m_entries )
229 {
230 int changeType = entry.m_type & CHT_TYPE;
231 int changeFlags = entry.m_type & CHT_FLAGS;
232 SCH_ITEM* schItem = dynamic_cast<SCH_ITEM*>( entry.m_item );
233 SCH_SCREEN* screen = dynamic_cast<SCH_SCREEN*>( entry.m_screen );
234
235 wxCHECK2( schItem, continue );
236 wxCHECK2( screen, continue );
237
238 if( !schematic )
239 schematic = schItem->Schematic();
240
241 if( schItem->IsSelected() )
242 {
243 selectedModified = true;
244 }
245 else
246 {
247 schItem->RunOnChildren(
248 [&selectedModified]( SCH_ITEM* aChild )
249 {
250 if( aChild->IsSelected() )
251 selectedModified = true;
252 },
254 }
255
256 switch( changeType )
257 {
258 case CHT_ADD:
259 {
260 if( enteredGroup && schItem->IsGroupableType() && !schItem->GetParentGroup() )
261 selTool->GetEnteredGroup()->AddItem( schItem );
262
263 updateConnectivityFlag( schItem );
264
265 if( !( aCommitFlags & SKIP_UNDO ) )
266 undoList.PushItem( ITEM_PICKER( screen, schItem, UNDO_REDO::NEWITEM ) );
267
268 if( !( changeFlags & CHT_DONE ) )
269 {
270 if( !screen->CheckIfOnDrawList( schItem ) ) // don't want a loop!
271 screen->Append( schItem );
272
273 if( view )
274 view->Add( schItem );
275 }
276
277 if( frame )
278 frame->UpdateItem( schItem, true, true );
279
280 bulkAddedItems.push_back( schItem );
281
282 if( schItem->Type() == SCH_SHEET_T )
283 refreshHierarchy = true;
284
285 break;
286 }
287
288 case CHT_REMOVE:
289 {
290 updateConnectivityFlag( schItem );
291
292 if( !( aCommitFlags & SKIP_UNDO ) )
293 {
294 ITEM_PICKER itemWrapper( screen, schItem, UNDO_REDO::DELETED );
295 itemWrapper.SetLink( entry.m_copy );
296 entry.m_copy = nullptr; // We've transferred ownership to the undo list
297 undoList.PushItem( itemWrapper );
298 }
299
300 if( schItem->IsSelected() )
301 {
302 if( selTool )
303 selTool->RemoveItemFromSel( schItem, true /* quiet mode */ );
304
305 itemsDeselected = true;
306 }
307
308 if( schItem->Type() == SCH_FIELD_T )
309 {
310 static_cast<SCH_FIELD*>( schItem )->SetVisible( false );
311 break;
312 }
313
314 if( EDA_GROUP* group = schItem->GetParentGroup() )
315 group->RemoveItem( schItem );
316
317 if( !( changeFlags & CHT_DONE ) )
318 {
319 screen->Remove( schItem );
320
321 if( view )
322 view->Remove( schItem );
323 }
324
325 if( frame )
326 frame->UpdateItem( schItem, true, true );
327
328 if( schItem->Type() == SCH_SHEET_T )
329 refreshHierarchy = true;
330
331 bulkRemovedItems.push_back( schItem );
332 break;
333 }
334
335 case CHT_MODIFY:
336 {
337 const SCH_ITEM* itemCopy = static_cast<const SCH_ITEM*>( entry.m_copy );
338 SCH_SHEET_PATH currentSheet;
339
340 if( frame )
341 currentSheet = frame->GetCurrentSheet();
342
343 if( itemCopy->HasConnectivityChanges( schItem, &currentSheet )
344 || ( itemCopy->Type() == SCH_RULE_AREA_T ) )
345 {
346 updateConnectivityFlag( schItem );
347 }
348
349 if( !( aCommitFlags & SKIP_UNDO ) )
350 {
351#if 0
352 // While this keeps us from marking documents modified when someone OK's a dialog with
353 // no changes, it depends on our various SCH_ITEM::operator=='s being bullet-proof. They
354 // currently aren't.
355 if( *itemCopy == *schItem )
356 {
357 // No actual changes made; short-circuit undo
358 delete entry.m_copy;
359 entry.m_copy = nullptr;
360 break;
361 }
362#endif
363
364 ITEM_PICKER itemWrapper( screen, schItem, UNDO_REDO::CHANGED );
365 itemWrapper.SetLink( entry.m_copy );
366 entry.m_copy = nullptr; // We've transferred ownership to the undo list
367 undoList.PushItem( itemWrapper );
368 }
369
370 if( schItem->Type() == SCH_SHEET_T )
371 {
372 const SCH_SHEET* modifiedSheet = static_cast<const SCH_SHEET*>( schItem );
373 const SCH_SHEET* originalSheet = static_cast<const SCH_SHEET*>( itemCopy );
374 wxCHECK2( modifiedSheet && originalSheet, continue );
375
376 if( originalSheet->HasPageNumberChanges( *modifiedSheet ) )
377 refreshHierarchy = true;
378 }
379
380 if( frame )
381 frame->UpdateItem( schItem, false, true );
382
383 itemsChanged.push_back( schItem );
384 break;
385 }
386
387 default:
388 wxASSERT( false );
389 break;
390 }
391
392 // Delete any copies we still have ownership of
393 delete entry.m_copy;
394 entry.m_copy = nullptr;
395
396 // Clear all flags but SELECTED and others used to move and rotate commands,
397 // after edition (selected items must keep their selection flag).
398 const int selected_mask = ( SELECTED | STARTPOINT | ENDPOINT );
399 schItem->ClearFlags( EDA_ITEM_ALL_FLAGS - selected_mask );
400
401 if( schItem->Type() == SCH_SHEET_T || schItem->Type() == SCH_SYMBOL_T )
402 {
403 schItem->RunOnChildren(
404 [&]( SCH_ITEM* child )
405 {
406 child->ClearFlags( EDA_ITEM_ALL_FLAGS - selected_mask );
407 },
409 }
410 }
411
412 if( schematic )
413 {
414 if( bulkAddedItems.size() > 0 )
415 schematic->OnItemsAdded( bulkAddedItems );
416
417 if( bulkRemovedItems.size() > 0 )
418 schematic->OnItemsRemoved( bulkRemovedItems );
419
420 if( itemsChanged.size() > 0 )
421 schematic->OnItemsChanged( itemsChanged );
422
423 if( refreshHierarchy )
424 {
425 schematic->RefreshHierarchy();
426
427 if( frame )
429 }
430 }
431
432 if( !( aCommitFlags & SKIP_UNDO ) )
433 {
434 if( frame )
435 {
436 if( undoList.GetCount() > 0 )
437 frame->SaveCopyInUndoList( undoList, UNDO_REDO::UNSPECIFIED, false );
438
439 if( dirtyConnectivity )
440 {
441 wxLogTrace( wxS( "CONN_PROFILE" ),
442 wxS( "SCH_COMMIT::pushSchEdit() %s clean up connectivity rebuild." ),
443 connectivityCleanUp == LOCAL_CLEANUP ? wxS( "local" ) : wxS( "global" ) );
444 frame->RecalculateConnections( this, connectivityCleanUp );
445 }
446 }
447 }
448
449 m_toolMgr->PostEvent( { TC_MESSAGE, TA_MODEL_CHANGE, AS_GLOBAL } );
450
451 if( itemsDeselected )
453
454 if( selectedModified )
456}
457
458
459void SCH_COMMIT::Push( const wxString& aMessage, int aCommitFlags )
460{
461 if( Empty() )
462 return;
463
464 if( m_isLibEditor )
465 pushLibEdit( aMessage, aCommitFlags );
466 else
467 pushSchEdit( aMessage, aCommitFlags );
468
469 if( SCH_BASE_FRAME* frame = static_cast<SCH_BASE_FRAME*>( m_toolMgr->GetToolHolder() ) )
470 {
471 if( !( aCommitFlags & SKIP_SET_DIRTY ) )
472 frame->OnModify();
473
474 if( frame && frame->GetCanvas() )
475 frame->GetCanvas()->Refresh();
476 }
477
478 clear();
479}
480
481
483{
484 EDA_ITEM* parent = aItem->GetParent();
485
486 if( m_isLibEditor )
487 return static_cast<SYMBOL_EDIT_FRAME*>( m_toolMgr->GetToolHolder() )->GetCurSymbol();
488
489 if( parent && parent->IsType( { SCH_SYMBOL_T, SCH_TABLE_T, SCH_SHEET_T, SCH_LABEL_LOCATE_ANY_T } ) )
490 return parent;
491
492 return aItem;
493}
494
495
497{
498 if( m_isLibEditor )
499 {
500 SYMBOL_EDIT_FRAME* frame = static_cast<SYMBOL_EDIT_FRAME*>( m_toolMgr->GetToolHolder() );
501 LIB_SYMBOL* symbol = frame->GetCurSymbol();
502 std::vector<KIID> selected;
503
504 // Cloning will clear the selected flags, but we want to keep them.
505 for( const SCH_ITEM& item : symbol->GetDrawItems() )
506 {
507 if( item.IsSelected() )
508 selected.push_back( item.m_Uuid );
509 }
510
511 symbol = new LIB_SYMBOL( *symbol );
512
513 // Restore selected flags.
514 for( SCH_ITEM& item : symbol->GetDrawItems() )
515 {
516 if( alg::contains( selected, item.m_Uuid ) )
517 item.SetSelected();
518 }
519
520 return symbol;
521 }
522
523 return aItem->Clone();
524}
525
526
528{
529 if( Empty() )
530 return;
531
532 // Symbol editor just saves copies of the whole symbol, so grab the first and discard the rest
533 SYMBOL_EDIT_FRAME* frame = dynamic_cast<SYMBOL_EDIT_FRAME*>( m_toolMgr->GetToolHolder() );
534 LIB_SYMBOL* copy = dynamic_cast<LIB_SYMBOL*>( m_entries.front().m_copy );
535 SCH_SELECTION_TOOL* selTool = m_toolMgr->GetTool<SCH_SELECTION_TOOL>();
536
537 if( frame && copy )
538 {
539 frame->SetCurSymbol( copy, false );
540 m_toolMgr->ResetTools( TOOL_BASE::MODEL_RELOAD );
541 }
542
543 if( selTool )
544 selTool->RebuildSelection();
545
546 clear();
547}
548
549
551{
552 KIGFX::VIEW* view = m_toolMgr->GetView();
553 SCH_EDIT_FRAME* frame = dynamic_cast<SCH_EDIT_FRAME*>( m_toolMgr->GetToolHolder() );
554 SCH_SELECTION_TOOL* selTool = m_toolMgr->GetTool<SCH_SELECTION_TOOL>();
555 SCH_SHEET_LIST sheets;
556
557 if( m_entries.empty() )
558 return;
559
560 if( m_isLibEditor )
561 {
563 return;
564 }
565
566 SCHEMATIC* schematic = nullptr;
567 std::vector<SCH_ITEM*> bulkAddedItems;
568 std::vector<SCH_ITEM*> bulkRemovedItems;
569 std::vector<SCH_ITEM*> itemsChanged;
570
571 for( COMMIT_LINE& ent : m_entries )
572 {
573 int changeType = ent.m_type & CHT_TYPE;
574 int changeFlags = ent.m_type & CHT_FLAGS;
575 SCH_ITEM* item = dynamic_cast<SCH_ITEM*>( ent.m_item );
576 SCH_ITEM* copy = dynamic_cast<SCH_ITEM*>( ent.m_copy );
577 SCH_SCREEN* screen = dynamic_cast<SCH_SCREEN*>( ent.m_screen );
578
579 wxCHECK2( item && screen, continue );
580
581 if( !schematic )
582 schematic = item->Schematic();
583
584 switch( changeType )
585 {
586 case CHT_ADD:
587 if( !( changeFlags & CHT_DONE ) )
588 break;
589
590 if( view )
591 view->Remove( item );
592
593 screen->Remove( item );
594 bulkRemovedItems.push_back( item );
595 break;
596
597 case CHT_REMOVE:
598 item->SetConnectivityDirty();
599
600 if( !( changeFlags & CHT_DONE ) )
601 break;
602
603 if( view )
604 view->Add( item );
605
606 screen->Append( item );
607 bulkAddedItems.push_back( item );
608 break;
609
610 case CHT_MODIFY:
611 {
612 wxCHECK2( copy, break );
613
614 if( view )
615 view->Remove( item );
616
617 bool unselect = !item->IsSelected();
618
619 item->SwapItemData( copy );
620
621 if( unselect )
622 {
623 item->ClearSelected();
624 item->RunOnChildren( []( SCH_ITEM* aChild )
625 {
626 aChild->ClearSelected();
627 },
629 }
630
631 // Special cases for items which have instance data
632 if( item->GetParent() && item->GetParent()->Type() == SCH_SYMBOL_T && item->Type() == SCH_FIELD_T )
633 {
634 SCH_FIELD* field = static_cast<SCH_FIELD*>( item );
635 SCH_SYMBOL* symbol = static_cast<SCH_SYMBOL*>( item->GetParent() );
636
637 if( field->GetId() == FIELD_T::REFERENCE )
638 {
639 // Lazy eval of sheet list; this is expensive even when unsorted
640 if( sheets.empty() )
641 sheets = schematic->Hierarchy();
642
643 SCH_SHEET_PATH sheet = sheets.FindSheetForScreen( screen );
644 symbol->SetRef( &sheet, field->GetText() );
645 }
646 }
647
648 // This must be called before any calls that require stable object pointers.
649 screen->Update( item );
650
651 // This hack is to prevent incorrectly parented symbol pins from breaking the
652 // connectivity algorithm.
653 if( item->Type() == SCH_SYMBOL_T )
654 {
655 SCH_SYMBOL* symbol = static_cast<SCH_SYMBOL*>( item );
656 symbol->UpdatePins();
657
658 CONNECTION_GRAPH* graph = schematic->ConnectionGraph();
659
660 SCH_SYMBOL* symbolCopy = static_cast<SCH_SYMBOL*>( copy );
661 graph->RemoveItem( symbolCopy );
662
663 for( SCH_PIN* pin : symbolCopy->GetPins() )
664 graph->RemoveItem( pin );
665 }
666
667 item->SetConnectivityDirty();
668
669 if( view )
670 view->Add( item );
671
672 delete copy;
673 break;
674 }
675
676 default:
677 wxASSERT( false );
678 break;
679 }
680 }
681
682 if( schematic )
683 {
684 if( bulkAddedItems.size() > 0 )
685 schematic->OnItemsAdded( bulkAddedItems );
686
687 if( bulkRemovedItems.size() > 0 )
688 schematic->OnItemsRemoved( bulkRemovedItems );
689
690 if( itemsChanged.size() > 0 )
691 schematic->OnItemsChanged( itemsChanged );
692 }
693
694 if( selTool )
695 selTool->RebuildSelection();
696
697 if( frame )
698 frame->RecalculateConnections( nullptr, NO_CLEANUP );
699
700 clear();
701}
702
Handles how to draw a screen (a board, a schematic ...)
Definition base_screen.h:41
bool Empty() const
Definition commit.h:137
COMMIT & Modify(EDA_ITEM *aItem, BASE_SCREEN *aScreen=nullptr, RECURSE_MODE aRecurse=RECURSE_MODE::NO_RECURSE)
Modify a given item in the model.
Definition commit.h:106
COMMIT()
Definition commit.cpp:34
std::vector< COMMIT_LINE > m_entries
Definition commit.h:185
void clear()
Should be called in Push() & Revert() methods.
Definition commit.h:157
virtual COMMIT & Stage(EDA_ITEM *aItem, CHANGE_TYPE aChangeType, BASE_SCREEN *aScreen=nullptr, RECURSE_MODE aRecurse=RECURSE_MODE::NO_RECURSE)
Add a change of the item aItem of type aChangeType to the change list.
Definition commit.cpp:46
Calculate the connectivity of a schematic and generates netlists.
void RemoveItem(SCH_ITEM *aItem)
bool IsType(FRAME_T aType) const
The base class for create windows for drawing purpose.
A set of EDA_ITEMs (i.e., without duplicates).
Definition eda_group.h:46
void AddItem(EDA_ITEM *aItem)
Add item to group.
Definition eda_group.cpp:27
virtual EDA_ITEM * AsEdaItem()=0
A base class for most all the KiCad significant classes used in schematics and boards.
Definition eda_item.h:99
virtual EDA_GROUP * GetParentGroup() const
Definition eda_item.h:117
KICAD_T Type() const
Returns the type of object.
Definition eda_item.h:111
void ClearSelected()
Definition eda_item.h:143
void ClearFlags(EDA_ITEM_FLAGS aMask=EDA_ITEM_ALL_FLAGS)
Definition eda_item.h:150
bool IsSelected() const
Definition eda_item.h:128
void SetSelected()
Definition eda_item.h:140
virtual bool IsType(const std::vector< KICAD_T > &aScanTypes) const
Check whether the item is one of the listed types.
Definition eda_item.h:198
EDA_ITEM * GetParent() const
Definition eda_item.h:113
virtual EDA_ITEM * Clone() const
Create a duplicate of this item with linked list members set to NULL.
Definition eda_item.cpp:128
bool HasFlag(EDA_ITEM_FLAGS aFlag) const
Definition eda_item.h:152
static const TOOL_EVENT SelectedItemsModified
Selected items were moved, this can be very high frequency on the canvas, use with care.
Definition actions.h:352
static const TOOL_EVENT UnselectedEvent
Definition actions.h:346
void SetLink(EDA_ITEM *aItem)
Hold a (potentially large) number of VIEW_ITEMs and renders them on a graphics device provided by the...
Definition view.h:67
virtual void Add(VIEW_ITEM *aItem, int aDrawPriority=-1)
Add a VIEW_ITEM to the view.
Definition view.cpp:299
virtual void Remove(VIEW_ITEM *aItem)
Remove a VIEW_ITEM from the view.
Definition view.cpp:342
Define a library symbol object.
Definition lib_symbol.h:83
LIB_ITEMS_CONTAINER & GetDrawItems()
Return a reference to the draw item list.
Definition lib_symbol.h:712
void RunOnChildren(const std::function< void(SCH_ITEM *)> &aFunction, RECURSE_MODE aMode) override
A holder to handle information on schematic or board items.
void PushItem(const ITEM_PICKER &aItem)
Push aItem to the top of the list.
void SetDescription(const wxString &aDescription)
unsigned GetCount() const
Holds all the data relating to one schematic.
Definition schematic.h:88
void OnItemsAdded(std::vector< SCH_ITEM * > &aNewItems)
Must be used if Add() is used using a BULK_x ADD_MODE to generate a change event for listeners.
void OnItemsRemoved(std::vector< SCH_ITEM * > &aRemovedItems)
Must be used if Remove() is used using a BULK_x REMOVE_MODE to generate a change event for listeners.
SCH_SHEET_LIST Hierarchy() const
Return the full schematic flattened hierarchical sheet list.
CONNECTION_GRAPH * ConnectionGraph() const
Definition schematic.h:199
void RefreshHierarchy()
void OnItemsChanged(std::vector< SCH_ITEM * > &aItems)
Notify the schematic and its listeners that an item on the schematic has been modified in some way.
A shim class between EDA_DRAW_FRAME and several derived classes: SYMBOL_EDIT_FRAME,...
COMMIT & Stage(EDA_ITEM *aItem, CHANGE_TYPE aChangeType, BASE_SCREEN *aScreen=nullptr, RECURSE_MODE aRecurse=RECURSE_MODE::NO_RECURSE) override
Add a change of the item aItem of type aChangeType to the change list.
bool m_isLibEditor
Definition sch_commit.h:73
virtual void Push(const wxString &aMessage=wxT("A commit"), int aCommitFlags=0) override
Execute the changes.
EDA_ITEM * undoLevelItem(EDA_ITEM *aItem) const override
virtual void Revert() override
Revert the commit by restoring the modified items state.
TOOL_MANAGER * m_toolMgr
Definition sch_commit.h:72
SCH_COMMIT(TOOL_MANAGER *aToolMgr)
virtual ~SCH_COMMIT()
void pushLibEdit(const wxString &aMessage, int aCommitFlags)
void revertLibEdit()
EDA_ITEM * makeImage(EDA_ITEM *aItem) const override
void pushSchEdit(const wxString &aMessage, int aCommitFlags)
Schematic editor (Eeschema) main window.
SCH_SCREEN * GetScreen() const override
Return a pointer to a BASE_SCREEN or one of its derivatives.
void SaveCopyInUndoList(SCH_SCREEN *aScreen, SCH_ITEM *aItemToCopy, UNDO_REDO aTypeCommand, bool aAppend)
Create a copy of the current schematic item, and put it in the undo list.
SCH_SHEET_PATH & GetCurrentSheet() const
void RecalculateConnections(SCH_COMMIT *aCommit, SCH_CLEANUP_FLAGS aCleanupFlags, PROGRESS_REPORTER *aProgressReporter=nullptr)
Generate the connection data for the entire schematic hierarchy.
void UpdateHierarchyNavigator(bool aRefreshNetNavigator=true, bool aClear=false)
Update the hierarchy navigation tree and history.
void UpdateItem(EDA_ITEM *aItem, bool isAddOrDelete=false, bool aUpdateRtree=false) override
Mark an item for refresh.
void UpdateHopOveredWires(SCH_ITEM *aItem)
virtual const wxString & GetText() const override
Return the string associated with the text object.
Definition sch_field.h:116
FIELD_T GetId() const
Definition sch_field.h:120
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:168
virtual void RunOnChildren(const std::function< void(SCH_ITEM *)> &aFunction, RECURSE_MODE aMode)
Definition sch_item.h:631
SCHEMATIC * Schematic() const
Search the item hierarchy to find a SCHEMATIC.
Definition sch_item.cpp:254
void SetConnectivityDirty(bool aDirty=true)
Definition sch_item.h:590
virtual bool HasConnectivityChanges(const SCH_ITEM *aItem, const SCH_SHEET_PATH *aInstance=nullptr) const
Check if aItem has connectivity changes against this object.
Definition sch_item.h:607
bool IsGroupableType() const
Definition sch_item.cpp:114
void SwapItemData(SCH_ITEM *aImage)
Swap data between aItem and aImage.
Definition sch_item.cpp:613
void Append(SCH_ITEM *aItem, bool aUpdateLibSymbol=true)
bool Remove(SCH_ITEM *aItem, bool aUpdateLibSymbol=true)
Remove aItem from the schematic associated with this screen.
void Update(SCH_ITEM *aItem, bool aUpdateLibSymbol=true)
Update aItem's bounding box in the tree.
bool CheckIfOnDrawList(const SCH_ITEM *aItem) const
void RebuildSelection()
Rebuild the selection from the EDA_ITEMs' selection flags.
SCH_GROUP * GetEnteredGroup()
A container for handling SCH_SHEET_PATH objects in a flattened hierarchy.
Handle access to a stack of flattened SCH_SHEET objects by way of a path for creating a flattened sch...
Sheet symbol placed in a schematic, and is the entry point for a sub schematic.
Definition sch_sheet.h:48
bool HasPageNumberChanges(const SCH_SHEET &aOther) const
Check if the instance data of this sheet has any changes compared to aOther.
Schematic symbol object.
Definition sch_symbol.h:76
std::vector< const SCH_PIN * > GetPins(const SCH_SHEET_PATH *aSheet) const
Retrieve a list of the SCH_PINs for the given sheet path.
void UpdatePins()
Updates the cache of SCH_PIN objects for each pin.
void SetRef(const SCH_SHEET_PATH *aSheet, const wxString &aReference)
Set the reference for the given sheet path for this symbol.
A foundation class for a tool operating on a schematic or symbol.
bool IsSymbolEditor() const
Returns true if the tool is running in the symbol editor.
int RemoveItemFromSel(const TOOL_EVENT &aEvent)
The symbol library editor main window.
void SetCurSymbol(LIB_SYMBOL *aSymbol, bool aUpdateZoom)
Take ownership of aSymbol and notes that it is the one currently being edited.
LIB_SYMBOL * GetCurSymbol() const
Return the current symbol being edited or NULL if none selected.
TOOL_MANAGER * GetToolManager() const
Return the MVC controller.
TOOL_MANAGER * GetManager() const
Return the instance of TOOL_MANAGER that takes care of the tool.
Definition tool_base.h:146
@ MODEL_RELOAD
Model changes (the sheet for a schematic)
Definition tool_base.h:80
Master controller class:
CHANGE_TYPE
Types of changes.
Definition commit.h:41
@ CHT_MODIFY
Definition commit.h:44
@ CHT_REMOVE
Definition commit.h:43
@ CHT_DONE
Flag to indicate the change is already applied.
Definition commit.h:47
@ CHT_TYPE
Definition commit.h:45
@ CHT_ADD
Definition commit.h:42
@ CHT_FLAGS
Definition commit.h:48
RECURSE_MODE
Definition eda_item.h:51
@ RECURSE
Definition eda_item.h:52
@ NO_RECURSE
Definition eda_item.h:53
#define SELECTED
Item was manually selected by the user.
#define SELECTED_BY_DRAG
Item was algorithmically selected as a dragged item.
#define EDA_ITEM_ALL_FLAGS
#define ENDPOINT
ends. (Used to support dragging.)
#define STARTPOINT
When a line is selected, these flags indicate which.
@ FRAME_SCH_SYMBOL_EDITOR
Definition frame_type.h:35
This file contains miscellaneous commonly used macros and functions.
bool contains(const _Container &__container, _Value __value)
Returns true if the container contains the given value.
Definition kicad_algo.h:100
#define SKIP_SET_DIRTY
Definition sch_commit.h:42
#define SKIP_UNDO
Definition sch_commit.h:40
Class to handle a set of SCH_ITEMs.
SCH_CLEANUP_FLAGS
Definition schematic.h:74
@ LOCAL_CLEANUP
Definition schematic.h:76
@ NO_CLEANUP
Definition schematic.h:75
@ GLOBAL_CLEANUP
Definition schematic.h:77
@ REFERENCE
Field Reference of part, i.e. "IC21".
KIBIS_PIN * pin
@ AS_GLOBAL
Global action (toolbar/main menu event, global shortcut)
Definition tool_action.h:49
@ TA_MODEL_CHANGE
Model has changed (partial update).
Definition tool_event.h:121
@ TC_MESSAGE
Definition tool_event.h:58
@ SCH_LINE_T
Definition typeinfo.h:167
@ SCH_SYMBOL_T
Definition typeinfo.h:176
@ SCH_FIELD_T
Definition typeinfo.h:154
@ SCH_SHEET_T
Definition typeinfo.h:179
@ SCH_RULE_AREA_T
Definition typeinfo.h:174