KiCad PCB EDA Suite
Loading...
Searching...
No Matches
rc_item.h
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, see <https://www.gnu.org/licenses/>.
18 */
19
20#ifndef RC_ITEM_H
21#define RC_ITEM_H
22
23#include <memory>
24#include <vector>
25
26#include <wx/dataview.h>
27#include <units_provider.h>
28#include <kiid.h>
29#include <reporter.h>
30#include <math/vector2d.h>
31
32class MARKER_BASE;
33class EDA_BASE_FRAME;
34class RC_ITEM;
35class EDA_ITEM;
36class EDA_DRAW_FRAME;
37
38namespace RC_JSON
39{
40struct VIOLATION;
41}
42
51{
52public:
53 virtual void SetSeverities( int aSeverities ) = 0;
54
55 virtual int GetSeverities() const = 0;
56
57 virtual int GetCount( int aSeverity = -1 ) const = 0;
58
62 virtual std::shared_ptr<RC_ITEM> GetItem( int aIndex ) const = 0;
63
68 virtual void DeleteItem( int aIndex, bool aDeep ) = 0;
69
70 virtual ~RC_ITEMS_PROVIDER() { }
71};
72
73
80{
81public:
82 typedef std::vector<KIID> KIIDS;
83
85 m_errorCode( 0 ),
86 m_parent( nullptr )
87 {
88 }
89
90 RC_ITEM( const std::shared_ptr<RC_ITEM>& aItem )
91 {
92 m_errorCode = aItem->m_errorCode;
93 m_errorMessage = aItem->m_errorMessage;
94 m_errorTitle = aItem->m_errorTitle;
95 m_settingsKey = aItem->m_settingsKey;
96 m_parent = aItem->m_parent;
97 m_ids = aItem->m_ids;
98 }
99
100 virtual ~RC_ITEM() { }
101
102 void SetErrorMessage( const wxString& aMessage ) { m_errorMessage = aMessage; }
103
104 void SetErrorDetail( const wxString& aMsg ) { SetErrorMessage( GetErrorText( true ) + wxS( " " ) + aMsg ); }
105
106 void SetItems( const KIIDS& aIds ) { m_ids = aIds; }
107
108 void AddItem( EDA_ITEM* aItem );
109
110 void SetItems( const EDA_ITEM* aItem, const EDA_ITEM* bItem = nullptr,
111 const EDA_ITEM* cItem = nullptr, const EDA_ITEM* dItem = nullptr );
112
113 void SetItems( const KIID& aItem, const KIID& bItem = niluuid, const KIID& cItem = niluuid,
114 const KIID& dItem = niluuid )
115 {
116 m_ids.clear();
117
118 m_ids.push_back( aItem );
119 m_ids.push_back( bItem );
120 m_ids.push_back( cItem );
121 m_ids.push_back( dItem );
122 }
123
124 virtual KIID GetMainItemID() const { return m_ids.size() > 0 ? m_ids[0] : niluuid; }
125 virtual KIID GetAuxItemID() const { return m_ids.size() > 1 ? m_ids[1] : niluuid; }
126 virtual KIID GetAuxItem2ID() const { return m_ids.size() > 2 ? m_ids[2] : niluuid; }
127 virtual KIID GetAuxItem3ID() const { return m_ids.size() > 3 ? m_ids[3] : niluuid; }
128
129 std::vector<KIID> GetIDs() const { return m_ids; }
130
131 void SetParent( MARKER_BASE* aMarker ) { m_parent = aMarker; }
132 MARKER_BASE* GetParent() const { return m_parent; }
133
134
140 virtual wxString ShowReport( UNITS_PROVIDER* aUnitsProvider, SEVERITY aSeverity,
141 const std::map<KIID, EDA_ITEM*>& aItemMap ) const;
142
153 virtual void GetJsonViolation( RC_JSON::VIOLATION& aViolation, UNITS_PROVIDER* aUnitsProvider,
154 SEVERITY aSeverity,
155 const std::map<KIID, EDA_ITEM*>& aItemMap ) const;
156
157 int GetErrorCode() const { return m_errorCode; }
158 void SetErrorCode( int aCode ) { m_errorCode = aCode; }
159
164 virtual wxString GetErrorMessage( bool aTranslate ) const;
165
170 wxString GetErrorText( bool aTranslate ) const
171 {
172 if( aTranslate )
173 return wxGetTranslation( m_errorTitle );
174 else
175 return m_errorTitle;
176 }
177
178 wxString GetSettingsKey() const
179 {
180 return m_settingsKey;
181 }
182
183 virtual wxString GetViolatingRuleDesc( bool aTranslate ) const
184 {
185 return wxEmptyString;
186 }
187
188protected:
189 static wxString getSeverityString( SEVERITY aSeverity );
190
200 virtual wxString getItemDescription( EDA_ITEM* aItem, int aIndex,
201 UNITS_PROVIDER* aUnitsProvider ) const;
202
204 wxString m_errorMessage;
205 wxString m_errorTitle;
206 wxString m_settingsKey;
208
210
211};
212
213
215{
216public:
226
227 RC_TREE_NODE( RC_TREE_NODE* aParent, const std::shared_ptr<RC_ITEM>& aRcItem,
228 NODE_TYPE aType ) :
229 m_Type( aType ),
230 m_RcItem( aRcItem ),
231 m_Parent( aParent )
232 {}
233
235 {
236 for( RC_TREE_NODE* child : m_Children )
237 delete child;
238 }
239
240 // We own at least one list of raw pointers. Don't let the compiler fill in copy c'tors that
241 // will only land us in trouble.
242 RC_TREE_NODE( const RC_TREE_NODE& ) = delete;
244
246 std::shared_ptr<RC_ITEM> m_RcItem;
247
248 struct HANDLE
249 {
251 };
252
253 HANDLE* m_Handle = nullptr;
255 std::vector<RC_TREE_NODE*> m_Children;
256};
257
258
259class RC_TREE_MODEL : public wxDataViewModel, public wxEvtHandler
260{
261public:
262 static wxDataViewItem ToItem( RC_TREE_NODE const* aNode )
263 {
264 return aNode && aNode->m_Handle ? wxDataViewItem( aNode->m_Handle ) : wxDataViewItem();
265 }
266
267 static RC_TREE_NODE* ToNode( wxDataViewItem aItem )
268 {
269 auto* handle = static_cast<RC_TREE_NODE::HANDLE*>( aItem.GetID() );
270 return handle ? handle->m_Node : nullptr;
271 }
272
273 const wxDataViewCtrl* GetView() const { return m_view; }
274
275 static KIID ToUUID( wxDataViewItem aItem );
276
277 RC_TREE_MODEL( EDA_DRAW_FRAME* aParentFrame, wxDataViewCtrl* aView );
278
280
281 // We own at least one list of raw pointers. Don't let the compiler fill in copy c'tors that
282 // will only land us in trouble.
283 RC_TREE_MODEL( const RC_TREE_MODEL& ) = delete;
285
286 void Update( std::shared_ptr<RC_ITEMS_PROVIDER> aProvider, int aSeverities );
287
290 void EnableHyperlinks( bool aEnable );
291
292 void ExpandAll();
293
294 void PrevMarker();
295 void NextMarker();
296 void SelectMarker( const MARKER_BASE* aMarker );
297 void CenterMarker( const MARKER_BASE* aMarker );
298
299 bool IsContainer( wxDataViewItem const& aItem ) const override;
300
301 wxDataViewItem GetParent( wxDataViewItem const& aItem ) const override;
302
303 unsigned int GetChildren( wxDataViewItem const& aItem,
304 wxDataViewItemArray& aChildren ) const override;
305
306 // Simple, single-text-column model
307 unsigned int GetColumnCount() const override { return 1; }
308 wxString GetColumnType( unsigned int aCol ) const override { return "string"; }
309 bool HasContainerColumns( wxDataViewItem const& aItem ) const override { return true; }
310
311 bool HasValue( const wxDataViewItem& item, unsigned col ) const override
312 {
313 if( m_tree.empty() )
314 return false;
315 else
316 return wxDataViewModel::HasValue( item, col );
317 }
318
322 void GetValue( wxVariant& aVariant, wxDataViewItem const& aItem,
323 unsigned int aCol ) const override;
324
328 bool SetValue( wxVariant const& aVariant, wxDataViewItem const& aItem,
329 unsigned int aCol ) override
330 {
331 // Editing not supported
332 return false;
333 }
334
339 bool GetAttr( wxDataViewItem const& aItem, unsigned int aCol,
340 wxDataViewItemAttr& aAttr ) const override;
341
342 void ValueChanged( RC_TREE_NODE* aNode );
343
344 void DeleteCurrentItem( bool aDeep );
345
351 void DeleteItems( bool aCurrentOnly, bool aIncludeExclusions, bool aDeep );
352
353protected:
354 RC_TREE_NODE* createNode( RC_TREE_NODE* aParent, const std::shared_ptr<RC_ITEM>& aRcItem,
356 void retireNodeTree( RC_TREE_NODE* aNode );
357 void deleteNodeTree( RC_TREE_NODE* aNode );
358 void rebuildModel( std::shared_ptr<RC_ITEMS_PROVIDER> aProvider, int aSeverities );
359
360 void onViewSize( wxSizeEvent& aEvent );
361
363 wxDataViewCtrl* m_view;
365 bool m_enableHyperlinks = false;
366 wxDataViewColumn* m_hyperlinkColumn = nullptr;
367 std::shared_ptr<RC_ITEMS_PROVIDER> m_rcItemsProvider;
368
369 std::vector<std::unique_ptr<RC_TREE_NODE::HANDLE>> m_handles; // Stable wx item IDs
370 std::vector<RC_TREE_NODE*> m_tree; // I own this
371};
372
373#endif // RC_ITEM_H
The base frame for deriving all KiCad main window classes.
The base class for create windows for drawing purpose.
A base class for most all the KiCad significant classes used in schematics and boards.
Definition eda_item.h:96
Definition kiid.h:44
Marker are mainly used to show a DRC or ERC error or warning.
Definition marker_base.h:45
Provide an abstract interface of a RC_ITEM* list manager.
Definition rc_item.h:51
virtual int GetSeverities() const =0
virtual void SetSeverities(int aSeverities)=0
virtual void DeleteItem(int aIndex, bool aDeep)=0
Remove (and optionally deletes) the indexed item from the list.
virtual ~RC_ITEMS_PROVIDER()
Definition rc_item.h:70
virtual int GetCount(int aSeverity=-1) const =0
virtual std::shared_ptr< RC_ITEM > GetItem(int aIndex) const =0
Retrieve a RC_ITEM by index.
A holder for a rule check item, DRC in Pcbnew or ERC in Eeschema.
Definition rc_item.h:80
wxString m_settingsKey
The key used to describe this type of error in settings.
Definition rc_item.h:206
void SetItems(const KIID &aItem, const KIID &bItem=niluuid, const KIID &cItem=niluuid, const KIID &dItem=niluuid)
Definition rc_item.h:113
int GetErrorCode() const
Definition rc_item.h:157
int m_errorCode
The error code's numeric value.
Definition rc_item.h:203
virtual ~RC_ITEM()
Definition rc_item.h:100
wxString GetErrorText(bool aTranslate) const
Definition rc_item.h:170
virtual void GetJsonViolation(RC_JSON::VIOLATION &aViolation, UNITS_PROVIDER *aUnitsProvider, SEVERITY aSeverity, const std::map< KIID, EDA_ITEM * > &aItemMap) const
Translate this object into an RC_JSON::VIOLATION object.
Definition rc_item.cpp:163
static wxString getSeverityString(SEVERITY aSeverity)
Definition rc_item.cpp:86
virtual wxString GetViolatingRuleDesc(bool aTranslate) const
Definition rc_item.h:183
MARKER_BASE * GetParent() const
Definition rc_item.h:132
std::vector< KIID > KIIDS
Definition rc_item.h:82
void AddItem(EDA_ITEM *aItem)
Definition rc_item.cpp:54
MARKER_BASE * m_parent
The marker this item belongs to, if any.
Definition rc_item.h:207
KIIDS m_ids
Definition rc_item.h:209
virtual KIID GetAuxItem3ID() const
Definition rc_item.h:127
void SetErrorMessage(const wxString &aMessage)
Definition rc_item.h:102
virtual KIID GetAuxItem2ID() const
Definition rc_item.h:126
virtual KIID GetMainItemID() const
Definition rc_item.h:124
virtual KIID GetAuxItemID() const
Definition rc_item.h:125
virtual wxString ShowReport(UNITS_PROVIDER *aUnitsProvider, SEVERITY aSeverity, const std::map< KIID, EDA_ITEM * > &aItemMap) const
Translate this object into a text string suitable for saving to disk in a report.
Definition rc_item.cpp:105
wxString m_errorMessage
A message describing the details of this specific error.
Definition rc_item.h:204
void SetParent(MARKER_BASE *aMarker)
Definition rc_item.h:131
RC_ITEM(const std::shared_ptr< RC_ITEM > &aItem)
Definition rc_item.h:90
void SetErrorCode(int aCode)
Definition rc_item.h:158
void SetErrorDetail(const wxString &aMsg)
Definition rc_item.h:104
wxString GetSettingsKey() const
Definition rc_item.h:178
std::vector< KIID > GetIDs() const
Definition rc_item.h:129
wxString m_errorTitle
The string describing the type of error.
Definition rc_item.h:205
RC_ITEM()
Definition rc_item.h:84
virtual wxString GetErrorMessage(bool aTranslate) const
Definition rc_item.cpp:37
virtual wxString getItemDescription(EDA_ITEM *aItem, int aIndex, UNITS_PROVIDER *aUnitsProvider) const
Resolve the description string used for an affected item in ShowReport and GetJsonViolation.
Definition rc_item.cpp:79
void SetItems(const KIIDS &aIds)
Definition rc_item.h:106
void ExpandAll()
Definition rc_item.cpp:444
wxString GetColumnType(unsigned int aCol) const override
Definition rc_item.h:308
void PrevMarker()
Definition rc_item.cpp:783
int m_severities
Definition rc_item.h:364
void onViewSize(wxSizeEvent &aEvent)
Definition rc_item.cpp:435
wxDataViewColumn * m_hyperlinkColumn
Definition rc_item.h:366
void GetValue(wxVariant &aVariant, wxDataViewItem const &aItem, unsigned int aCol) const override
Called by the wxDataView to fetch an item's value.
Definition rc_item.cpp:488
std::vector< RC_TREE_NODE * > m_tree
Definition rc_item.h:370
unsigned int GetChildren(wxDataViewItem const &aItem, wxDataViewItemArray &aChildren) const override
Definition rc_item.cpp:472
std::vector< std::unique_ptr< RC_TREE_NODE::HANDLE > > m_handles
Definition rc_item.h:369
bool HasContainerColumns(wxDataViewItem const &aItem) const override
Definition rc_item.h:309
bool HasValue(const wxDataViewItem &item, unsigned col) const override
Definition rc_item.h:311
EDA_DRAW_FRAME * m_editFrame
Definition rc_item.h:362
void retireNodeTree(RC_TREE_NODE *aNode)
Definition rc_item.cpp:276
static wxDataViewItem ToItem(RC_TREE_NODE const *aNode)
Definition rc_item.h:262
bool SetValue(wxVariant const &aVariant, wxDataViewItem const &aItem, unsigned int aCol) override
Called by the wxDataView to edit an item's content.
Definition rc_item.h:328
bool m_enableHyperlinks
Definition rc_item.h:365
void SelectMarker(const MARKER_BASE *aMarker)
Definition rc_item.cpp:832
RC_TREE_MODEL(EDA_DRAW_FRAME *aParentFrame, wxDataViewCtrl *aView)
Definition rc_item.cpp:253
void deleteNodeTree(RC_TREE_NODE *aNode)
Definition rc_item.cpp:289
const wxDataViewCtrl * GetView() const
Definition rc_item.h:273
static RC_TREE_NODE * ToNode(wxDataViewItem aItem)
Definition rc_item.h:267
void ValueChanged(RC_TREE_NODE *aNode)
Definition rc_item.cpp:611
void Update(std::shared_ptr< RC_ITEMS_PROVIDER > aProvider, int aSeverities)
Definition rc_item.cpp:413
bool GetAttr(wxDataViewItem const &aItem, unsigned int aCol, wxDataViewItemAttr &aAttr) const override
Called by the wxDataView to fetch an item's formatting.
Definition rc_item.cpp:566
RC_TREE_MODEL & operator=(const RC_TREE_MODEL &)=delete
void DeleteItems(bool aCurrentOnly, bool aIncludeExclusions, bool aDeep)
Delete the current item or all items.
Definition rc_item.cpp:668
RC_TREE_NODE * createNode(RC_TREE_NODE *aParent, const std::shared_ptr< RC_ITEM > &aRcItem, RC_TREE_NODE::NODE_TYPE aType)
Definition rc_item.cpp:262
RC_TREE_MODEL(const RC_TREE_MODEL &)=delete
void DeleteCurrentItem(bool aDeep)
Definition rc_item.cpp:662
unsigned int GetColumnCount() const override
Definition rc_item.h:307
wxDataViewItem GetParent(wxDataViewItem const &aItem) const override
Definition rc_item.cpp:465
void CenterMarker(const MARKER_BASE *aMarker)
Definition rc_item.cpp:847
void EnableHyperlinks(bool aEnable)
Render [label](url) markup as clickable links.
Definition rc_item.cpp:419
static KIID ToUUID(wxDataViewItem aItem)
Definition rc_item.cpp:223
wxDataViewCtrl * m_view
Definition rc_item.h:363
std::shared_ptr< RC_ITEMS_PROVIDER > m_rcItemsProvider
Definition rc_item.h:367
void NextMarker()
Definition rc_item.cpp:804
bool IsContainer(wxDataViewItem const &aItem) const override
Definition rc_item.cpp:451
void rebuildModel(std::shared_ptr< RC_ITEMS_PROVIDER > aProvider, int aSeverities)
Definition rc_item.cpp:308
std::shared_ptr< RC_ITEM > m_RcItem
Definition rc_item.h:246
RC_TREE_NODE * m_Parent
Definition rc_item.h:254
RC_TREE_NODE(RC_TREE_NODE *aParent, const std::shared_ptr< RC_ITEM > &aRcItem, NODE_TYPE aType)
Definition rc_item.h:227
std::vector< RC_TREE_NODE * > m_Children
Definition rc_item.h:255
RC_TREE_NODE(const RC_TREE_NODE &)=delete
HANDLE * m_Handle
Definition rc_item.h:253
RC_TREE_NODE & operator=(const RC_TREE_NODE &)=delete
NODE_TYPE m_Type
Definition rc_item.h:245
KIID niluuid(0)
Contains the json serialization structs for DRC and ERC reports If you are trying to change the outpu...
Definition rc_item.h:39
SEVERITY
RC_TREE_NODE * m_Node
Definition rc_item.h:250