KiCad PCB EDA Suite
Loading...
Searching...
No Matches
footprint_editor_utils.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 <board_commit.h>
25#include <confirm.h>
28#include <footprint_info.h>
29#include <footprint_tree_pane.h>
31#include <functional>
32#include <kiway_mail.h>
33#include <pcb_group.h>
34#include <pcb_marker.h>
35#include <pcb_textbox.h>
36#include <pcb_barcode.h>
37#include <pcb_table.h>
38#include <pcb_shape.h>
39#include <pad.h>
40#include <zone.h>
42#include <tool/tool_manager.h>
43#include <tools/pcb_actions.h>
47#include <widgets/lib_tree.h>
49#include <pcb_dimension.h>
50#include <project_pcb.h>
51#include <view/view_controls.h>
54
55using namespace std::placeholders;
56
57
59{
60 bool is_last_fp_from_brd = IsCurrentFPFromBoard();
61
62 // The legacy path wipes the shared board; the tab path leaves other tabs untouched.
63 const bool useTabs = ( m_tabsPanel != nullptr ) && aFPID.IsValid();
64
65 if( useTabs )
66 {
67 const wxString key = aFPID.GetLibNickname().wx_str() + wxT( ':' ) + aFPID.GetLibItemName().wx_str();
68
69 // Reactivate rather than reload, which would discard in-tab edits.
70 if( int existing = m_tabsPanel->FindTab( key ); existing >= 0 )
71 {
72 m_tabsPanel->SelectTab( existing );
73
74 m_treePane->GetLibTree()->ExpandLibId( aFPID );
75
76 m_centerItemOnIdle = aFPID;
77 Bind( wxEVT_IDLE, &FOOTPRINT_EDIT_FRAME::centerItemIdleHandler, this );
78
79 m_treePane->GetLibTree()->RefreshLibTree(); // update highlighting
80
81 return;
82 }
83 }
84
85 FOOTPRINT* footprint = LoadFootprint( aFPID );
86
87 if( !footprint )
88 return;
89
90 if( useTabs )
91 {
92 // A board-sourced or new footprint occupies the frame-owned board with no backing tab.
93 // Switching to the library footprint's tab frees that board, so prompt to save those edits
94 // first, the same way the legacy single-board path does. A tab-owned board survives the
95 // switch untouched and needs no prompt.
97 {
99 this, _( "The current footprint has been modified. Save changes?" ),
100 [&]() -> bool
101 {
102 return SaveFootprint( GetBoard()->Footprints().front() );
103 } ) )
104 {
105 // AddFootprintToBoard would have taken ownership; on cancel we still own the clone.
106 delete footprint;
107 return;
108 }
109 }
110
112 AddFootprintToBoard( footprint );
113 }
114 else
115 {
116 if( !Clear_Pcb( true ) )
117 {
118 // AddFootprintToBoard would have taken ownership; on cancel we still own the clone.
119 delete footprint;
120 return;
121 }
122
124 AddFootprintToBoard( footprint );
125 }
126
127 footprint->ClearFlags();
128
129 // if either reference or value are missing, reinstall them -
130 // otherwise you cannot see what you are doing on board
131 if( footprint->Reference().GetText().IsEmpty() )
132 footprint->SetReference( wxT( "Ref**" ) );
133
134 if( footprint->Value().GetText().IsEmpty() )
135 footprint->SetValue( wxT( "Val**" ) );
136
137 Zoom_Automatique( false );
138
139 Update3DView( true, true );
140
141 GetScreen()->SetContentModified( false );
142
143 UpdateView();
144 GetCanvas()->Refresh();
145
146 // Update the save items if needed.
147 if( is_last_fp_from_brd )
148 {
151 }
152
153 m_treePane->GetLibTree()->ExpandLibId( aFPID );
154
155 m_centerItemOnIdle = aFPID;
156 Bind( wxEVT_IDLE, &FOOTPRINT_EDIT_FRAME::centerItemIdleHandler, this );
157
158 m_treePane->GetLibTree()->RefreshLibTree(); // update highlighting
159}
160
161
163{
164 m_treePane->GetLibTree()->CenterLibId( m_centerItemOnIdle );
165 Unbind( wxEVT_IDLE, &FOOTPRINT_EDIT_FRAME::centerItemIdleHandler, this );
166}
167
168
169void FOOTPRINT_EDIT_FRAME::OnTabCharHook( wxKeyEvent& aEvent )
170{
171 const bool isTab = aEvent.GetKeyCode() == WXK_TAB;
172 const bool ctrlOnly = aEvent.ControlDown() && !aEvent.AltDown() && !aEvent.MetaDown();
173
174 // Ctrl+W arrives as 'W' or the control char depending on platform, so accept both.
175 const int keyCode = aEvent.GetKeyCode();
176 const bool isCtrlW = ctrlOnly && !aEvent.ShiftDown()
177 && ( keyCode == 'W' || keyCode == ( 'W' - '@' ) );
178
179 if( isCtrlW && m_tabsPanel && m_tabsPanel->Model().Entries().size() >= 1 )
180 {
182 return;
183 }
184
185 if( !isTab || !ctrlOnly || !m_tabsPanel )
186 {
187 aEvent.Skip();
188 return;
189 }
190
191 // The appearance panel owns Ctrl+Tab for its layer-preset cycle while focused, so defer to it.
192 if( APPEARANCE_CONTROLS* appearance = GetAppearancePanel() )
193 {
194 for( wxWindow* focus = wxWindow::FindFocus(); focus; focus = focus->GetParent() )
195 {
196 if( focus == appearance )
197 {
198 aEvent.Skip();
199 return;
200 }
201 }
202 }
203
204 AdvanceFootprintTab( !aEvent.ShiftDown() );
205
206 // Do not Skip, so the GTK default Tab focus-traversal does not also run.
207}
208
209
211{
212public:
214 {
215 wxASSERT( aFootprint );
216
217 m_nickname = aFootprint->GetFPID().GetLibNickname().wx_str();
218 m_fpname = aFootprint->GetFPID().GetLibItemName().wx_str();
221 m_keywords = aFootprint->GetKeywords();
222 m_doc = aFootprint->GetLibDescription();
223 m_loaded = true;
224 }
225};
226
227
228void FOOTPRINT_EDIT_FRAME::UpdateLibraryTree( const wxDataViewItem& aTreeItem,
229 FOOTPRINT* aFootprint )
230{
231 wxCHECK( aFootprint, /* void */ );
232
233 BASIC_FOOTPRINT_INFO footprintInfo( aFootprint );
234
235 if( aTreeItem.IsOk() ) // Can be not found in tree if the current footprint is imported
236 // from file therefore not yet in tree.
237 {
238 static_cast<LIB_TREE_NODE_ITEM*>( aTreeItem.GetID() )->Update( &footprintInfo );
239 m_treePane->GetLibTree()->RefreshLibTree();
240 }
241}
242
243
245{
246 LIB_ID oldFPID = aFootprint->GetFPID();
247
248 DIALOG_FOOTPRINT_PROPERTIES_FP_EDITOR dialog( this, aFootprint );
249 dialog.ShowQuasiModal();
250
251 // Update design settings for footprint layers
253
254 // Update library tree and title in case of a name change
255 wxDataViewItem treeItem = m_adapter->FindItem( oldFPID );
256 UpdateLibraryTree( treeItem, aFootprint );
257 UpdateTitle();
258
261}
262
263
265{
266 switch( aItem->Type() )
267 {
270 break;
271
272 case PCB_BARCODE_T:
273 ShowBarcodePropertiesDialog( static_cast<PCB_BARCODE*>( aItem ) );
274 break;
275
276 case PCB_PAD_T:
277 ShowPadPropertiesDialog( static_cast<PAD*>( aItem ) );
278 break;
279
280 case PCB_FOOTPRINT_T:
281 editFootprintProperties( static_cast<FOOTPRINT*>( aItem ) );
282 GetCanvas()->Refresh();
283 break;
284
285 case PCB_FIELD_T:
286 case PCB_TEXT_T:
287 ShowTextPropertiesDialog( static_cast<PCB_TEXT*>( aItem ) );
288 break;
289
290 case PCB_TEXTBOX_T:
291 ShowTextBoxPropertiesDialog( static_cast<PCB_TEXTBOX*>( aItem ) );
292 break;
293
294 case PCB_TABLE_T:
295 {
296 DIALOG_TABLE_PROPERTIES dlg( this, static_cast<PCB_TABLE*>( aItem ) );
297
298 //QuasiModal required for Scintilla auto-complete
299 dlg.ShowQuasiModal();
300 break;
301 }
302
303 case PCB_SHAPE_T :
304 ShowGraphicItemPropertiesDialog( static_cast<PCB_SHAPE*>( aItem ) );
305 break;
306
308 case PCB_DIM_CENTER_T:
309 case PCB_DIM_RADIAL_T:
311 case PCB_DIM_LEADER_T:
312 {
313 DIALOG_DIMENSION_PROPERTIES dlg( this, static_cast<PCB_DIMENSION_BASE*>( aItem ) );
314
315 dlg.ShowModal();
316 break;
317 }
318
319 case PCB_ZONE_T:
320 {
321 ZONE* zone = static_cast<ZONE*>( aItem );
322 bool success = false;
323 ZONE_SETTINGS zoneSettings;
324
325 zoneSettings << *static_cast<ZONE*>( aItem );
326
327 if( zone->GetIsRuleArea() )
328 success = InvokeRuleAreaEditor( this, &zoneSettings ) == wxID_OK;
329 else if( zone->IsOnCopperLayer() )
330 success = InvokeCopperZonesEditor( this, zone, &zoneSettings ) == wxID_OK;
331 else
332 success = InvokeNonCopperZonesEditor( this, &zoneSettings ) == wxID_OK;
333
334 if( success )
335 {
336 BOARD_COMMIT commit( this );
337 commit.Modify( zone );
338 commit.Push( _( "Edit Zone" ) );
339 zoneSettings.ExportSetting( *static_cast<ZONE*>( aItem ) );
340 }
341
342 break;
343 }
344
345 case PCB_GROUP_T:
347 static_cast<EDA_GROUP*>( static_cast<PCB_GROUP*>( aItem ) ) );
348 break;
349
350 case PCB_MARKER_T:
351 m_toolManager->GetTool<FOOTPRINT_EDITOR_CONTROL>()->CrossProbe( static_cast<PCB_MARKER*>( aItem ) );
352 break;
353
354 case PCB_POINT_T:
355 break;
356
357 default:
358 wxFAIL_MSG( wxT( "FOOTPRINT_EDIT_FRAME::OnEditItemRequest: unsupported item type " )
359 + aItem->GetClass() );
360 break;
361 }
362}
363
364
369
370
372{
373 const PCB_LAYER_ID oldLayer = GetActiveLayer();
374
375 if( oldLayer == aLayer )
376 return;
377
379
380 /*
381 * Follow the PCB editor logic for showing/hiding clearance layers: show only for
382 * the active copper layer or a front/back non-copper layer.
383 */
384 const auto getClearanceLayerForActive = []( PCB_LAYER_ID aActiveLayer ) -> std::optional<int>
385 {
386 if( IsCopperLayer( aActiveLayer ) )
387 return CLEARANCE_LAYER_FOR( aActiveLayer );
388
389 return std::nullopt;
390 };
391
392 if( std::optional<int> oldClearanceLayer = getClearanceLayerForActive( oldLayer ) )
393 GetCanvas()->GetView()->SetLayerVisible( *oldClearanceLayer, false );
394
395 if( std::optional<int> newClearanceLayer = getClearanceLayerForActive( aLayer ) )
396 GetCanvas()->GetView()->SetLayerVisible( *newClearanceLayer, true );
397
398 m_appearancePanel->OnLayerChanged();
399
400 m_toolManager->RunAction( PCB_ACTIONS::layerChanged ); // notify other tools
401 GetCanvas()->SetFocus(); // allow capture of hotkeys
402 GetCanvas()->SetHighContrastLayer( aLayer );
403 GetCanvas()->Refresh();
404}
405
406
407bool FOOTPRINT_EDIT_FRAME::OpenProjectFiles( const std::vector<wxString>& aFileSet, int aCtl )
408{
409 if( !Clear_Pcb( true ) )
410 return false; // this command is aborted
411
413 ImportFootprint( aFileSet[ 0 ] );
414
415 if( GetBoard()->GetFirstFootprint() )
417
418 GetScreen()->SetContentModified( false );
419 Zoom_Automatique( false );
420 GetCanvas()->Refresh();
421
422 return true;
423}
424
425
427{
428 const std::string& payload = mail.GetPayload();
429
430 switch( mail.Command() )
431 {
432 case MAIL_FP_EDIT:
433 if( !payload.empty() )
434 {
435 wxFileName fpFileName( payload );
436 wxString libNickname;
437 wxString msg;
438
440 std::optional<LIBRARY_TABLE_ROW*> optRow = adapter->FindRowByURI( fpFileName.GetPath() );
441
442 if( !optRow )
443 {
444 msg.Printf( _( "The current configuration does not include the footprint library '%s'." ),
445 fpFileName.GetPath() );
446 msg += wxS( "\n" ) + _( "Use Manage Footprint Libraries to edit the configuration." );
447 DisplayErrorMessage( this, _( "Library not found in footprint library table." ),
448 msg );
449 break;
450 }
451
452 libNickname = ( *optRow )->Nickname();
453
454 if( !adapter->HasLibrary( libNickname, true ) )
455 {
456 msg.Printf( _( "The footprint library '%s' is not enabled in the current configuration." ),
457 libNickname );
458 msg += wxS( "\n" ) + _( "Use Manage Footprint Libraries to edit the configuration." );
459 DisplayErrorMessage( this, _( "Footprint library not enabled." ), msg );
460 break;
461 }
462
463 LIB_ID fpId( libNickname, fpFileName.GetName() );
464
465 if( m_treePane )
466 {
467 m_treePane->GetLibTree()->SelectLibId( fpId );
468 wxCommandEvent event( EVT_LIBITEM_CHOSEN );
469 wxPostEvent( m_treePane, event );
470 }
471 }
472
473 break;
474
475 case MAIL_RELOAD_LIB:
476 SyncLibraryTree( true );
478 break;
479
480 default:
481 break;
482 }
483}
static TOOL_ACTION groupProperties
Definition actions.h:247
void SetContentModified(bool aModified=true)
Definition base_screen.h:59
BASIC_FOOTPRINT_INFO(FOOTPRINT *aFootprint)
virtual void Push(const wxString &aMessage=wxEmptyString, int aCommitFlags=0) override
Execute the changes.
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
Definition board_item.h:84
FOOTPRINT * GetFirstFootprint() const
Get the first footprint on the board or nullptr.
Definition board.h:532
COLOR4D GetColor(int aLayer) const
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
int ShowModal() override
void ReCreateMenuBar()
Recreate the menu bar.
virtual void ReCreateHToolbar()
virtual void Zoom_Automatique(bool aWarpPointer)
Redraw the screen with best zoom level and the best centering that shows all the page or the board.
KIGFX::VIEW_CONTROLS * GetViewControls() const
Return a pointer to the #VIEW_CONTROLS instance used in the panel.
virtual void Refresh(bool aEraseBackground=true, const wxRect *aRect=nullptr) override
void SetFocus() override
A set of EDA_ITEMs (i.e., without duplicates).
Definition eda_group.h:46
KICAD_T Type() const
Returns the type of object.
Definition eda_item.h:112
void ClearFlags(EDA_ITEM_FLAGS aMask=EDA_ITEM_ALL_FLAGS)
Definition eda_item.h:158
virtual const wxString & GetText() const
Return the string associated with the text object.
Definition eda_text.h:114
Module editor specific tools.
void editFootprintProperties(FOOTPRINT *aFootprint)
Run the Footprint Properties dialog and handle changes made in it.
void UpdateLibraryTree(const wxDataViewItem &treeItem, FOOTPRINT *aFootprint)
Update a single node in the library tree.
void SyncLibraryTree(bool aProgress)
Synchronize the footprint library tree to the current state of the footprint library table.
void UpdateMsgPanel() override
Redraw the message panel.
EDITOR_TABS_PANEL * m_tabsPanel
bool SaveFootprint(FOOTPRINT *aFootprint)
Save in an existing library a given footprint.
void OnTabCharHook(wxKeyEvent &aEvent)
Cycle footprint tabs from the CHAR_HOOK stream, since GTK cannot register WXK_TAB as a menu accelerat...
void LoadFootprintFromLibrary(LIB_ID aFPID)
FOOTPRINT * ImportFootprint(const wxString &aName=wxT(""))
Read a file containing only one footprint.
bool IsContentModified() const override
Get if any footprints or libraries have been modified but not saved.
void UpdateUserInterface()
Update the layer manager and other widgets from the board setup (layer and items visibility,...
wxObjectDataPtr< LIB_TREE_MODEL_ADAPTER > m_adapter
void centerItemIdleHandler(wxIdleEvent &aEvent)
bool Clear_Pcb(bool doAskAboutUnsavedChanges)
Delete all and reinitialize the current board.
Definition initpcb.cpp:108
void KiwayMailIn(KIWAY_MAIL_EVENT &mail) override
Receive #KIWAY_ROUTED_EVENT messages from other players.
void OnEditItemRequest(BOARD_ITEM *aItem) override
Install the corresponding dialog editor for the given item.
void AdvanceFootprintTab(bool aForward)
Advance the active tab forward or backward in MRU order.
void SetActiveLayer(PCB_LAYER_ID aLayer) override
void AddFootprintToBoard(FOOTPRINT *aFootprint) override
Override from PCB_BASE_EDIT_FRAME which adds a footprint to the editor's dummy board,...
bool activeBoardOwnedByTab() const
True when a tab context owns the frame's borrowed board, so the frame must not delete it.
void CloseActiveFootprintTab()
Request closing the active tab, prompting to save if it is modified.
FOOTPRINT_TREE_PANE * m_treePane
void RefreshLibraryTree()
Redisplay the library tree.
bool OpenProjectFiles(const std::vector< wxString > &aFileSet, int aCtl=0) override
Load a KiCad board (.kicad_pcb) from aFileName.
COLOR_SETTINGS * GetColorSettings(bool aForceRefresh=false) const override
Helper to retrieve the current color settings.
wxString m_doc
Footprint description.
wxString m_fpname
Module name.
wxString m_keywords
Footprint keywords.
unsigned m_unique_pad_count
Number of unique pads.
unsigned m_pad_count
Number of pads.
wxString m_nickname
library as known in FP_LIB_TABLE
An interface to the global shared library manager that is schematic-specific and linked to one projec...
wxString GetLibDescription() const
Definition footprint.h:446
unsigned GetPadCount(INCLUDE_NPTH_T aIncludeNPTH=INCLUDE_NPTH_T(INCLUDE_NPTH)) const
Return the number of pads.
PCB_FIELD & Value()
read/write accessors:
Definition footprint.h:865
const LIB_ID & GetFPID() const
Definition footprint.h:429
void SetReference(const wxString &aReference)
Definition footprint.h:835
unsigned GetUniquePadCount(INCLUDE_NPTH_T aIncludeNPTH=INCLUDE_NPTH_T(INCLUDE_NPTH)) const
Return the number of unique non-blank pads.
void SetValue(const wxString &aValue)
Definition footprint.h:856
PCB_FIELD & Reference()
Definition footprint.h:866
wxString GetKeywords() const
Definition footprint.h:449
A color representation with 4 components: red, green, blue, alpha.
Definition color4d.h:105
virtual void SetCrossHairCursorPosition(const VECTOR2D &aPosition, bool aWarpView=true)=0
Move the graphic crosshair cursor to the requested position expressed in world coordinates.
virtual wxString GetClass() const =0
Return the class name.
void SetLayerVisible(int aLayer, bool aVisible=true)
Control the visibility of a particular layer.
Definition view.h:409
Carry a payload from one KIWAY_PLAYER to another within a PROJECT.
Definition kiway_mail.h:38
std::string & GetPayload()
Return the payload, which can be any text but it typically self identifying s-expression.
Definition kiway_mail.h:56
MAIL_T Command()
Returns the MAIL_T associated with this mail.
Definition kiway_mail.h:48
std::optional< LIBRARY_TABLE_ROW * > FindRowByURI(const wxString &aUri, LIBRARY_TABLE_SCOPE aScope=LIBRARY_TABLE_SCOPE::BOTH) const
Like LIBRARY_MANAGER::FindRowByURI but filtered to the LIBRARY_TABLE_TYPE of this adapter.
bool HasLibrary(const wxString &aNickname, bool aCheckEnabled=false) const
Test for the existence of aNickname in the library tables.
A logical library item identifier and consists of various portions much like a URI.
Definition lib_id.h:49
bool IsValid() const
Check if this LID_ID is valid.
Definition lib_id.h:172
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
Node type: LIB_ID.
void Update(LIB_TREE_ITEM *aItem)
Update the node using data from a LIB_ALIAS object.
Definition pad.h:65
static TOOL_ACTION layerChanged
int ShowTextBoxPropertiesDialog(PCB_TEXTBOX *aTextBox)
APPEARANCE_CONTROLS * GetAppearancePanel()
APPEARANCE_CONTROLS * m_appearancePanel
void ShowReferenceImagePropertiesDialog(BOARD_ITEM *aBitmap)
void ShowBarcodePropertiesDialog(PCB_BARCODE *aText)
void ShowGraphicItemPropertiesDialog(PCB_SHAPE *aShape)
void ShowPadPropertiesDialog(PAD *aPad)
virtual void SetActiveLayer(PCB_LAYER_ID aLayer)
FOOTPRINT * LoadFootprint(const LIB_ID &aFootprintId)
Attempt to load aFootprintId from the footprint library table.
PCB_DRAW_PANEL_GAL * GetCanvas() const override
Return a pointer to GAL-based canvas of given EDA draw frame.
virtual PCB_LAYER_ID GetActiveLayer() const
PCB_SCREEN * GetScreen() const override
Return a pointer to a BASE_SCREEN or one of its derivatives.
BOARD * GetBoard() const
virtual void Update3DView(bool aMarkDirty, bool aRefresh, const wxString *aTitle=nullptr)
Update the 3D view, if the viewer is opened by this frame.
Abstract dimension API.
virtual KIGFX::PCB_VIEW * GetView() const override
Return a pointer to the #VIEW instance used in the panel.
virtual void SetHighContrastLayer(int aLayer) override
SetHighContrastLayer(), with some extra smarts for PCB.
A set of BOARD_ITEMs (i.e., without duplicates).
Definition pcb_group.h:53
static FOOTPRINT_LIBRARY_ADAPTER * FootprintLibAdapter(PROJECT *aProject)
TOOL_MANAGER * m_toolManager
wxString wx_str() const
Definition utf8.cpp:45
ZONE_SETTINGS handles zones parameters.
void ExportSetting(ZONE &aTarget, bool aFullExport=true) const
Function ExportSetting copy settings to a given zone.
Handle a list of polygons defining a copper zone.
Definition zone.h:74
bool GetIsRuleArea() const
Accessors to parameters used in Rule Area zones:
Definition zone.h:802
bool IsOnCopperLayer() const override
Definition zone.cpp:578
bool HandleUnsavedChanges(wxWindow *aParent, const wxString &aMessage, const std::function< bool()> &aSaveFunction)
Display a dialog with Save, Cancel and Discard Changes buttons.
Definition confirm.cpp:150
void DisplayErrorMessage(wxWindow *aParent, const wxString &aText, const wxString &aExtraInfo)
Display an error message with aMessage.
Definition confirm.cpp:221
This file is part of the common library.
int InvokeCopperZonesEditor(PCB_BASE_FRAME *aCaller, ZONE *aZone, ZONE_SETTINGS *aSettings, CONVERT_SETTINGS *aConvertSettings)
Function InvokeCopperZonesEditor invokes up a modal dialog window for copper zone editing.
int InvokeNonCopperZonesEditor(PCB_BASE_FRAME *aParent, ZONE_SETTINGS *aSettings, CONVERT_SETTINGS *aConvertSettings)
Function InvokeNonCopperZonesEditor invokes up a modal dialog window for non-copper zone editing.
int InvokeRuleAreaEditor(PCB_BASE_FRAME *aCaller, ZONE_SETTINGS *aZoneSettings, BOARD *aBoard, CONVERT_SETTINGS *aConvertSettings)
Function InvokeRuleAreaEditor invokes up a modal dialog window for copper zone editing.
#define _(s)
@ DO_NOT_INCLUDE_NPTH
Definition footprint.h:74
PROJECT & Prj()
Definition kicad.cpp:669
bool IsCopperLayer(int aLayerId)
Test whether a layer is a copper layer.
Definition layer_ids.h:679
@ LAYER_GRID
Definition layer_ids.h:254
#define CLEARANCE_LAYER_FOR(boardLayer)
Definition layer_ids.h:373
PCB_LAYER_ID
A quick note on layer IDs:
Definition layer_ids.h:60
@ MAIL_FP_EDIT
Definition mail_type.h:57
@ MAIL_RELOAD_LIB
Definition mail_type.h:58
BARCODE class definition.
Class to handle a set of BOARD_ITEMs.
@ PCB_SHAPE_T
class PCB_SHAPE, a segment not on copper layers
Definition typeinfo.h:85
@ PCB_DIM_ORTHOGONAL_T
class PCB_DIM_ORTHOGONAL, a linear dimension constrained to x/y
Definition typeinfo.h:103
@ PCB_DIM_LEADER_T
class PCB_DIM_LEADER, a leader dimension (graphic item)
Definition typeinfo.h:100
@ PCB_DIM_CENTER_T
class PCB_DIM_CENTER, a center point marking (graphic item)
Definition typeinfo.h:101
@ PCB_GROUP_T
class PCB_GROUP, a set of BOARD_ITEMs
Definition typeinfo.h:108
@ PCB_TEXTBOX_T
class PCB_TEXTBOX, wrapped text on a layer
Definition typeinfo.h:90
@ PCB_ZONE_T
class ZONE, a copper pour area
Definition typeinfo.h:105
@ PCB_TEXT_T
class PCB_TEXT, text on a layer
Definition typeinfo.h:89
@ PCB_REFERENCE_IMAGE_T
class PCB_REFERENCE_IMAGE, bitmap on a layer
Definition typeinfo.h:86
@ PCB_FIELD_T
class PCB_FIELD, text associated with a footprint property
Definition typeinfo.h:87
@ PCB_MARKER_T
class PCB_MARKER, a marker used to show something
Definition typeinfo.h:96
@ PCB_BARCODE_T
class PCB_BARCODE, a barcode (graphic item)
Definition typeinfo.h:98
@ PCB_FOOTPRINT_T
class FOOTPRINT, a footprint
Definition typeinfo.h:83
@ PCB_DIM_ALIGNED_T
class PCB_DIM_ALIGNED, a linear dimension (graphic item)
Definition typeinfo.h:99
@ PCB_PAD_T
class PAD, a pad in a footprint
Definition typeinfo.h:84
@ PCB_TABLE_T
class PCB_TABLE, table of PCB_TABLECELLs
Definition typeinfo.h:91
@ PCB_POINT_T
class PCB_POINT, a 0-dimensional point
Definition typeinfo.h:110
@ PCB_DIM_RADIAL_T
class PCB_DIM_RADIAL, a radius or diameter dimension
Definition typeinfo.h:102
VECTOR2< double > VECTOR2D
Definition vector2d.h:686