diff --git a/common/dialog_about/AboutDialog_main.cpp b/common/dialog_about/AboutDialog_main.cpp
index c2f6639cc7..7b7eb1f16a 100644
--- a/common/dialog_about/AboutDialog_main.cpp
+++ b/common/dialog_about/AboutDialog_main.cpp
@@ -113,8 +113,10 @@ static void InitKiCadAboutNew( AboutAppInfo& info )
description << wxT( "
" );
description << wxT( "" ) << _( "Description" ) << wxT( " " ); // bold & underlined font for caption
- description << wxT(
- "
The KiCad EDA Suite is a set of open source applications for the creation of electronic schematics and to design printed circuit boards.
" );
+ description << wxT( "" ) <<
+ _(
+ "The KiCad EDA Suite is a set of open source applications for the creation of electronic schematics and to design printed circuit boards." )
+ << wxT( "
" );
description << wxT( "" );
@@ -170,7 +172,7 @@ static void InitKiCadAboutNew( AboutAppInfo& info )
<< HtmlNewline( 4 )
<< _( "The complete KiCad EDA Suite is released under the" ) << HtmlNewline( 2 )
<< HtmlHyperlink( wxT( "http://www.gnu.org/licenses" ),
- _( "GNU General Public License version 2" ) )
+ _( "GNU General Public License (GPL) version 2" ) )
<< wxT( "" );
info.SetLicense( license );
@@ -201,7 +203,8 @@ static void InitKiCadAboutNew( AboutAppInfo& info )
info.AddDeveloper( new Contributor( wxT( "Lorenzo Marcantonio" ), wxT( "lomarcan@tin.it" ) ) );
info.AddDeveloper( new Contributor( wxT( "Marco Serantoni" ), wxT( "marco.serantoni@gmail.com" ) ) );
info.AddDeveloper( new Contributor( wxT( "Marco Mattila" ), wxT( "marcom99@gmail.com" ) ) );
- info.AddDeveloper( new Contributor( wxT( "Rafael Sokolowski" ), wxT( "rafael.sokolowski@web.de" ) ) );
+ info.AddDeveloper( new Contributor( wxT( "Rafael Sokolowski" ),
+ wxT( "rafael.sokolowski@web.de" ) ) );
info.AddDeveloper( new Contributor( wxT( "Rok Markovic" ), wxT( "rok@kanardia.eu" ) ) );
info.AddDeveloper( new Contributor( wxT( "Tim Hanson" ), wxT( "sideskate@gmail.com" ) ) );
info.AddDeveloper( new Contributor( wxT( "Vesa Solonen" ), wxT( "vesa.solonen@hut.fi" ) ) );
diff --git a/pcbnew/dialog_design_rules.cpp b/pcbnew/dialog_design_rules.cpp
index f86982db67..e375d2ec13 100644
--- a/pcbnew/dialog_design_rules.cpp
+++ b/pcbnew/dialog_design_rules.cpp
@@ -1,4 +1,5 @@
/////////////////////////////////////////////////////////////////////////////
+
// Name: dialog_design_rules.cpp
/////////////////////////////////////////////////////////////////////////////
@@ -42,7 +43,7 @@
#include "pcbnew_id.h"
#include "dialog_design_rules.h"
#include "wx/generic/gridctrl.h"
-
+#include "dialog_design_rules_aux_helper_class.h"
// Field Positions on rules grid
enum {
@@ -54,15 +55,62 @@ enum {
GRID_uVIADRILL,
};
-const wxString DIALOG_DESIGN_RULES::wildCard = _("* (Any)");
+const wxString DIALOG_DESIGN_RULES::wildCard = _( "* (Any)" );
// dialog should remember its previously selected tab
-int DIALOG_DESIGN_RULES::s_LastTabSelection = -1;
+int DIALOG_DESIGN_RULES:: s_LastTabSelection = -1;
// dialog should remember its previous screen position and size
-wxPoint DIALOG_DESIGN_RULES::s_LastPos( -1, -1 );
-wxSize DIALOG_DESIGN_RULES::s_LastSize;
+wxPoint DIALOG_DESIGN_RULES:: s_LastPos( -1, -1 );
+wxSize DIALOG_DESIGN_RULES:: s_LastSize;
+// methods for the helper class NETS_LIST_CTRL
+
+/** OnGetItemText (overlaid method)
+ * needed by wxListCtrl with wxLC_VIRTUAL options
+ */
+wxString NETS_LIST_CTRL::OnGetItemText( long item, long column ) const
+{
+ if( column == 0 )
+ {
+ if( item < (long) m_Netnames.GetCount() )
+ return m_Netnames[item];
+ else
+ return wxEmptyString;
+ }
+ else if( item < (long) m_Classnames.GetCount() )
+ return m_Classnames[item];
+
+ return wxEmptyString;
+}
+
+
+/** Function setRowItems
+ * Initialize the net name and the net class name at row aRow
+ * @param aRow = row index (if aRow > number of stored row, empty rows will be created)
+ * @param aNetname = the string to display in row aRow, column 0
+ * @param aNetclassName = the string to display in row aRow, column 1
+ */
+void NETS_LIST_CTRL::setRowItems( unsigned aRow,
+ const wxString& aNetname,
+ const wxString& aNetclassName )
+{
+ // insert blanks if aRow is larger than existing row count
+ unsigned cnt = m_Netnames.GetCount();
+
+ if( cnt <= aRow )
+ m_Netnames.Add( wxEmptyString, aRow - cnt + 1 );
+
+ cnt = m_Classnames.GetCount();
+ if( cnt <= aRow )
+ m_Classnames.Add( wxEmptyString, aRow - cnt + 1 );
+
+ if( (int)aRow <= GetItemCount() )
+ SetItemCount( aRow + 1 );
+
+ m_Netnames[aRow] = aNetname;
+ m_Classnames[aRow] = aNetclassName;
+}
/**
@@ -71,6 +119,7 @@ wxSize DIALOG_DESIGN_RULES::s_LastSize;
* column titles and not on the grid cell requirements, assuming that the grid
* cell width requirements are narrower than the column title requirements.
*/
+
// @todo: maybe move this to common.cpp if it works.
void EnsureGridColumnWidths( wxGrid* aGrid )
{
@@ -79,12 +128,12 @@ void EnsureGridColumnWidths( wxGrid* aGrid )
sDC.SetFont( aGrid->GetLabelFont() );
int colCount = aGrid->GetNumberCols();
- for( int col=0; colGetColLabelValue( col ) + wxT( " " );
- wxSize needed = sDC.GetTextExtent( colText );
+ wxSize needed = sDC.GetTextExtent( colText );
// set the width of this column
aGrid->SetColSize( col, needed.x );
@@ -102,14 +151,14 @@ DIALOG_DESIGN_RULES::DIALOG_DESIGN_RULES( WinEDA_PcbFrame* parent ) :
EnsureGridColumnWidths( m_grid ); // override any column widths set by wxformbuilder.
- wxListItem column0;
- wxListItem column1;
+ wxListItem column0;
+ wxListItem column1;
column0.Clear();
column1.Clear();
- column0.SetMask(wxLIST_MASK_TEXT);
- column1.SetMask(wxLIST_MASK_TEXT);
+ column0.SetMask( wxLIST_MASK_TEXT );
+ column1.SetMask( wxLIST_MASK_TEXT );
column0.SetText( _( "Net" ) );
column1.SetText( _( "Class" ) );
@@ -148,26 +197,31 @@ DIALOG_DESIGN_RULES::DIALOG_DESIGN_RULES( WinEDA_PcbFrame* parent ) :
/* Display on m_MessagesList the current global settings:
* minimal values for tracks, vias, clearance ...
*/
-void DIALOG_DESIGN_RULES::PrintCurrentSettings( )
+void DIALOG_DESIGN_RULES::PrintCurrentSettings()
{
wxString msg, value;
- int internal_units = m_Parent->m_InternalUnits;
+ int internal_units = m_Parent->m_InternalUnits;
- m_MessagesList->AppendToPage(_("Current general settings: ") );
+ m_MessagesList->AppendToPage( _( "Current general settings: " ) );
// Display min values:
- value = ReturnStringFromValue( g_UserUnit, m_BrdSettings->m_TrackMinWidth, internal_units, true );
- msg.Printf(_("Minimum value for tracks width: %s \n"), GetChars( value ) );
- m_MessagesList->AppendToPage(msg);
+ value = ReturnStringFromValue( g_UserUnit,
+ m_BrdSettings->m_TrackMinWidth,
+ internal_units,
+ true );
+ msg.Printf( _( "Minimum value for tracks width: %s \n" ), GetChars( value ) );
+ m_MessagesList->AppendToPage( msg );
- value = ReturnStringFromValue( g_UserUnit, m_BrdSettings->m_ViasMinSize, internal_units, true );
- msg.Printf(_("Minimum value for vias diameter: %s \n"), GetChars( value ) );
- m_MessagesList->AppendToPage(msg);
-
- value = ReturnStringFromValue( g_UserUnit, m_BrdSettings->m_MicroViasMinSize, internal_units, true );
- msg.Printf(_("Minimum value for microvias diameter: %s \n"), GetChars( value ) );
- m_MessagesList->AppendToPage(msg);
+ value = ReturnStringFromValue( g_UserUnit, m_BrdSettings->m_ViasMinSize, internal_units, true );
+ msg.Printf( _( "Minimum value for vias diameter: %s \n" ), GetChars( value ) );
+ m_MessagesList->AppendToPage( msg );
+ value = ReturnStringFromValue( g_UserUnit,
+ m_BrdSettings->m_MicroViasMinSize,
+ internal_units,
+ true );
+ msg.Printf( _( "Minimum value for microvias diameter: %s \n" ), GetChars( value ) );
+ m_MessagesList->AppendToPage( msg );
}
@@ -215,9 +269,10 @@ void DIALOG_DESIGN_RULES::InitDialogRules()
InitializeRulesSelectionBoxes();
InitGlobalRules();
- PrintCurrentSettings( );
+ PrintCurrentSettings();
}
+
/*******************************************/
void DIALOG_DESIGN_RULES::InitGlobalRules()
/*******************************************/
@@ -229,29 +284,33 @@ void DIALOG_DESIGN_RULES::InitGlobalRules()
AddUnitSymbol( *m_TrackMinWidthTitle );
int Internal_Unit = m_Parent->m_InternalUnits;
- PutValueInLocalUnits( *m_SetViasMinSizeCtrl, m_BrdSettings->m_ViasMinSize, Internal_Unit );
- PutValueInLocalUnits( *m_SetViasMinDrillCtrl, m_BrdSettings->m_ViasMinDrill, Internal_Unit );
+ PutValueInLocalUnits( *m_SetViasMinSizeCtrl, m_BrdSettings->m_ViasMinSize, Internal_Unit );
+ PutValueInLocalUnits( *m_SetViasMinDrillCtrl, m_BrdSettings->m_ViasMinDrill, Internal_Unit );
if( m_BrdSettings->m_CurrentViaType != VIA_THROUGH )
m_OptViaType->SetSelection( 1 );
- m_AllowMicroViaCtrl->SetSelection( m_BrdSettings->m_MicroViasAllowed ? 1 : 0);
- PutValueInLocalUnits( *m_SetMicroViasMinSizeCtrl, m_BrdSettings->m_MicroViasMinSize, Internal_Unit );
- PutValueInLocalUnits( *m_SetMicroViasMinDrillCtrl, m_BrdSettings->m_MicroViasMinDrill, Internal_Unit );
+ m_AllowMicroViaCtrl->SetSelection( m_BrdSettings->m_MicroViasAllowed ? 1 : 0 );
+ PutValueInLocalUnits( *m_SetMicroViasMinSizeCtrl,
+ m_BrdSettings->m_MicroViasMinSize,
+ Internal_Unit );
+ PutValueInLocalUnits( *m_SetMicroViasMinDrillCtrl,
+ m_BrdSettings->m_MicroViasMinDrill,
+ Internal_Unit );
- PutValueInLocalUnits( *m_SetTrackMinWidthCtrl, m_BrdSettings->m_TrackMinWidth, Internal_Unit );
+ PutValueInLocalUnits( *m_SetTrackMinWidthCtrl, m_BrdSettings->m_TrackMinWidth, Internal_Unit );
// Initialize Vias and Tracks sizes lists.
// note we display only extra values, never the current netclass value.
// (the first value in histories list)
m_TracksWidthList = m_Parent->GetBoard()->m_TrackWidthList;
- m_TracksWidthList.erase( m_TracksWidthList.begin() ); // remove the netclass value
+ m_TracksWidthList.erase( m_TracksWidthList.begin() ); // remove the netclass value
m_ViasDimensionsList = m_Parent->GetBoard()->m_ViasDimensionsList;
m_ViasDimensionsList.erase( m_ViasDimensionsList.begin() ); // remove the netclass value
InitDimensionsLists();
-
}
+
/***************************************************/
void DIALOG_DESIGN_RULES::InitDimensionsLists()
/***************************************************/
@@ -271,12 +330,12 @@ void DIALOG_DESIGN_RULES::InitDimensionsLists()
for( unsigned ii = 0; ii < m_ViasDimensionsList.size(); ii++ )
{
msg = ReturnStringFromValue( g_UserUnit, m_ViasDimensionsList[ii].m_Diameter,
- Internal_Unit, false );
+ Internal_Unit, false );
m_gridViaSizeList->SetCellValue( ii, 0, msg );
if( m_ViasDimensionsList[ii].m_Drill > 0 )
{
msg = ReturnStringFromValue( g_UserUnit, m_ViasDimensionsList[ii].m_Drill,
- Internal_Unit, false );
+ Internal_Unit, false );
m_gridViaSizeList->SetCellValue( ii, 1, msg );
}
}
@@ -286,6 +345,7 @@ void DIALOG_DESIGN_RULES::InitDimensionsLists()
m_gridTrackWidthList->SetColumnWidth( 0, wxLIST_AUTOSIZE );
}
+
// Sort comparison function (helper for makePointers() )
static bool sortByClassThenName( NETCUP* a, NETCUP* b )
{
@@ -303,6 +363,7 @@ static bool sortByClassThenName( NETCUP* a, NETCUP* b )
return false;
}
+
void DIALOG_DESIGN_RULES::makePointers( PNETCUPS* aList, const wxString& aNetClassName )
{
aList->clear();
@@ -331,38 +392,16 @@ void DIALOG_DESIGN_RULES::makePointers( PNETCUPS* aList, const wxString& aNetCla
}
-void DIALOG_DESIGN_RULES::setRowItem( wxListCtrl* aListCtrl, int aRow, NETCUP* aNetAndClass )
-{
- wxASSERT( aRow >= 0 );
-
- // insert blanks if aRow is larger than existing count
- while( aRow >= aListCtrl->GetItemCount() )
- {
- long ndx = aListCtrl->InsertItem( aListCtrl->GetItemCount(), wxEmptyString );
-
- wxASSERT( ndx >= 0 );
-
- aListCtrl->SetItem( ndx, 1, wxEmptyString );
- }
-
- aListCtrl->SetItem( aRow, 0, aNetAndClass->net );
- aListCtrl->SetItem( aRow, 1, aNetAndClass->clazz );
-
- // recompute the column widths here, after setting texts
- aListCtrl->SetColumnWidth( 0, wxLIST_AUTOSIZE );
- aListCtrl->SetColumnWidth( 1, wxLIST_AUTOSIZE );
-}
-
-
/**
* Function FillListBoxWithNetNames
* populates aListCtrl with net names and class names from m_AllNets in a two column display.
*/
-void DIALOG_DESIGN_RULES::FillListBoxWithNetNames( wxListCtrl* aListCtrl, const wxString& aNetClass )
+void DIALOG_DESIGN_RULES::FillListBoxWithNetNames( NETS_LIST_CTRL* aListCtrl,
+ const wxString& aNetClass )
{
- aListCtrl->DeleteAllItems();
+ aListCtrl->ClearList();
- PNETCUPS ptrList;
+ PNETCUPS ptrList;
// get a subset of m_AllNets in pointer form, sorted as desired.
makePointers( &ptrList, aNetClass );
@@ -371,8 +410,9 @@ void DIALOG_DESIGN_RULES::FillListBoxWithNetNames( wxListCtrl* aListCtrl, const
int r = 0;
for( PNETCUPS::iterator i = ptrList.begin(); i!=ptrList.end(); ++i, ++r )
{
- printf("[%d]: %s %s\n", r, CONV_TO_UTF8( (*i)->net ), CONV_TO_UTF8( (*i)->clazz ) );
+ printf( "[%d]: %s %s\n", r, CONV_TO_UTF8( (*i)->net ), CONV_TO_UTF8( (*i)->clazz ) );
}
+
#endif
// to speed up inserting we hide the control temporarily
@@ -381,9 +421,13 @@ void DIALOG_DESIGN_RULES::FillListBoxWithNetNames( wxListCtrl* aListCtrl, const
int row = 0;
for( PNETCUPS::iterator i = ptrList.begin(); i!=ptrList.end(); ++i, ++row )
{
- setRowItem( aListCtrl, row, *i );
+ aListCtrl->setRowItems( row, (*i)->net, (*i)->clazz );
}
+ // recompute the column widths here, after setting texts
+ aListCtrl->SetColumnWidth( 0, wxLIST_AUTOSIZE );
+ aListCtrl->SetColumnWidth( 1, wxLIST_AUTOSIZE );
+
aListCtrl->Show();
}
@@ -444,6 +488,7 @@ static void class2gridRow( wxGrid* grid, int row, NETCLASS* nc, int units )
grid->SetCellValue( row, GRID_uVIADRILL, msg );
}
+
/** Function InitRulesList()
* Fill the grid showing current rules with values
*/
@@ -452,9 +497,9 @@ void DIALOG_DESIGN_RULES::InitRulesList()
NETCLASSES& netclasses = m_Pcb->m_NetClasses;
// the +1 is for the Default NETCLASS.
- if( netclasses.GetCount()+1 > (unsigned) m_grid->GetNumberRows() )
+ if( netclasses.GetCount() + 1 > (unsigned) m_grid->GetNumberRows() )
{
- m_grid->AppendRows( netclasses.GetCount()+1 - m_grid->GetNumberRows() );
+ m_grid->AppendRows( netclasses.GetCount() + 1 - m_grid->GetNumberRows() );
}
// enter the Default NETCLASS.
@@ -462,7 +507,7 @@ void DIALOG_DESIGN_RULES::InitRulesList()
// enter others netclasses
int row = 1;
- for( NETCLASSES::iterator i=netclasses.begin(); i!=netclasses.end(); ++i, ++row )
+ for( NETCLASSES::iterator i = netclasses.begin(); i!=netclasses.end(); ++i, ++row )
{
NETCLASS* netclass = i->second;
@@ -473,15 +518,15 @@ void DIALOG_DESIGN_RULES::InitRulesList()
static void gridRow2class( wxGrid* grid, int row, NETCLASS* nc, int units )
{
-#define MYCELL(col) \
+#define MYCELL( col ) \
ReturnValueFromString( g_UserUnit, grid->GetCellValue( row, col ), units )
- nc->SetClearance( MYCELL( GRID_CLEARANCE ) );
- nc->SetTrackWidth( MYCELL( GRID_TRACKSIZE ) );
- nc->SetViaDiameter( MYCELL( GRID_VIASIZE ) );
- nc->SetViaDrill( MYCELL( GRID_VIADRILL ) );
+ nc->SetClearance( MYCELL( GRID_CLEARANCE ) );
+ nc->SetTrackWidth( MYCELL( GRID_TRACKSIZE ) );
+ nc->SetViaDiameter( MYCELL( GRID_VIASIZE ) );
+ nc->SetViaDrill( MYCELL( GRID_VIADRILL ) );
nc->SetuViaDiameter( MYCELL( GRID_uVIASIZE ) );
- nc->SetuViaDrill( MYCELL( GRID_uVIADRILL ) );
+ nc->SetuViaDrill( MYCELL( GRID_uVIADRILL ) );
}
@@ -507,8 +552,8 @@ void DIALOG_DESIGN_RULES::CopyRulesListToBoard()
// this netclass cannot be added because an other netclass with the same name exists
// Should not occur because OnAddNetclassClick() tests for existing NetClass names
wxString msg;
- msg.Printf( wxT("CopyRulesListToBoard(): The NetClass \"%s\" already exists. Skip"),
- GetChars( m_grid->GetRowLabelValue( row ) ) );
+ msg.Printf( wxT( "CopyRulesListToBoard(): The NetClass \"%s\" already exists. Skip" ),
+ GetChars( m_grid->GetRowLabelValue( row ) ) );
wxMessageBox( msg );
delete nc;
continue;
@@ -528,35 +573,37 @@ void DIALOG_DESIGN_RULES::CopyRulesListToBoard()
m_Pcb->SynchronizeNetsAndNetClasses();
}
+
/*************************************************/
void DIALOG_DESIGN_RULES::CopyGlobalRulesToBoard()
/*************************************************/
{
- m_BrdSettings->m_CurrentViaType = VIA_THROUGH;
+ m_BrdSettings->m_CurrentViaType = VIA_THROUGH;
if( m_OptViaType->GetSelection() > 0 )
- m_BrdSettings->m_CurrentViaType = VIA_BLIND_BURIED;
+ m_BrdSettings->m_CurrentViaType = VIA_BLIND_BURIED;
// Update vias minimum values for DRC
- m_BrdSettings->m_ViasMinSize =
+ m_BrdSettings->m_ViasMinSize =
ReturnValueFromTextCtrl( *m_SetViasMinSizeCtrl, m_Parent->m_InternalUnits );
- m_BrdSettings->m_ViasMinDrill =
+ m_BrdSettings->m_ViasMinDrill =
ReturnValueFromTextCtrl( *m_SetViasMinDrillCtrl, m_Parent->m_InternalUnits );
- m_BrdSettings->m_MicroViasAllowed = m_AllowMicroViaCtrl->GetSelection() == 1;
+ m_BrdSettings->m_MicroViasAllowed = m_AllowMicroViaCtrl->GetSelection() == 1;
// Update microvias minimum values for DRC
- m_BrdSettings->m_MicroViasMinSize =
+ m_BrdSettings->m_MicroViasMinSize =
ReturnValueFromTextCtrl( *m_SetMicroViasMinSizeCtrl, m_Parent->m_InternalUnits );
- m_BrdSettings->m_MicroViasMinDrill =
+ m_BrdSettings->m_MicroViasMinDrill =
ReturnValueFromTextCtrl( *m_SetMicroViasMinDrillCtrl, m_Parent->m_InternalUnits );
// Update tracks minimum values for DRC
- m_BrdSettings->m_TrackMinWidth =
+ m_BrdSettings->m_TrackMinWidth =
ReturnValueFromTextCtrl( *m_SetTrackMinWidthCtrl, m_Parent->m_InternalUnits );
}
+
/*******************************************************************/
-void DIALOG_DESIGN_RULES::CopyDimensionsListsToBoard( )
+void DIALOG_DESIGN_RULES::CopyDimensionsListsToBoard()
/*******************************************************************/
{
wxString msg;
@@ -568,9 +615,10 @@ void DIALOG_DESIGN_RULES::CopyDimensionsListsToBoard( )
msg = m_gridTrackWidthList->GetCellValue( row, 0 );
if( msg.IsEmpty() )
continue;
- int value = ReturnValueFromString( g_UserUnit, msg, m_Parent->m_InternalUnits );
- m_TracksWidthList.push_back( value);
+ int value = ReturnValueFromString( g_UserUnit, msg, m_Parent->m_InternalUnits );
+ m_TracksWidthList.push_back( value );
}
+
// Sort new list by by increasing value
sort( m_TracksWidthList.begin(), m_TracksWidthList.end() );
@@ -581,23 +629,24 @@ void DIALOG_DESIGN_RULES::CopyDimensionsListsToBoard( )
msg = m_gridViaSizeList->GetCellValue( row, 0 );
if( msg.IsEmpty() )
continue;
- int value = ReturnValueFromString( g_UserUnit, msg, m_Parent->m_InternalUnits );
+ int value = ReturnValueFromString( g_UserUnit, msg, m_Parent->m_InternalUnits );
VIA_DIMENSION via_dim;
via_dim.m_Diameter = value;
msg = m_gridViaSizeList->GetCellValue( row, 1 );
- if( ! msg.IsEmpty() )
+ if( !msg.IsEmpty() )
{
value = ReturnValueFromString( g_UserUnit, msg, m_Parent->m_InternalUnits );
via_dim.m_Drill = value;
}
- m_ViasDimensionsList.push_back( via_dim);
+ m_ViasDimensionsList.push_back( via_dim );
}
+
// Sort new list by by increasing value
sort( m_ViasDimensionsList.begin(), m_ViasDimensionsList.end() );
std::vector * tlist = &m_Parent->GetBoard()->m_TrackWidthList;
- tlist->erase( tlist->begin() + 1, tlist->end() ); // Remove old "custom" sizes
- tlist->insert( tlist->end(), m_TracksWidthList.begin(), m_TracksWidthList.end() ); //Add new "custom" sizes
+ tlist->erase( tlist->begin() + 1, tlist->end() ); // Remove old "custom" sizes
+ tlist->insert( tlist->end(), m_TracksWidthList.begin(), m_TracksWidthList.end() ); //Add new "custom" sizes
// Reinitialize m_ViaSizeList
std::vector * vialist = &m_Parent->GetBoard()->m_ViasDimensionsList;
@@ -636,7 +685,7 @@ void DIALOG_DESIGN_RULES::OnOkButtonClick( wxCommandEvent& event )
CopyRulesListToBoard();
CopyGlobalRulesToBoard();
- CopyDimensionsListsToBoard( );
+ CopyDimensionsListsToBoard();
// Save the dialog's position before finishing
s_LastPos = GetPosition();
@@ -654,13 +703,14 @@ void DIALOG_DESIGN_RULES::OnOkButtonClick( wxCommandEvent& event )
void DIALOG_DESIGN_RULES::OnAddNetclassClick( wxCommandEvent& event )
/**************************************************************************/
{
- wxString class_name;
+ wxString class_name;
+
+ wxTextEntryDialog dlg( this, _( "New Net Class Name:" ), wxEmptyString, class_name );
- wxTextEntryDialog dlg( this, _( "New Net Class Name:" ), wxEmptyString, class_name );
if( dlg.ShowModal() != wxID_OK )
return; // cancelled by user
- class_name = dlg.GetValue( );
+ class_name = dlg.GetValue();
class_name.Trim( true );
class_name.Trim( false );
if( class_name.IsEmpty() )
@@ -695,25 +745,31 @@ void DIALOG_DESIGN_RULES::OnAddNetclassClick( wxCommandEvent& event )
InitializeRulesSelectionBoxes();
}
+
// Sort function for wxArrayInt. Items (ints) are sorted by decreasing value
// used in DIALOG_DESIGN_RULES::OnRemoveNetclassClick
-int sort_int(int *first, int *second)
+int sort_int( int* first, int* second )
{
- return * second - *first;
+ return *second - *first;
}
+
+
/**************************************************************************/
void DIALOG_DESIGN_RULES::OnRemoveNetclassClick( wxCommandEvent& event )
/**************************************************************************/
{
wxArrayInt select = m_grid->GetSelectedRows();
+
// Sort selection by decreasing index order:
- select.Sort(sort_int);
+ select.Sort( sort_int );
bool reinit = false;
+
// rows labels are not removed when deleting rows: they are not deleted.
// So we must store them, remove correponding labels and reinit them
wxArrayString labels;
for( int ii = 0; ii < m_grid->GetNumberRows(); ii++ )
- labels.Add(m_grid->GetRowLabelValue(ii));
+ labels.Add( m_grid->GetRowLabelValue( ii ) );
+
// Delete rows from last to first (this is the order wxArrayInt select after sorting) )
// This order is Ok when removing rows
for( unsigned ii = 0; ii < select.GetCount(); ii++ )
@@ -723,25 +779,27 @@ void DIALOG_DESIGN_RULES::OnRemoveNetclassClick( wxCommandEvent& event )
{
wxString classname = m_grid->GetRowLabelValue( grid_row );
m_grid->DeleteRows( grid_row );
- labels.RemoveAt(grid_row); // Remove corresponding row label
+ labels.RemoveAt( grid_row ); // Remove corresponding row label
reinit = true;
// reset the net class to default for members of the removed class
swapNetClass( classname, NETCLASS::Default );
}
else
- wxMessageBox(_("The defaut Netclass cannot be removed") );
+ wxMessageBox( _( "The defaut Netclass cannot be removed" ) );
}
+
if( reinit )
{
// Reinit labels :
for( unsigned ii = 1; ii < labels.GetCount(); ii++ )
- m_grid->SetRowLabelValue(ii, labels[ii]);
+ m_grid->SetRowLabelValue( ii, labels[ii] );
InitializeRulesSelectionBoxes();
}
}
+
/*
* Called on "Move Up" button click
* the selected(s) rules are moved up
@@ -754,26 +812,27 @@ void DIALOG_DESIGN_RULES::OnMoveUpSelectedNetClass( wxCommandEvent& event )
return;
wxArrayInt select = m_grid->GetSelectedRows();
- bool reinit = false;
+ bool reinit = false;
for( unsigned irow = 0; irow < select.GetCount(); irow++ )
{
int ii = select[irow];
- if( ii < 2 ) // The default netclass *must* be the first netclass
+ if( ii < 2 ) // The default netclass *must* be the first netclass
continue; // so we cannot move up line 0 and 1
// Swap the rule and the previous rule
wxString curr_value, previous_value;
for( int icol = 0; icol < m_grid->GetNumberCols(); icol++ )
{
- reinit = true;
- curr_value = m_grid->GetCellValue( ii, icol );
- previous_value = m_grid->GetCellValue( ii-1, icol );
+ reinit = true;
+ curr_value = m_grid->GetCellValue( ii, icol );
+ previous_value = m_grid->GetCellValue( ii - 1, icol );
m_grid->SetCellValue( ii, icol, previous_value );
- m_grid->SetCellValue( ii-1, icol, curr_value );
+ m_grid->SetCellValue( ii - 1, icol, curr_value );
}
- curr_value = m_grid->GetRowLabelValue( ii );
- previous_value = m_grid->GetRowLabelValue( ii-1 );
- m_grid->SetRowLabelValue(ii, previous_value );
- m_grid->SetRowLabelValue(ii-1, curr_value );
+
+ curr_value = m_grid->GetRowLabelValue( ii );
+ previous_value = m_grid->GetRowLabelValue( ii - 1 );
+ m_grid->SetRowLabelValue( ii, previous_value );
+ m_grid->SetRowLabelValue( ii - 1, curr_value );
}
if( reinit )
@@ -819,11 +878,12 @@ void DIALOG_DESIGN_RULES::OnRightCBSelection( wxCommandEvent& event )
}
-void DIALOG_DESIGN_RULES::moveSelectedItems( wxListCtrl* src, const wxString& newClassName )
+void DIALOG_DESIGN_RULES::moveSelectedItems( NETS_LIST_CTRL* src, const wxString& newClassName )
{
- wxListItem item;
- wxString netName;
- item.m_mask |= wxLIST_MASK_TEXT ; // Validate the member m_text of the wxListItem item
+ wxListItem item;
+ wxString netName;
+
+ item.m_mask |= wxLIST_MASK_TEXT; // Validate the member m_text of the wxListItem item
for( int row = 0; row < src->GetItemCount(); ++row )
{
@@ -851,6 +911,7 @@ void DIALOG_DESIGN_RULES::OnRightToLeftCopyButton( wxCommandEvent& event )
FillListBoxWithNetNames( m_rightListCtrl, m_rightClassChoice->GetStringSelection() );
}
+
void DIALOG_DESIGN_RULES::OnLeftToRightCopyButton( wxCommandEvent& event )
{
wxString newClassName = m_rightClassChoice->GetStringSelection();
@@ -904,53 +965,58 @@ bool DIALOG_DESIGN_RULES::TestDataValidity()
{
bool result = true;
- m_MessagesList->SetPage(wxEmptyString); // Clear message list
+ m_MessagesList->SetPage( wxEmptyString ); // Clear message list
- wxString msg;
+ wxString msg;
- int minViaDia = ReturnValueFromTextCtrl( *m_SetViasMinSizeCtrl, m_Parent->m_InternalUnits );
- int minViaDrill = ReturnValueFromTextCtrl( *m_SetViasMinDrillCtrl, m_Parent->m_InternalUnits );
- int minUViaDia = ReturnValueFromTextCtrl( *m_SetMicroViasMinSizeCtrl, m_Parent->m_InternalUnits );
- int minUViaDrill = ReturnValueFromTextCtrl( *m_SetMicroViasMinDrillCtrl, m_Parent->m_InternalUnits );
- int minTrackWidth = ReturnValueFromTextCtrl( *m_SetTrackMinWidthCtrl, m_Parent->m_InternalUnits );
+ int minViaDia = ReturnValueFromTextCtrl( *m_SetViasMinSizeCtrl,
+ m_Parent->m_InternalUnits );
+ int minViaDrill = ReturnValueFromTextCtrl( *m_SetViasMinDrillCtrl,
+ m_Parent->m_InternalUnits );
+ int minUViaDia = ReturnValueFromTextCtrl( *m_SetMicroViasMinSizeCtrl,
+ m_Parent->m_InternalUnits );
+ int minUViaDrill = ReturnValueFromTextCtrl( *m_SetMicroViasMinDrillCtrl,
+ m_Parent->m_InternalUnits );
+ int minTrackWidth = ReturnValueFromTextCtrl( *m_SetTrackMinWidthCtrl,
+ m_Parent->m_InternalUnits );
for( int row = 0; row < m_grid->GetNumberRows(); row++ )
{
int tracksize = ReturnValueFromString( g_UserUnit,
- m_grid->GetCellValue( row, GRID_TRACKSIZE ),
- m_Parent->m_InternalUnits );
+ m_grid->GetCellValue( row, GRID_TRACKSIZE ),
+ m_Parent->m_InternalUnits );
if( tracksize < minTrackWidth )
{
result = false;
msg.Printf( _( "%s: Track Size < Min Track Size " ),
- GetChars( m_grid->GetRowLabelValue(row)) );
+ GetChars( m_grid->GetRowLabelValue( row ) ) );
m_MessagesList->AppendToPage( msg );
}
// Test vias
int viadia = ReturnValueFromString( g_UserUnit,
- m_grid->GetCellValue( row, GRID_VIASIZE ),
- m_Parent->m_InternalUnits );
+ m_grid->GetCellValue( row, GRID_VIASIZE ),
+ m_Parent->m_InternalUnits );
if( viadia < minViaDia )
{
result = false;
msg.Printf( _( "%s: Via Diameter < Minimun Via Diameter " ),
- GetChars( m_grid->GetRowLabelValue(row)) );
+ GetChars( m_grid->GetRowLabelValue( row ) ) );
m_MessagesList->AppendToPage( msg );
}
int viadrill = ReturnValueFromString( g_UserUnit,
- m_grid->GetCellValue( row, GRID_VIADRILL ),
- m_Parent->m_InternalUnits );
+ m_grid->GetCellValue( row, GRID_VIADRILL ),
+ m_Parent->m_InternalUnits );
if( viadrill >= viadia )
{
result = false;
msg.Printf( _( "%s: Via Drill ≥ Via Dia " ),
- GetChars( m_grid->GetRowLabelValue(row)) );
+ GetChars( m_grid->GetRowLabelValue( row ) ) );
m_MessagesList->AppendToPage( msg );
}
@@ -959,33 +1025,33 @@ bool DIALOG_DESIGN_RULES::TestDataValidity()
{
result = false;
msg.Printf( _( "%s: Via Drill < Min Via Drill " ),
- GetChars( m_grid->GetRowLabelValue(row)) );
+ GetChars( m_grid->GetRowLabelValue( row ) ) );
m_MessagesList->AppendToPage( msg );
}
// Test Micro vias
int muviadia = ReturnValueFromString( g_UserUnit,
- m_grid->GetCellValue( row, GRID_uVIASIZE ),
- m_Parent->m_InternalUnits );
+ m_grid->GetCellValue( row, GRID_uVIASIZE ),
+ m_Parent->m_InternalUnits );
if( muviadia < minUViaDia )
{
result = false;
msg.Printf( _( "%s: MicroVia Diameter < MicroVia Min Diameter " ),
- GetChars( m_grid->GetRowLabelValue(row)) );
+ GetChars( m_grid->GetRowLabelValue( row ) ) );
m_MessagesList->AppendToPage( msg );
}
int muviadrill = ReturnValueFromString( g_UserUnit,
- m_grid->GetCellValue( row, GRID_uVIADRILL ),
- m_Parent->m_InternalUnits );
+ m_grid->GetCellValue( row, GRID_uVIADRILL ),
+ m_Parent->m_InternalUnits );
if( muviadrill >= muviadia )
{
result = false;
msg.Printf( _( "%s: MicroVia Drill ≥ MicroVia Dia " ),
- GetChars( m_grid->GetRowLabelValue(row)) );
+ GetChars( m_grid->GetRowLabelValue( row ) ) );
m_MessagesList->AppendToPage( msg );
}
@@ -994,7 +1060,7 @@ bool DIALOG_DESIGN_RULES::TestDataValidity()
{
result = false;
msg.Printf( _( "%s: MicroVia Drill < MicroVia Min Drill " ),
- GetChars( m_grid->GetRowLabelValue(row)) );
+ GetChars( m_grid->GetRowLabelValue( row ) ) );
m_MessagesList->AppendToPage( msg );
}
@@ -1003,18 +1069,18 @@ bool DIALOG_DESIGN_RULES::TestDataValidity()
// Test list of values for specific vias and tracks
for( int row = 1; row < m_gridTrackWidthList->GetNumberRows(); ++row )
{
- wxString tvalue = m_gridTrackWidthList->GetCellValue(row, 0);
+ wxString tvalue = m_gridTrackWidthList->GetCellValue( row, 0 );
if( tvalue.IsEmpty() )
continue;
int tracksize = ReturnValueFromString( g_UserUnit,
- tvalue,
- m_Parent->m_InternalUnits );
+ tvalue,
+ m_Parent->m_InternalUnits );
if( tracksize < minTrackWidth )
{
result = false;
msg.Printf( _( "Extra Track %d Size %s < Min Track Size " ),
- row+1, GetChars( tvalue ) );
+ row + 1, GetChars( tvalue ) );
m_MessagesList->AppendToPage( msg );
}
@@ -1022,7 +1088,7 @@ bool DIALOG_DESIGN_RULES::TestDataValidity()
{
result = false;
msg.Printf( _( "Extra Track %d Size %s > 1 inch! " ),
- row+1, GetChars( tvalue ) );
+ row + 1, GetChars( tvalue ) );
m_MessagesList->AppendToPage( msg );
}
@@ -1030,18 +1096,18 @@ bool DIALOG_DESIGN_RULES::TestDataValidity()
for( int row = 1; row < m_gridViaSizeList->GetNumberRows(); ++row )
{
- wxString tvalue = m_gridViaSizeList->GetCellValue(row, 0);
+ wxString tvalue = m_gridViaSizeList->GetCellValue( row, 0 );
if( tvalue.IsEmpty() )
continue;
int viadia = ReturnValueFromString( g_UserUnit,
- tvalue,
- m_Parent->m_InternalUnits );
+ tvalue,
+ m_Parent->m_InternalUnits );
if( viadia < minViaDia )
{
result = false;
msg.Printf( _( "Extra Via %d Size %s < Min Via Size " ),
- row+1, GetChars( tvalue ) );
+ row + 1, GetChars( tvalue ) );
m_MessagesList->AppendToPage( msg );
}
@@ -1049,7 +1115,7 @@ bool DIALOG_DESIGN_RULES::TestDataValidity()
{
result = false;
msg.Printf( _( "Extra Via %d Size %s > 1 inch! " ),
- row+1, GetChars( tvalue ) );
+ row + 1, GetChars( tvalue ) );
m_MessagesList->AppendToPage( msg );
}
@@ -1057,4 +1123,3 @@ bool DIALOG_DESIGN_RULES::TestDataValidity()
return result;
}
-
diff --git a/pcbnew/dialog_design_rules.h b/pcbnew/dialog_design_rules.h
index 9cc6f30566..178483473b 100644
--- a/pcbnew/dialog_design_rules.h
+++ b/pcbnew/dialog_design_rules.h
@@ -76,7 +76,7 @@ private:
void CopyGlobalRulesToBoard();
void CopyDimensionsListsToBoard( );
void SetRoutableLayerStatus();
- void FillListBoxWithNetNames( wxListCtrl* aListCtrl, const wxString& aNetClass );
+ void FillListBoxWithNetNames( NETS_LIST_CTRL* aListCtrl, const wxString& aNetClass );
void PrintCurrentSettings( );
/**
@@ -96,9 +96,7 @@ private:
void setNetClass( const wxString& aNetName, const wxString& aClassName );
- static void setRowItem( wxListCtrl* aListCtrl, int aRow, NETCUP* aNetAndClass );
-
- void moveSelectedItems( wxListCtrl* src, const wxString& newClassName );
+ void moveSelectedItems( NETS_LIST_CTRL* src, const wxString& newClassName );
public:
diff --git a/pcbnew/dialog_design_rules_aux_helper_class.h b/pcbnew/dialog_design_rules_aux_helper_class.h
new file mode 100644
index 0000000000..8f214299b1
--- /dev/null
+++ b/pcbnew/dialog_design_rules_aux_helper_class.h
@@ -0,0 +1,46 @@
+///////////////////////////////////////////////////////////////////////////////
+/// Class DIALOG_DESIGN_RULES
+///////////////////////////////////////////////////////////////////////////////
+
+#ifndef __dialog_design_rules_aux_helper_class_h_
+#define __dialog_design_rules_aux_helper_class_h_
+
+#include
+
+/* helper class to display lists of nets and associated netclasses
+ * used in dialog design rules.
+ * It s needed because the 2 wxListCtlr used to display lists of nets
+ * use the wxLC_VIRTUAL option.
+ * The virtual wxString OnGetItemText(long item, long column) const method
+ * must be overlaid.
+ */
+class NETS_LIST_CTRL: public wxListCtrl
+{
+private:
+ wxArrayString m_Netnames; ///< an array to store the list of nets (column 0)
+ wxArrayString m_Classnames; ///< an array to store the list of netclasse (column 1)
+public:
+ NETS_LIST_CTRL(wxWindow* parent, wxWindowID id,
+ const wxPoint& pos = wxDefaultPosition,
+ const wxSize& size = wxDefaultSize,
+ long style = wxLC_ICON):
+ wxListCtrl( parent, id, pos, size, style )
+ {
+ };
+
+ NETS_LIST_CTRL()
+ {
+ };
+ void setRowItems(unsigned aRow, const wxString & aNetname, const wxString & aNetclassName );
+ void ClearList()
+ {
+ SetItemCount(0);
+ m_Netnames.Clear();
+ m_Classnames.Clear();
+ }
+
+ virtual wxString OnGetItemText(long item, long column) const;
+};
+
+
+#endif //__dialog_design_rules_aux_helper_class_h_
diff --git a/pcbnew/dialog_design_rules_base.cpp b/pcbnew/dialog_design_rules_base.cpp
index a9b972d9bc..2b464dbf5d 100644
--- a/pcbnew/dialog_design_rules_base.cpp
+++ b/pcbnew/dialog_design_rules_base.cpp
@@ -1,419 +1,421 @@
-///////////////////////////////////////////////////////////////////////////
-// C++ code generated with wxFormBuilder (version Apr 16 2008)
-// http://www.wxformbuilder.org/
-//
-// PLEASE DO "NOT" EDIT THIS FILE!
-///////////////////////////////////////////////////////////////////////////
-
-#include "dialog_design_rules_base.h"
-
-///////////////////////////////////////////////////////////////////////////
-
-DIALOG_DESIGN_RULES_BASE::DIALOG_DESIGN_RULES_BASE( wxWindow* parent, wxWindowID id, const wxString& title, const wxPoint& pos, const wxSize& size, long style ) : wxDialog( parent, id, title, pos, size, style )
-{
- this->SetSizeHints( wxSize( -1,-1 ), wxDefaultSize );
-
- wxBoxSizer* bMainSizer;
- bMainSizer = new wxBoxSizer( wxVERTICAL );
-
- m_DRnotebook = new wxNotebook( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxNB_TOP );
- m_panelNetClassesEditor = new wxPanel( m_DRnotebook, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxSUNKEN_BORDER|wxTAB_TRAVERSAL );
- wxBoxSizer* bpanelNetClassesSizer;
- bpanelNetClassesSizer = new wxBoxSizer( wxVERTICAL );
-
- wxStaticBoxSizer* sbSizer1;
- sbSizer1 = new wxStaticBoxSizer( new wxStaticBox( m_panelNetClassesEditor, wxID_ANY, _("Net Classes:") ), wxVERTICAL );
-
- m_grid = new wxGrid( m_panelNetClassesEditor, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxHSCROLL|wxSIMPLE_BORDER|wxVSCROLL );
-
- // Grid
- m_grid->CreateGrid( 1, 6 );
- m_grid->EnableEditing( true );
- m_grid->EnableGridLines( true );
- m_grid->EnableDragGridSize( false );
- m_grid->SetMargins( 0, 0 );
-
- // Columns
- m_grid->SetColSize( 0, 100 );
- m_grid->SetColSize( 1, 120 );
- m_grid->SetColSize( 2, 84 );
- m_grid->SetColSize( 3, 85 );
- m_grid->SetColSize( 4, 81 );
- m_grid->SetColSize( 5, 90 );
- m_grid->EnableDragColMove( false );
- m_grid->EnableDragColSize( true );
- m_grid->SetColLabelSize( 40 );
- m_grid->SetColLabelValue( 0, _("Clearance") );
- m_grid->SetColLabelValue( 1, _("Track Width") );
- m_grid->SetColLabelValue( 2, _("Via Dia") );
- m_grid->SetColLabelValue( 3, _("Via Drill") );
- m_grid->SetColLabelValue( 4, _("uVia Dia") );
- m_grid->SetColLabelValue( 5, _("uVia Drill") );
- m_grid->SetColLabelAlignment( wxALIGN_CENTRE, wxALIGN_CENTRE );
-
- // Rows
- m_grid->AutoSizeRows();
- m_grid->EnableDragRowSize( true );
- m_grid->SetRowLabelSize( 120 );
- m_grid->SetRowLabelValue( 0, _("Default") );
- m_grid->SetRowLabelAlignment( wxALIGN_LEFT, wxALIGN_CENTRE );
-
- // Label Appearance
-
- // Cell Defaults
- m_grid->SetDefaultCellAlignment( wxALIGN_LEFT, wxALIGN_TOP );
- m_grid->SetToolTip( _("Net Class parameters") );
-
- sbSizer1->Add( m_grid, 1, wxEXPAND, 5 );
-
- wxBoxSizer* buttonBoxSizer;
- buttonBoxSizer = new wxBoxSizer( wxHORIZONTAL );
-
- m_addButton = new wxButton( m_panelNetClassesEditor, wxID_ADD_NETCLASS, _("Add"), wxDefaultPosition, wxDefaultSize, 0 );
- m_addButton->SetToolTip( _("Add another Net Class") );
-
- buttonBoxSizer->Add( m_addButton, 0, wxALIGN_CENTER_HORIZONTAL|wxTOP|wxRIGHT|wxLEFT, 5 );
-
- m_removeButton = new wxButton( m_panelNetClassesEditor, wxID_REMOVE_NETCLASS, _("Remove"), wxDefaultPosition, wxDefaultSize, 0 );
- m_removeButton->SetToolTip( _("Remove the currently select Net Class\nThe default Net Class cannot be removed") );
-
- buttonBoxSizer->Add( m_removeButton, 0, wxALIGN_CENTER_HORIZONTAL|wxTOP|wxRIGHT|wxLEFT, 5 );
-
- m_moveUpButton = new wxButton( m_panelNetClassesEditor, wxID_ANY, _("Move Up"), wxDefaultPosition, wxDefaultSize, 0 );
- m_moveUpButton->SetToolTip( _("Move the currently selected Net Class up one row") );
-
- buttonBoxSizer->Add( m_moveUpButton, 0, wxTOP|wxRIGHT|wxLEFT, 5 );
-
- sbSizer1->Add( buttonBoxSizer, 0, wxALIGN_CENTER_HORIZONTAL|wxRIGHT|wxLEFT, 5 );
-
- bpanelNetClassesSizer->Add( sbSizer1, 1, wxRIGHT|wxLEFT|wxEXPAND, 5 );
-
- wxStaticBoxSizer* sbSizer4;
- sbSizer4 = new wxStaticBoxSizer( new wxStaticBox( m_panelNetClassesEditor, wxID_ANY, _("Membership:") ), wxHORIZONTAL );
-
- wxBoxSizer* leftNetSelectBoxSizer;
- leftNetSelectBoxSizer = new wxBoxSizer( wxVERTICAL );
-
- wxArrayString m_leftClassChoiceChoices;
- m_leftClassChoice = new wxChoice( m_panelNetClassesEditor, ID_LEFT_CHOICE_CLICK, wxDefaultPosition, wxDefaultSize, m_leftClassChoiceChoices, 0 );
- m_leftClassChoice->SetSelection( 0 );
- leftNetSelectBoxSizer->Add( m_leftClassChoice, 0, wxEXPAND, 5 );
-
- m_leftListCtrl = new wxListCtrl( m_panelNetClassesEditor, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_HRULES|wxLC_REPORT|wxLC_VRULES|wxSUNKEN_BORDER );
- m_leftListCtrl->SetMinSize( wxSize( 220,200 ) );
-
- leftNetSelectBoxSizer->Add( m_leftListCtrl, 1, wxEXPAND|wxTOP, 5 );
-
- sbSizer4->Add( leftNetSelectBoxSizer, 1, wxEXPAND|wxRIGHT|wxLEFT, 5 );
-
- wxBoxSizer* bmiddleSizerNetSelect;
- bmiddleSizerNetSelect = new wxBoxSizer( wxVERTICAL );
-
- m_buttonRightToLeft = new wxButton( m_panelNetClassesEditor, ID_LEFT_TO_RIGHT_COPY, _("<<<"), wxDefaultPosition, wxDefaultSize, 0 );
- m_buttonRightToLeft->SetToolTip( _("Move the selected nets in the right list to the left list") );
-
- bmiddleSizerNetSelect->Add( m_buttonRightToLeft, 0, wxALL|wxALIGN_CENTER_HORIZONTAL, 5 );
-
- m_buttonLeftToRight = new wxButton( m_panelNetClassesEditor, ID_RIGHT_TO_LEFT_COPY, _(">>>"), wxDefaultPosition, wxDefaultSize, 0 );
- m_buttonLeftToRight->SetToolTip( _("Move the selected nets in the left list to the right list") );
-
- bmiddleSizerNetSelect->Add( m_buttonLeftToRight, 0, wxALL|wxALIGN_CENTER_HORIZONTAL, 5 );
-
- m_buttonLeftSelAll = new wxButton( m_panelNetClassesEditor, wxID_ANY, _("<< Select All"), wxDefaultPosition, wxDefaultSize, 0 );
- m_buttonLeftSelAll->SetToolTip( _("Select all nets in the left list") );
-
- bmiddleSizerNetSelect->Add( m_buttonLeftSelAll, 0, wxALL|wxALIGN_CENTER_HORIZONTAL, 5 );
-
- m_buttonRightSelAll = new wxButton( m_panelNetClassesEditor, wxID_ANY, _("Select All >>"), wxDefaultPosition, wxDefaultSize, 0 );
- m_buttonRightSelAll->SetToolTip( _("Select all nets in the right list") );
-
- bmiddleSizerNetSelect->Add( m_buttonRightSelAll, 0, wxALIGN_BOTTOM|wxALL|wxALIGN_CENTER_HORIZONTAL, 5 );
-
- sbSizer4->Add( bmiddleSizerNetSelect, 0, wxALIGN_CENTER_VERTICAL, 5 );
-
- wxBoxSizer* rghtNetSelectBoxSizer;
- rghtNetSelectBoxSizer = new wxBoxSizer( wxVERTICAL );
-
- wxArrayString m_rightClassChoiceChoices;
- m_rightClassChoice = new wxChoice( m_panelNetClassesEditor, ID_RIGHT_CHOICE_CLICK, wxDefaultPosition, wxDefaultSize, m_rightClassChoiceChoices, 0 );
- m_rightClassChoice->SetSelection( 0 );
- rghtNetSelectBoxSizer->Add( m_rightClassChoice, 0, wxEXPAND, 5 );
-
- m_rightListCtrl = new wxListCtrl( m_panelNetClassesEditor, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_HRULES|wxLC_REPORT|wxLC_VRULES|wxSUNKEN_BORDER );
- m_rightListCtrl->SetMinSize( wxSize( 220,-1 ) );
-
- rghtNetSelectBoxSizer->Add( m_rightListCtrl, 1, wxEXPAND|wxTOP, 5 );
-
- sbSizer4->Add( rghtNetSelectBoxSizer, 1, wxEXPAND|wxRIGHT|wxLEFT, 5 );
-
- bpanelNetClassesSizer->Add( sbSizer4, 2, wxEXPAND|wxRIGHT|wxLEFT, 5 );
-
- m_panelNetClassesEditor->SetSizer( bpanelNetClassesSizer );
- m_panelNetClassesEditor->Layout();
- bpanelNetClassesSizer->Fit( m_panelNetClassesEditor );
- m_DRnotebook->AddPage( m_panelNetClassesEditor, _("Net Classes Editor"), true );
- m_panelGolbalDesignRules = new wxPanel( m_DRnotebook, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxSUNKEN_BORDER|wxTAB_TRAVERSAL );
- wxBoxSizer* bpanelGlobRulesSizer;
- bpanelGlobRulesSizer = new wxBoxSizer( wxVERTICAL );
-
- wxBoxSizer* bDesignRulesUpperSizer;
- bDesignRulesUpperSizer = new wxBoxSizer( wxHORIZONTAL );
-
- wxStaticBoxSizer* sbViasOptionSizer;
- sbViasOptionSizer = new wxStaticBoxSizer( new wxStaticBox( m_panelGolbalDesignRules, wxID_ANY, _("Via Options:") ), wxVERTICAL );
-
- wxString m_OptViaTypeChoices[] = { _("Through via"), _("Blind or buried via") };
- int m_OptViaTypeNChoices = sizeof( m_OptViaTypeChoices ) / sizeof( wxString );
- m_OptViaType = new wxRadioBox( m_panelGolbalDesignRules, wxID_ANY, _("Default Via Type"), wxDefaultPosition, wxDefaultSize, m_OptViaTypeNChoices, m_OptViaTypeChoices, 1, wxRA_SPECIFY_COLS );
- m_OptViaType->SetSelection( 0 );
- m_OptViaType->SetToolTip( _("Select the current via type.\nTrough via is the usual selection") );
-
- sbViasOptionSizer->Add( m_OptViaType, 0, wxALL|wxEXPAND, 5 );
-
- wxFlexGridSizer* fgViasMinValuesSizer;
- fgViasMinValuesSizer = new wxFlexGridSizer( 1, 2, 0, 0 );
- fgViasMinValuesSizer->AddGrowableCol( 1 );
- fgViasMinValuesSizer->SetFlexibleDirection( wxBOTH );
- fgViasMinValuesSizer->SetNonFlexibleGrowMode( wxFLEX_GROWMODE_SPECIFIED );
-
- m_ViaMinTitle = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Min via diameter"), wxDefaultPosition, wxDefaultSize, 0 );
- m_ViaMinTitle->Wrap( -1 );
- fgViasMinValuesSizer->Add( m_ViaMinTitle, 0, wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT, 5 );
-
- m_SetViasMinSizeCtrl = new wxTextCtrl( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 );
- fgViasMinValuesSizer->Add( m_SetViasMinSizeCtrl, 0, wxEXPAND|wxALL, 5 );
-
- m_ViaMinDrillTitle = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Min via drill dia"), wxDefaultPosition, wxDefaultSize, 0 );
- m_ViaMinDrillTitle->Wrap( -1 );
- fgViasMinValuesSizer->Add( m_ViaMinDrillTitle, 0, wxTOP|wxBOTTOM|wxLEFT|wxALIGN_RIGHT, 5 );
-
- m_SetViasMinDrillCtrl = new wxTextCtrl( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 );
- fgViasMinValuesSizer->Add( m_SetViasMinDrillCtrl, 0, wxALL|wxEXPAND, 5 );
-
- sbViasOptionSizer->Add( fgViasMinValuesSizer, 0, wxEXPAND, 5 );
-
- bDesignRulesUpperSizer->Add( sbViasOptionSizer, 1, wxALIGN_CENTER_VERTICAL, 5 );
-
- wxStaticBoxSizer* sbuViasSizer;
- sbuViasSizer = new wxStaticBoxSizer( new wxStaticBox( m_panelGolbalDesignRules, wxID_ANY, _("Micro Via Options:") ), wxVERTICAL );
-
- wxString m_AllowMicroViaCtrlChoices[] = { _("Do not allow micro vias"), _("Allow micro vias") };
- int m_AllowMicroViaCtrlNChoices = sizeof( m_AllowMicroViaCtrlChoices ) / sizeof( wxString );
- m_AllowMicroViaCtrl = new wxRadioBox( m_panelGolbalDesignRules, wxID_ANY, _("Micro Vias:"), wxDefaultPosition, wxDefaultSize, m_AllowMicroViaCtrlNChoices, m_AllowMicroViaCtrlChoices, 1, wxRA_SPECIFY_COLS );
- m_AllowMicroViaCtrl->SetSelection( 0 );
- m_AllowMicroViaCtrl->SetToolTip( _("Allows or do not allow use of micro vias\nThey are very small vias only from an external copper layer to its near neightbour") );
-
- sbuViasSizer->Add( m_AllowMicroViaCtrl, 0, wxALL|wxEXPAND, 5 );
-
- wxFlexGridSizer* fgMinMicroviasValuesSizer;
- fgMinMicroviasValuesSizer = new wxFlexGridSizer( 1, 2, 0, 0 );
- fgMinMicroviasValuesSizer->AddGrowableCol( 1 );
- fgMinMicroviasValuesSizer->SetFlexibleDirection( wxBOTH );
- fgMinMicroviasValuesSizer->SetNonFlexibleGrowMode( wxFLEX_GROWMODE_SPECIFIED );
-
- m_MicroViaMinSizeTitle = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Min uvia diameter"), wxDefaultPosition, wxDefaultSize, 0 );
- m_MicroViaMinSizeTitle->Wrap( -1 );
- fgMinMicroviasValuesSizer->Add( m_MicroViaMinSizeTitle, 0, wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT, 5 );
-
- m_SetMicroViasMinSizeCtrl = new wxTextCtrl( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 );
- m_SetMicroViasMinSizeCtrl->SetMaxLength( 6 );
- fgMinMicroviasValuesSizer->Add( m_SetMicroViasMinSizeCtrl, 0, wxALL|wxEXPAND, 5 );
-
- m_MicroViaMinDrillTitle = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Min uvia drill dia"), wxDefaultPosition, wxDefaultSize, 0 );
- m_MicroViaMinDrillTitle->Wrap( -1 );
- fgMinMicroviasValuesSizer->Add( m_MicroViaMinDrillTitle, 0, wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT, 5 );
-
- m_SetMicroViasMinDrillCtrl = new wxTextCtrl( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 );
- m_SetMicroViasMinDrillCtrl->SetMaxLength( 6 );
- fgMinMicroviasValuesSizer->Add( m_SetMicroViasMinDrillCtrl, 0, wxALL|wxEXPAND, 5 );
-
- sbuViasSizer->Add( fgMinMicroviasValuesSizer, 1, wxEXPAND, 5 );
-
- bDesignRulesUpperSizer->Add( sbuViasSizer, 1, wxALIGN_CENTER_VERTICAL, 5 );
-
- wxStaticBoxSizer* sbMinSizesSizer;
- sbMinSizesSizer = new wxStaticBoxSizer( new wxStaticBox( m_panelGolbalDesignRules, wxID_ANY, _("Minimum Allowed Values:") ), wxVERTICAL );
-
- wxFlexGridSizer* fgMinValuesSizer;
- fgMinValuesSizer = new wxFlexGridSizer( 1, 2, 0, 0 );
- fgMinValuesSizer->AddGrowableCol( 1 );
- fgMinValuesSizer->SetFlexibleDirection( wxBOTH );
- fgMinValuesSizer->SetNonFlexibleGrowMode( wxFLEX_GROWMODE_SPECIFIED );
-
- m_TrackMinWidthTitle = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Min track width"), wxDefaultPosition, wxDefaultSize, 0 );
- m_TrackMinWidthTitle->Wrap( -1 );
- fgMinValuesSizer->Add( m_TrackMinWidthTitle, 0, wxALIGN_CENTER_VERTICAL|wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT, 5 );
-
- m_SetTrackMinWidthCtrl = new wxTextCtrl( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 );
- fgMinValuesSizer->Add( m_SetTrackMinWidthCtrl, 0, wxALL|wxEXPAND, 5 );
-
- sbMinSizesSizer->Add( fgMinValuesSizer, 0, 0, 5 );
-
- bDesignRulesUpperSizer->Add( sbMinSizesSizer, 1, wxEXPAND, 5 );
-
- bpanelGlobRulesSizer->Add( bDesignRulesUpperSizer, 0, wxEXPAND, 5 );
-
- m_staticline1 = new wxStaticLine( m_panelGolbalDesignRules, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLI_HORIZONTAL );
- bpanelGlobRulesSizer->Add( m_staticline1, 0, wxEXPAND | wxALL, 5 );
-
- m_staticTextInfo = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Specific via diameters and track widths, which \ncan be used to replace default Netclass values \non demand, for arbitrary via or track segments."), wxDefaultPosition, wxDefaultSize, 0 );
- m_staticTextInfo->Wrap( -1 );
- bpanelGlobRulesSizer->Add( m_staticTextInfo, 0, wxALL|wxALIGN_CENTER_HORIZONTAL, 5 );
-
- wxBoxSizer* bDesignRulesLowerSizer;
- bDesignRulesLowerSizer = new wxBoxSizer( wxHORIZONTAL );
-
- wxStaticBoxSizer* sViaSizeBox;
- sViaSizeBox = new wxStaticBoxSizer( new wxStaticBox( m_panelGolbalDesignRules, wxID_ANY, _("Custom Via Sizes:") ), wxVERTICAL );
-
- m_staticText7 = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Drill value: a blank or 0 => default Netclass value"), wxDefaultPosition, wxDefaultSize, 0 );
- m_staticText7->Wrap( -1 );
- sViaSizeBox->Add( m_staticText7, 0, wxALL, 5 );
-
- m_gridViaSizeList = new wxGrid( m_panelGolbalDesignRules, wxID_ANY, wxDefaultPosition, wxDefaultSize, 0 );
-
- // Grid
- m_gridViaSizeList->CreateGrid( 7, 2 );
- m_gridViaSizeList->EnableEditing( true );
- m_gridViaSizeList->EnableGridLines( true );
- m_gridViaSizeList->EnableDragGridSize( false );
- m_gridViaSizeList->SetMargins( 0, 0 );
-
- // Columns
- m_gridViaSizeList->EnableDragColMove( false );
- m_gridViaSizeList->EnableDragColSize( true );
- m_gridViaSizeList->SetColLabelSize( 30 );
- m_gridViaSizeList->SetColLabelValue( 0, _("Diameter") );
- m_gridViaSizeList->SetColLabelValue( 1, _("Drill") );
- m_gridViaSizeList->SetColLabelAlignment( wxALIGN_CENTRE, wxALIGN_CENTRE );
-
- // Rows
- m_gridViaSizeList->EnableDragRowSize( true );
- m_gridViaSizeList->SetRowLabelSize( 80 );
- m_gridViaSizeList->SetRowLabelValue( 0, _("Via 1") );
- m_gridViaSizeList->SetRowLabelValue( 1, _("Via 2") );
- m_gridViaSizeList->SetRowLabelValue( 2, _("Via 3") );
- m_gridViaSizeList->SetRowLabelValue( 3, _("Via 4") );
- m_gridViaSizeList->SetRowLabelValue( 4, _("Via 5") );
- m_gridViaSizeList->SetRowLabelValue( 5, _("Via 6") );
- m_gridViaSizeList->SetRowLabelValue( 6, _("Via 7") );
- m_gridViaSizeList->SetRowLabelAlignment( wxALIGN_CENTRE, wxALIGN_CENTRE );
-
- // Label Appearance
-
- // Cell Defaults
- m_gridViaSizeList->SetDefaultCellAlignment( wxALIGN_LEFT, wxALIGN_TOP );
- sViaSizeBox->Add( m_gridViaSizeList, 0, wxALL, 5 );
-
- bDesignRulesLowerSizer->Add( sViaSizeBox, 1, wxALIGN_CENTER_HORIZONTAL|wxALL|wxEXPAND, 5 );
-
- wxStaticBoxSizer* sbTracksListSizer;
- sbTracksListSizer = new wxStaticBoxSizer( new wxStaticBox( m_panelGolbalDesignRules, wxID_ANY, _("Custom Track Widths:") ), wxVERTICAL );
-
- m_staticText8 = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 );
- m_staticText8->Wrap( -1 );
- sbTracksListSizer->Add( m_staticText8, 0, wxALL, 5 );
-
- m_gridTrackWidthList = new wxGrid( m_panelGolbalDesignRules, wxID_ANY, wxDefaultPosition, wxDefaultSize, 0 );
-
- // Grid
- m_gridTrackWidthList->CreateGrid( 7, 1 );
- m_gridTrackWidthList->EnableEditing( true );
- m_gridTrackWidthList->EnableGridLines( true );
- m_gridTrackWidthList->EnableDragGridSize( false );
- m_gridTrackWidthList->SetMargins( 0, 0 );
-
- // Columns
- m_gridTrackWidthList->EnableDragColMove( false );
- m_gridTrackWidthList->EnableDragColSize( true );
- m_gridTrackWidthList->SetColLabelSize( 30 );
- m_gridTrackWidthList->SetColLabelValue( 0, _("Width") );
- m_gridTrackWidthList->SetColLabelAlignment( wxALIGN_CENTRE, wxALIGN_CENTRE );
-
- // Rows
- m_gridTrackWidthList->EnableDragRowSize( true );
- m_gridTrackWidthList->SetRowLabelSize( 80 );
- m_gridTrackWidthList->SetRowLabelValue( 0, _("Track 1") );
- m_gridTrackWidthList->SetRowLabelValue( 1, _("Track 2") );
- m_gridTrackWidthList->SetRowLabelValue( 2, _("Track 3") );
- m_gridTrackWidthList->SetRowLabelValue( 3, _("Track 4") );
- m_gridTrackWidthList->SetRowLabelValue( 4, _("Track 5") );
- m_gridTrackWidthList->SetRowLabelValue( 5, _("Track 6") );
- m_gridTrackWidthList->SetRowLabelValue( 6, _("Track 7") );
- m_gridTrackWidthList->SetRowLabelAlignment( wxALIGN_CENTRE, wxALIGN_CENTRE );
-
- // Label Appearance
-
- // Cell Defaults
- m_gridTrackWidthList->SetDefaultCellAlignment( wxALIGN_LEFT, wxALIGN_TOP );
- sbTracksListSizer->Add( m_gridTrackWidthList, 0, wxALL, 5 );
-
- bDesignRulesLowerSizer->Add( sbTracksListSizer, 1, wxALIGN_CENTER_HORIZONTAL|wxALL|wxEXPAND, 5 );
-
- bpanelGlobRulesSizer->Add( bDesignRulesLowerSizer, 0, wxALIGN_CENTER_HORIZONTAL|wxEXPAND, 5 );
-
- m_panelGolbalDesignRules->SetSizer( bpanelGlobRulesSizer );
- m_panelGolbalDesignRules->Layout();
- bpanelGlobRulesSizer->Fit( m_panelGolbalDesignRules );
- m_DRnotebook->AddPage( m_panelGolbalDesignRules, _("Global Design Rules"), false );
-
- bMainSizer->Add( m_DRnotebook, 1, wxEXPAND|wxRIGHT|wxLEFT, 5 );
-
- wxStaticBoxSizer* sbSizer2;
- sbSizer2 = new wxStaticBoxSizer( new wxStaticBox( this, wxID_ANY, _("Messages:") ), wxHORIZONTAL );
-
- m_MessagesList = new wxHtmlWindow( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxHW_SCROLLBAR_AUTO|wxSUNKEN_BORDER );
- m_MessagesList->SetMinSize( wxSize( -1,90 ) );
-
- sbSizer2->Add( m_MessagesList, 1, wxEXPAND, 5 );
-
- wxBoxSizer* bSizerButtons;
- bSizerButtons = new wxBoxSizer( wxVERTICAL );
-
- m_buttonOk = new wxButton( this, wxID_OK, _("OK"), wxDefaultPosition, wxDefaultSize, 0 );
- m_buttonOk->SetDefault();
- bSizerButtons->Add( m_buttonOk, 0, wxALL|wxEXPAND, 5 );
-
- m_buttonCancel = new wxButton( this, wxID_CANCEL, _("Cancel"), wxDefaultPosition, wxDefaultSize, 0 );
- bSizerButtons->Add( m_buttonCancel, 0, wxALL|wxEXPAND, 5 );
-
- sbSizer2->Add( bSizerButtons, 0, 0, 5 );
-
- bMainSizer->Add( sbSizer2, 0, wxEXPAND|wxRIGHT|wxLEFT, 5 );
-
- this->SetSizer( bMainSizer );
- this->Layout();
-
- // Connect Events
- m_grid->Connect( wxEVT_GRID_LABEL_LEFT_CLICK, wxGridEventHandler( DIALOG_DESIGN_RULES_BASE::OnNetClassesNameLeftClick ), NULL, this );
- m_grid->Connect( wxEVT_GRID_LABEL_RIGHT_CLICK, wxGridEventHandler( DIALOG_DESIGN_RULES_BASE::OnNetClassesNameRightClick ), NULL, this );
- m_addButton->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnAddNetclassClick ), NULL, this );
- m_removeButton->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnRemoveNetclassClick ), NULL, this );
- m_moveUpButton->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnMoveUpSelectedNetClass ), NULL, this );
- m_leftClassChoice->Connect( wxEVT_COMMAND_CHOICE_SELECTED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnLeftCBSelection ), NULL, this );
- m_buttonRightToLeft->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnRightToLeftCopyButton ), NULL, this );
- m_buttonLeftToRight->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnLeftToRightCopyButton ), NULL, this );
- m_buttonLeftSelAll->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnLeftSelectAllButton ), NULL, this );
- m_buttonRightSelAll->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnRightSelectAllButton ), NULL, this );
- m_rightClassChoice->Connect( wxEVT_COMMAND_CHOICE_SELECTED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnRightCBSelection ), NULL, this );
- m_buttonOk->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnOkButtonClick ), NULL, this );
- m_buttonCancel->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnCancelButtonClick ), NULL, this );
-}
-
-DIALOG_DESIGN_RULES_BASE::~DIALOG_DESIGN_RULES_BASE()
-{
- // Disconnect Events
- m_grid->Disconnect( wxEVT_GRID_LABEL_LEFT_CLICK, wxGridEventHandler( DIALOG_DESIGN_RULES_BASE::OnNetClassesNameLeftClick ), NULL, this );
- m_grid->Disconnect( wxEVT_GRID_LABEL_RIGHT_CLICK, wxGridEventHandler( DIALOG_DESIGN_RULES_BASE::OnNetClassesNameRightClick ), NULL, this );
- m_addButton->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnAddNetclassClick ), NULL, this );
- m_removeButton->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnRemoveNetclassClick ), NULL, this );
- m_moveUpButton->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnMoveUpSelectedNetClass ), NULL, this );
- m_leftClassChoice->Disconnect( wxEVT_COMMAND_CHOICE_SELECTED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnLeftCBSelection ), NULL, this );
- m_buttonRightToLeft->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnRightToLeftCopyButton ), NULL, this );
- m_buttonLeftToRight->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnLeftToRightCopyButton ), NULL, this );
- m_buttonLeftSelAll->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnLeftSelectAllButton ), NULL, this );
- m_buttonRightSelAll->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnRightSelectAllButton ), NULL, this );
- m_rightClassChoice->Disconnect( wxEVT_COMMAND_CHOICE_SELECTED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnRightCBSelection ), NULL, this );
- m_buttonOk->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnOkButtonClick ), NULL, this );
- m_buttonCancel->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnCancelButtonClick ), NULL, this );
-}
+///////////////////////////////////////////////////////////////////////////
+// C++ code generated with wxFormBuilder (version Apr 16 2008)
+// http://www.wxformbuilder.org/
+//
+// PLEASE DO "NOT" EDIT THIS FILE!
+///////////////////////////////////////////////////////////////////////////
+
+#include "dialog_design_rules_aux_helper_class.h"
+
+#include "dialog_design_rules_base.h"
+
+///////////////////////////////////////////////////////////////////////////
+
+DIALOG_DESIGN_RULES_BASE::DIALOG_DESIGN_RULES_BASE( wxWindow* parent, wxWindowID id, const wxString& title, const wxPoint& pos, const wxSize& size, long style ) : wxDialog( parent, id, title, pos, size, style )
+{
+ this->SetSizeHints( wxSize( -1,-1 ), wxDefaultSize );
+
+ wxBoxSizer* bMainSizer;
+ bMainSizer = new wxBoxSizer( wxVERTICAL );
+
+ m_DRnotebook = new wxNotebook( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxNB_TOP );
+ m_panelNetClassesEditor = new wxPanel( m_DRnotebook, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxSUNKEN_BORDER|wxTAB_TRAVERSAL );
+ wxBoxSizer* bpanelNetClassesSizer;
+ bpanelNetClassesSizer = new wxBoxSizer( wxVERTICAL );
+
+ wxStaticBoxSizer* sbSizer1;
+ sbSizer1 = new wxStaticBoxSizer( new wxStaticBox( m_panelNetClassesEditor, wxID_ANY, _("Net Classes:") ), wxVERTICAL );
+
+ m_grid = new wxGrid( m_panelNetClassesEditor, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxHSCROLL|wxSIMPLE_BORDER|wxVSCROLL );
+
+ // Grid
+ m_grid->CreateGrid( 1, 6 );
+ m_grid->EnableEditing( true );
+ m_grid->EnableGridLines( true );
+ m_grid->EnableDragGridSize( false );
+ m_grid->SetMargins( 0, 0 );
+
+ // Columns
+ m_grid->SetColSize( 0, 100 );
+ m_grid->SetColSize( 1, 120 );
+ m_grid->SetColSize( 2, 84 );
+ m_grid->SetColSize( 3, 85 );
+ m_grid->SetColSize( 4, 81 );
+ m_grid->SetColSize( 5, 90 );
+ m_grid->EnableDragColMove( false );
+ m_grid->EnableDragColSize( true );
+ m_grid->SetColLabelSize( 40 );
+ m_grid->SetColLabelValue( 0, _("Clearance") );
+ m_grid->SetColLabelValue( 1, _("Track Width") );
+ m_grid->SetColLabelValue( 2, _("Via Dia") );
+ m_grid->SetColLabelValue( 3, _("Via Drill") );
+ m_grid->SetColLabelValue( 4, _("uVia Dia") );
+ m_grid->SetColLabelValue( 5, _("uVia Drill") );
+ m_grid->SetColLabelAlignment( wxALIGN_CENTRE, wxALIGN_CENTRE );
+
+ // Rows
+ m_grid->AutoSizeRows();
+ m_grid->EnableDragRowSize( true );
+ m_grid->SetRowLabelSize( 120 );
+ m_grid->SetRowLabelValue( 0, _("Default") );
+ m_grid->SetRowLabelAlignment( wxALIGN_LEFT, wxALIGN_CENTRE );
+
+ // Label Appearance
+
+ // Cell Defaults
+ m_grid->SetDefaultCellAlignment( wxALIGN_LEFT, wxALIGN_TOP );
+ m_grid->SetToolTip( _("Net Class parameters") );
+
+ sbSizer1->Add( m_grid, 1, wxEXPAND, 5 );
+
+ wxBoxSizer* buttonBoxSizer;
+ buttonBoxSizer = new wxBoxSizer( wxHORIZONTAL );
+
+ m_addButton = new wxButton( m_panelNetClassesEditor, wxID_ADD_NETCLASS, _("Add"), wxDefaultPosition, wxDefaultSize, 0 );
+ m_addButton->SetToolTip( _("Add another Net Class") );
+
+ buttonBoxSizer->Add( m_addButton, 0, wxALIGN_CENTER_HORIZONTAL|wxTOP|wxRIGHT|wxLEFT, 5 );
+
+ m_removeButton = new wxButton( m_panelNetClassesEditor, wxID_REMOVE_NETCLASS, _("Remove"), wxDefaultPosition, wxDefaultSize, 0 );
+ m_removeButton->SetToolTip( _("Remove the currently select Net Class\nThe default Net Class cannot be removed") );
+
+ buttonBoxSizer->Add( m_removeButton, 0, wxALIGN_CENTER_HORIZONTAL|wxTOP|wxRIGHT|wxLEFT, 5 );
+
+ m_moveUpButton = new wxButton( m_panelNetClassesEditor, wxID_ANY, _("Move Up"), wxDefaultPosition, wxDefaultSize, 0 );
+ m_moveUpButton->SetToolTip( _("Move the currently selected Net Class up one row") );
+
+ buttonBoxSizer->Add( m_moveUpButton, 0, wxTOP|wxRIGHT|wxLEFT, 5 );
+
+ sbSizer1->Add( buttonBoxSizer, 0, wxALIGN_CENTER_HORIZONTAL|wxRIGHT|wxLEFT, 5 );
+
+ bpanelNetClassesSizer->Add( sbSizer1, 1, wxRIGHT|wxLEFT|wxEXPAND, 5 );
+
+ wxStaticBoxSizer* sbSizer4;
+ sbSizer4 = new wxStaticBoxSizer( new wxStaticBox( m_panelNetClassesEditor, wxID_ANY, _("Membership:") ), wxHORIZONTAL );
+
+ wxBoxSizer* leftNetSelectBoxSizer;
+ leftNetSelectBoxSizer = new wxBoxSizer( wxVERTICAL );
+
+ wxArrayString m_leftClassChoiceChoices;
+ m_leftClassChoice = new wxChoice( m_panelNetClassesEditor, ID_LEFT_CHOICE_CLICK, wxDefaultPosition, wxDefaultSize, m_leftClassChoiceChoices, 0 );
+ m_leftClassChoice->SetSelection( 0 );
+ leftNetSelectBoxSizer->Add( m_leftClassChoice, 0, wxEXPAND, 5 );
+
+ m_leftListCtrl = new NETS_LIST_CTRL( m_panelNetClassesEditor, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_HRULES|wxLC_REPORT|wxLC_VIRTUAL|wxLC_VRULES|wxSUNKEN_BORDER );
+ m_leftListCtrl->SetMinSize( wxSize( 220,200 ) );
+
+ leftNetSelectBoxSizer->Add( m_leftListCtrl, 1, wxEXPAND|wxTOP, 5 );
+
+ sbSizer4->Add( leftNetSelectBoxSizer, 1, wxEXPAND|wxRIGHT|wxLEFT, 5 );
+
+ wxBoxSizer* bmiddleSizerNetSelect;
+ bmiddleSizerNetSelect = new wxBoxSizer( wxVERTICAL );
+
+ m_buttonRightToLeft = new wxButton( m_panelNetClassesEditor, ID_LEFT_TO_RIGHT_COPY, _("<<<"), wxDefaultPosition, wxDefaultSize, 0 );
+ m_buttonRightToLeft->SetToolTip( _("Move the selected nets in the right list to the left list") );
+
+ bmiddleSizerNetSelect->Add( m_buttonRightToLeft, 0, wxALL|wxALIGN_CENTER_HORIZONTAL, 5 );
+
+ m_buttonLeftToRight = new wxButton( m_panelNetClassesEditor, ID_RIGHT_TO_LEFT_COPY, _(">>>"), wxDefaultPosition, wxDefaultSize, 0 );
+ m_buttonLeftToRight->SetToolTip( _("Move the selected nets in the left list to the right list") );
+
+ bmiddleSizerNetSelect->Add( m_buttonLeftToRight, 0, wxALL|wxALIGN_CENTER_HORIZONTAL, 5 );
+
+ m_buttonLeftSelAll = new wxButton( m_panelNetClassesEditor, wxID_ANY, _("<< Select All"), wxDefaultPosition, wxDefaultSize, 0 );
+ m_buttonLeftSelAll->SetToolTip( _("Select all nets in the left list") );
+
+ bmiddleSizerNetSelect->Add( m_buttonLeftSelAll, 0, wxALL|wxALIGN_CENTER_HORIZONTAL, 5 );
+
+ m_buttonRightSelAll = new wxButton( m_panelNetClassesEditor, wxID_ANY, _("Select All >>"), wxDefaultPosition, wxDefaultSize, 0 );
+ m_buttonRightSelAll->SetToolTip( _("Select all nets in the right list") );
+
+ bmiddleSizerNetSelect->Add( m_buttonRightSelAll, 0, wxALIGN_BOTTOM|wxALL|wxALIGN_CENTER_HORIZONTAL, 5 );
+
+ sbSizer4->Add( bmiddleSizerNetSelect, 0, wxALIGN_CENTER_VERTICAL, 5 );
+
+ wxBoxSizer* rghtNetSelectBoxSizer;
+ rghtNetSelectBoxSizer = new wxBoxSizer( wxVERTICAL );
+
+ wxArrayString m_rightClassChoiceChoices;
+ m_rightClassChoice = new wxChoice( m_panelNetClassesEditor, ID_RIGHT_CHOICE_CLICK, wxDefaultPosition, wxDefaultSize, m_rightClassChoiceChoices, 0 );
+ m_rightClassChoice->SetSelection( 0 );
+ rghtNetSelectBoxSizer->Add( m_rightClassChoice, 0, wxEXPAND, 5 );
+
+ m_rightListCtrl = new NETS_LIST_CTRL( m_panelNetClassesEditor, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_HRULES|wxLC_REPORT|wxLC_VIRTUAL|wxLC_VRULES|wxSUNKEN_BORDER );
+ m_rightListCtrl->SetMinSize( wxSize( 220,-1 ) );
+
+ rghtNetSelectBoxSizer->Add( m_rightListCtrl, 1, wxEXPAND|wxTOP, 5 );
+
+ sbSizer4->Add( rghtNetSelectBoxSizer, 1, wxEXPAND|wxRIGHT|wxLEFT, 5 );
+
+ bpanelNetClassesSizer->Add( sbSizer4, 2, wxEXPAND|wxRIGHT|wxLEFT, 5 );
+
+ m_panelNetClassesEditor->SetSizer( bpanelNetClassesSizer );
+ m_panelNetClassesEditor->Layout();
+ bpanelNetClassesSizer->Fit( m_panelNetClassesEditor );
+ m_DRnotebook->AddPage( m_panelNetClassesEditor, _("Net Classes Editor"), true );
+ m_panelGolbalDesignRules = new wxPanel( m_DRnotebook, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxSUNKEN_BORDER|wxTAB_TRAVERSAL );
+ wxBoxSizer* bpanelGlobRulesSizer;
+ bpanelGlobRulesSizer = new wxBoxSizer( wxVERTICAL );
+
+ wxBoxSizer* bDesignRulesUpperSizer;
+ bDesignRulesUpperSizer = new wxBoxSizer( wxHORIZONTAL );
+
+ wxStaticBoxSizer* sbViasOptionSizer;
+ sbViasOptionSizer = new wxStaticBoxSizer( new wxStaticBox( m_panelGolbalDesignRules, wxID_ANY, _("Via Options:") ), wxVERTICAL );
+
+ wxString m_OptViaTypeChoices[] = { _("Through via"), _("Blind or buried via") };
+ int m_OptViaTypeNChoices = sizeof( m_OptViaTypeChoices ) / sizeof( wxString );
+ m_OptViaType = new wxRadioBox( m_panelGolbalDesignRules, wxID_ANY, _("Default Via Type"), wxDefaultPosition, wxDefaultSize, m_OptViaTypeNChoices, m_OptViaTypeChoices, 1, wxRA_SPECIFY_COLS );
+ m_OptViaType->SetSelection( 0 );
+ m_OptViaType->SetToolTip( _("Select the current via type.\nTrough via is the usual selection") );
+
+ sbViasOptionSizer->Add( m_OptViaType, 0, wxALL|wxEXPAND, 5 );
+
+ wxFlexGridSizer* fgViasMinValuesSizer;
+ fgViasMinValuesSizer = new wxFlexGridSizer( 1, 2, 0, 0 );
+ fgViasMinValuesSizer->AddGrowableCol( 1 );
+ fgViasMinValuesSizer->SetFlexibleDirection( wxBOTH );
+ fgViasMinValuesSizer->SetNonFlexibleGrowMode( wxFLEX_GROWMODE_SPECIFIED );
+
+ m_ViaMinTitle = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Min via diameter"), wxDefaultPosition, wxDefaultSize, 0 );
+ m_ViaMinTitle->Wrap( -1 );
+ fgViasMinValuesSizer->Add( m_ViaMinTitle, 0, wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT, 5 );
+
+ m_SetViasMinSizeCtrl = new wxTextCtrl( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 );
+ fgViasMinValuesSizer->Add( m_SetViasMinSizeCtrl, 0, wxEXPAND|wxALL, 5 );
+
+ m_ViaMinDrillTitle = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Min via drill dia"), wxDefaultPosition, wxDefaultSize, 0 );
+ m_ViaMinDrillTitle->Wrap( -1 );
+ fgViasMinValuesSizer->Add( m_ViaMinDrillTitle, 0, wxTOP|wxBOTTOM|wxLEFT|wxALIGN_RIGHT, 5 );
+
+ m_SetViasMinDrillCtrl = new wxTextCtrl( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 );
+ fgViasMinValuesSizer->Add( m_SetViasMinDrillCtrl, 0, wxALL|wxEXPAND, 5 );
+
+ sbViasOptionSizer->Add( fgViasMinValuesSizer, 0, wxEXPAND, 5 );
+
+ bDesignRulesUpperSizer->Add( sbViasOptionSizer, 1, wxALIGN_CENTER_VERTICAL, 5 );
+
+ wxStaticBoxSizer* sbuViasSizer;
+ sbuViasSizer = new wxStaticBoxSizer( new wxStaticBox( m_panelGolbalDesignRules, wxID_ANY, _("Micro Via Options:") ), wxVERTICAL );
+
+ wxString m_AllowMicroViaCtrlChoices[] = { _("Do not allow micro vias"), _("Allow micro vias") };
+ int m_AllowMicroViaCtrlNChoices = sizeof( m_AllowMicroViaCtrlChoices ) / sizeof( wxString );
+ m_AllowMicroViaCtrl = new wxRadioBox( m_panelGolbalDesignRules, wxID_ANY, _("Micro Vias:"), wxDefaultPosition, wxDefaultSize, m_AllowMicroViaCtrlNChoices, m_AllowMicroViaCtrlChoices, 1, wxRA_SPECIFY_COLS );
+ m_AllowMicroViaCtrl->SetSelection( 0 );
+ m_AllowMicroViaCtrl->SetToolTip( _("Allows or do not allow use of micro vias\nThey are very small vias only from an external copper layer to its near neightbour") );
+
+ sbuViasSizer->Add( m_AllowMicroViaCtrl, 0, wxALL|wxEXPAND, 5 );
+
+ wxFlexGridSizer* fgMinMicroviasValuesSizer;
+ fgMinMicroviasValuesSizer = new wxFlexGridSizer( 1, 2, 0, 0 );
+ fgMinMicroviasValuesSizer->AddGrowableCol( 1 );
+ fgMinMicroviasValuesSizer->SetFlexibleDirection( wxBOTH );
+ fgMinMicroviasValuesSizer->SetNonFlexibleGrowMode( wxFLEX_GROWMODE_SPECIFIED );
+
+ m_MicroViaMinSizeTitle = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Min uvia diameter"), wxDefaultPosition, wxDefaultSize, 0 );
+ m_MicroViaMinSizeTitle->Wrap( -1 );
+ fgMinMicroviasValuesSizer->Add( m_MicroViaMinSizeTitle, 0, wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT, 5 );
+
+ m_SetMicroViasMinSizeCtrl = new wxTextCtrl( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 );
+ m_SetMicroViasMinSizeCtrl->SetMaxLength( 6 );
+ fgMinMicroviasValuesSizer->Add( m_SetMicroViasMinSizeCtrl, 0, wxALL|wxEXPAND, 5 );
+
+ m_MicroViaMinDrillTitle = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Min uvia drill dia"), wxDefaultPosition, wxDefaultSize, 0 );
+ m_MicroViaMinDrillTitle->Wrap( -1 );
+ fgMinMicroviasValuesSizer->Add( m_MicroViaMinDrillTitle, 0, wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT, 5 );
+
+ m_SetMicroViasMinDrillCtrl = new wxTextCtrl( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 );
+ m_SetMicroViasMinDrillCtrl->SetMaxLength( 6 );
+ fgMinMicroviasValuesSizer->Add( m_SetMicroViasMinDrillCtrl, 0, wxALL|wxEXPAND, 5 );
+
+ sbuViasSizer->Add( fgMinMicroviasValuesSizer, 1, wxEXPAND, 5 );
+
+ bDesignRulesUpperSizer->Add( sbuViasSizer, 1, wxALIGN_CENTER_VERTICAL, 5 );
+
+ wxStaticBoxSizer* sbMinSizesSizer;
+ sbMinSizesSizer = new wxStaticBoxSizer( new wxStaticBox( m_panelGolbalDesignRules, wxID_ANY, _("Minimum Allowed Values:") ), wxVERTICAL );
+
+ wxFlexGridSizer* fgMinValuesSizer;
+ fgMinValuesSizer = new wxFlexGridSizer( 1, 2, 0, 0 );
+ fgMinValuesSizer->AddGrowableCol( 1 );
+ fgMinValuesSizer->SetFlexibleDirection( wxBOTH );
+ fgMinValuesSizer->SetNonFlexibleGrowMode( wxFLEX_GROWMODE_SPECIFIED );
+
+ m_TrackMinWidthTitle = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Min track width"), wxDefaultPosition, wxDefaultSize, 0 );
+ m_TrackMinWidthTitle->Wrap( -1 );
+ fgMinValuesSizer->Add( m_TrackMinWidthTitle, 0, wxALIGN_CENTER_VERTICAL|wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT, 5 );
+
+ m_SetTrackMinWidthCtrl = new wxTextCtrl( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 );
+ fgMinValuesSizer->Add( m_SetTrackMinWidthCtrl, 0, wxALL|wxEXPAND, 5 );
+
+ sbMinSizesSizer->Add( fgMinValuesSizer, 0, 0, 5 );
+
+ bDesignRulesUpperSizer->Add( sbMinSizesSizer, 1, wxEXPAND, 5 );
+
+ bpanelGlobRulesSizer->Add( bDesignRulesUpperSizer, 0, wxEXPAND, 5 );
+
+ m_staticline1 = new wxStaticLine( m_panelGolbalDesignRules, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLI_HORIZONTAL );
+ bpanelGlobRulesSizer->Add( m_staticline1, 0, wxEXPAND | wxALL, 5 );
+
+ m_staticTextInfo = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Specific via diameters and track widths, which \ncan be used to replace default Netclass values \non demand, for arbitrary via or track segments."), wxDefaultPosition, wxDefaultSize, 0 );
+ m_staticTextInfo->Wrap( -1 );
+ bpanelGlobRulesSizer->Add( m_staticTextInfo, 0, wxALL|wxALIGN_CENTER_HORIZONTAL, 5 );
+
+ wxBoxSizer* bDesignRulesLowerSizer;
+ bDesignRulesLowerSizer = new wxBoxSizer( wxHORIZONTAL );
+
+ wxStaticBoxSizer* sViaSizeBox;
+ sViaSizeBox = new wxStaticBoxSizer( new wxStaticBox( m_panelGolbalDesignRules, wxID_ANY, _("Custom Via Sizes:") ), wxVERTICAL );
+
+ m_staticText7 = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, _("Drill value: a blank or 0 => default Netclass value"), wxDefaultPosition, wxDefaultSize, 0 );
+ m_staticText7->Wrap( -1 );
+ sViaSizeBox->Add( m_staticText7, 0, wxALL, 5 );
+
+ m_gridViaSizeList = new wxGrid( m_panelGolbalDesignRules, wxID_ANY, wxDefaultPosition, wxDefaultSize, 0 );
+
+ // Grid
+ m_gridViaSizeList->CreateGrid( 7, 2 );
+ m_gridViaSizeList->EnableEditing( true );
+ m_gridViaSizeList->EnableGridLines( true );
+ m_gridViaSizeList->EnableDragGridSize( false );
+ m_gridViaSizeList->SetMargins( 0, 0 );
+
+ // Columns
+ m_gridViaSizeList->EnableDragColMove( false );
+ m_gridViaSizeList->EnableDragColSize( true );
+ m_gridViaSizeList->SetColLabelSize( 30 );
+ m_gridViaSizeList->SetColLabelValue( 0, _("Diameter") );
+ m_gridViaSizeList->SetColLabelValue( 1, _("Drill") );
+ m_gridViaSizeList->SetColLabelAlignment( wxALIGN_CENTRE, wxALIGN_CENTRE );
+
+ // Rows
+ m_gridViaSizeList->EnableDragRowSize( true );
+ m_gridViaSizeList->SetRowLabelSize( 80 );
+ m_gridViaSizeList->SetRowLabelValue( 0, _("Via 1") );
+ m_gridViaSizeList->SetRowLabelValue( 1, _("Via 2") );
+ m_gridViaSizeList->SetRowLabelValue( 2, _("Via 3") );
+ m_gridViaSizeList->SetRowLabelValue( 3, _("Via 4") );
+ m_gridViaSizeList->SetRowLabelValue( 4, _("Via 5") );
+ m_gridViaSizeList->SetRowLabelValue( 5, _("Via 6") );
+ m_gridViaSizeList->SetRowLabelValue( 6, _("Via 7") );
+ m_gridViaSizeList->SetRowLabelAlignment( wxALIGN_CENTRE, wxALIGN_CENTRE );
+
+ // Label Appearance
+
+ // Cell Defaults
+ m_gridViaSizeList->SetDefaultCellAlignment( wxALIGN_LEFT, wxALIGN_TOP );
+ sViaSizeBox->Add( m_gridViaSizeList, 0, wxALL, 5 );
+
+ bDesignRulesLowerSizer->Add( sViaSizeBox, 1, wxALIGN_CENTER_HORIZONTAL|wxALL|wxEXPAND, 5 );
+
+ wxStaticBoxSizer* sbTracksListSizer;
+ sbTracksListSizer = new wxStaticBoxSizer( new wxStaticBox( m_panelGolbalDesignRules, wxID_ANY, _("Custom Track Widths:") ), wxVERTICAL );
+
+ m_staticText8 = new wxStaticText( m_panelGolbalDesignRules, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 );
+ m_staticText8->Wrap( -1 );
+ sbTracksListSizer->Add( m_staticText8, 0, wxALL, 5 );
+
+ m_gridTrackWidthList = new wxGrid( m_panelGolbalDesignRules, wxID_ANY, wxDefaultPosition, wxDefaultSize, 0 );
+
+ // Grid
+ m_gridTrackWidthList->CreateGrid( 7, 1 );
+ m_gridTrackWidthList->EnableEditing( true );
+ m_gridTrackWidthList->EnableGridLines( true );
+ m_gridTrackWidthList->EnableDragGridSize( false );
+ m_gridTrackWidthList->SetMargins( 0, 0 );
+
+ // Columns
+ m_gridTrackWidthList->EnableDragColMove( false );
+ m_gridTrackWidthList->EnableDragColSize( true );
+ m_gridTrackWidthList->SetColLabelSize( 30 );
+ m_gridTrackWidthList->SetColLabelValue( 0, _("Width") );
+ m_gridTrackWidthList->SetColLabelAlignment( wxALIGN_CENTRE, wxALIGN_CENTRE );
+
+ // Rows
+ m_gridTrackWidthList->EnableDragRowSize( true );
+ m_gridTrackWidthList->SetRowLabelSize( 80 );
+ m_gridTrackWidthList->SetRowLabelValue( 0, _("Track 1") );
+ m_gridTrackWidthList->SetRowLabelValue( 1, _("Track 2") );
+ m_gridTrackWidthList->SetRowLabelValue( 2, _("Track 3") );
+ m_gridTrackWidthList->SetRowLabelValue( 3, _("Track 4") );
+ m_gridTrackWidthList->SetRowLabelValue( 4, _("Track 5") );
+ m_gridTrackWidthList->SetRowLabelValue( 5, _("Track 6") );
+ m_gridTrackWidthList->SetRowLabelValue( 6, _("Track 7") );
+ m_gridTrackWidthList->SetRowLabelAlignment( wxALIGN_CENTRE, wxALIGN_CENTRE );
+
+ // Label Appearance
+
+ // Cell Defaults
+ m_gridTrackWidthList->SetDefaultCellAlignment( wxALIGN_LEFT, wxALIGN_TOP );
+ sbTracksListSizer->Add( m_gridTrackWidthList, 0, wxALL, 5 );
+
+ bDesignRulesLowerSizer->Add( sbTracksListSizer, 1, wxALIGN_CENTER_HORIZONTAL|wxALL|wxEXPAND, 5 );
+
+ bpanelGlobRulesSizer->Add( bDesignRulesLowerSizer, 0, wxALIGN_CENTER_HORIZONTAL|wxEXPAND, 5 );
+
+ m_panelGolbalDesignRules->SetSizer( bpanelGlobRulesSizer );
+ m_panelGolbalDesignRules->Layout();
+ bpanelGlobRulesSizer->Fit( m_panelGolbalDesignRules );
+ m_DRnotebook->AddPage( m_panelGolbalDesignRules, _("Global Design Rules"), false );
+
+ bMainSizer->Add( m_DRnotebook, 1, wxEXPAND|wxRIGHT|wxLEFT, 5 );
+
+ wxStaticBoxSizer* sbSizer2;
+ sbSizer2 = new wxStaticBoxSizer( new wxStaticBox( this, wxID_ANY, _("Messages:") ), wxHORIZONTAL );
+
+ m_MessagesList = new wxHtmlWindow( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxHW_SCROLLBAR_AUTO|wxSUNKEN_BORDER );
+ m_MessagesList->SetMinSize( wxSize( -1,90 ) );
+
+ sbSizer2->Add( m_MessagesList, 1, wxEXPAND, 5 );
+
+ wxBoxSizer* bSizerButtons;
+ bSizerButtons = new wxBoxSizer( wxVERTICAL );
+
+ m_buttonOk = new wxButton( this, wxID_OK, _("OK"), wxDefaultPosition, wxDefaultSize, 0 );
+ m_buttonOk->SetDefault();
+ bSizerButtons->Add( m_buttonOk, 0, wxALL|wxEXPAND, 5 );
+
+ m_buttonCancel = new wxButton( this, wxID_CANCEL, _("Cancel"), wxDefaultPosition, wxDefaultSize, 0 );
+ bSizerButtons->Add( m_buttonCancel, 0, wxALL|wxEXPAND, 5 );
+
+ sbSizer2->Add( bSizerButtons, 0, 0, 5 );
+
+ bMainSizer->Add( sbSizer2, 0, wxEXPAND|wxRIGHT|wxLEFT, 5 );
+
+ this->SetSizer( bMainSizer );
+ this->Layout();
+
+ // Connect Events
+ m_grid->Connect( wxEVT_GRID_LABEL_LEFT_CLICK, wxGridEventHandler( DIALOG_DESIGN_RULES_BASE::OnNetClassesNameLeftClick ), NULL, this );
+ m_grid->Connect( wxEVT_GRID_LABEL_RIGHT_CLICK, wxGridEventHandler( DIALOG_DESIGN_RULES_BASE::OnNetClassesNameRightClick ), NULL, this );
+ m_addButton->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnAddNetclassClick ), NULL, this );
+ m_removeButton->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnRemoveNetclassClick ), NULL, this );
+ m_moveUpButton->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnMoveUpSelectedNetClass ), NULL, this );
+ m_leftClassChoice->Connect( wxEVT_COMMAND_CHOICE_SELECTED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnLeftCBSelection ), NULL, this );
+ m_buttonRightToLeft->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnRightToLeftCopyButton ), NULL, this );
+ m_buttonLeftToRight->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnLeftToRightCopyButton ), NULL, this );
+ m_buttonLeftSelAll->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnLeftSelectAllButton ), NULL, this );
+ m_buttonRightSelAll->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnRightSelectAllButton ), NULL, this );
+ m_rightClassChoice->Connect( wxEVT_COMMAND_CHOICE_SELECTED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnRightCBSelection ), NULL, this );
+ m_buttonOk->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnOkButtonClick ), NULL, this );
+ m_buttonCancel->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnCancelButtonClick ), NULL, this );
+}
+
+DIALOG_DESIGN_RULES_BASE::~DIALOG_DESIGN_RULES_BASE()
+{
+ // Disconnect Events
+ m_grid->Disconnect( wxEVT_GRID_LABEL_LEFT_CLICK, wxGridEventHandler( DIALOG_DESIGN_RULES_BASE::OnNetClassesNameLeftClick ), NULL, this );
+ m_grid->Disconnect( wxEVT_GRID_LABEL_RIGHT_CLICK, wxGridEventHandler( DIALOG_DESIGN_RULES_BASE::OnNetClassesNameRightClick ), NULL, this );
+ m_addButton->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnAddNetclassClick ), NULL, this );
+ m_removeButton->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnRemoveNetclassClick ), NULL, this );
+ m_moveUpButton->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnMoveUpSelectedNetClass ), NULL, this );
+ m_leftClassChoice->Disconnect( wxEVT_COMMAND_CHOICE_SELECTED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnLeftCBSelection ), NULL, this );
+ m_buttonRightToLeft->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnRightToLeftCopyButton ), NULL, this );
+ m_buttonLeftToRight->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnLeftToRightCopyButton ), NULL, this );
+ m_buttonLeftSelAll->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnLeftSelectAllButton ), NULL, this );
+ m_buttonRightSelAll->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnRightSelectAllButton ), NULL, this );
+ m_rightClassChoice->Disconnect( wxEVT_COMMAND_CHOICE_SELECTED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnRightCBSelection ), NULL, this );
+ m_buttonOk->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnOkButtonClick ), NULL, this );
+ m_buttonCancel->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_DESIGN_RULES_BASE::OnCancelButtonClick ), NULL, this );
+}
diff --git a/pcbnew/dialog_design_rules_base.fbp b/pcbnew/dialog_design_rules_base.fbp
index 80565cb984..103a0e5a04 100644
--- a/pcbnew/dialog_design_rules_base.fbp
+++ b/pcbnew/dialog_design_rules_base.fbp
@@ -1,2417 +1,2417 @@
-
-
-
-
-
- C++
- 1
- UTF-8
- connect
- dialog_design_rules_base
- 1000
- none
- 1
- dialog_design_rules_base
-
- .
-
- 1
- 1
- 0
-
-
-
-
- 1
-
-
-
- 0
- wxID_ANY
-
- -1,-1
- DIALOG_DESIGN_RULES_BASE
-
- 777,640
- wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER
-
- Design Rules Editor
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- bMainSizer
- wxVERTICAL
- none
-
- 5
- wxEXPAND|wxRIGHT|wxLEFT
- 1
-
-
-
-
- 1
-
-
- 0
- wxID_ANY
-
-
- m_DRnotebook
- protected
-
-
- wxNB_TOP
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Net Classes Editor
- 1
-
-
-
- 1
-
-
- 0
- wxID_ANY
-
-
- m_panelNetClassesEditor
- protected
-
-
-
-
-
-
- wxSUNKEN_BORDER|wxTAB_TRAVERSAL
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- bpanelNetClassesSizer
- wxVERTICAL
- none
-
- 5
- wxRIGHT|wxLEFT|wxEXPAND
- 1
-
- wxID_ANY
- Net Classes:
-
- sbSizer1
- wxVERTICAL
- none
-
-
- 5
- wxEXPAND
- 1
-
- 0
- 1
-
-
-
- wxALIGN_LEFT
-
- wxALIGN_TOP
- wxALIGN_CENTRE
- 40
- "Clearance" "Track Width" "Via Dia" "Via Drill" "uVia Dia" "uVia Drill"
- wxALIGN_CENTRE
- 6
- 100,120,84,85,81,90
-
- 0
- 1
- 0
- 1
- 1
- 1
-
-
-
- 1
- 0
- wxID_ANY
-
-
-
- 0
- 0
-
- -1,-1
- m_grid
- protected
-
- wxALIGN_LEFT
- 120
- "Default"
- wxALIGN_CENTRE
-
- 1
-
-
- Net Class parameters
-
-
- wxHSCROLL|wxSIMPLE_BORDER|wxVSCROLL
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OnNetClassesNameLeftClick
-
- OnNetClassesNameRightClick
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALIGN_CENTER_HORIZONTAL|wxRIGHT|wxLEFT
- 0
-
-
- buttonBoxSizer
- wxHORIZONTAL
- none
-
- 5
- wxALIGN_CENTER_HORIZONTAL|wxTOP|wxRIGHT|wxLEFT
- 0
-
-
-
- 0
- 1
-
-
- 0
- wxID_ADD_NETCLASS
- Add
-
-
- m_addButton
- protected
-
-
-
-
- Add another Net Class
-
-
-
- OnAddNetclassClick
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALIGN_CENTER_HORIZONTAL|wxTOP|wxRIGHT|wxLEFT
- 0
-
-
-
- 0
- 1
-
-
- 0
- wxID_REMOVE_NETCLASS
- Remove
-
-
- m_removeButton
- protected
-
-
-
-
- Remove the currently select Net Class
The default Net Class cannot be removed
-
-
-
- OnRemoveNetclassClick
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxTOP|wxRIGHT|wxLEFT
- 0
-
-
-
- 0
- 1
-
-
- 0
- wxID_ANY
- Move Up
-
-
- m_moveUpButton
- protected
-
-
-
-
- Move the currently selected Net Class up one row
-
-
-
- OnMoveUpSelectedNetClass
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxEXPAND|wxRIGHT|wxLEFT
- 2
-
- wxID_ANY
- Membership:
-
- sbSizer4
- wxHORIZONTAL
- none
-
-
- 5
- wxEXPAND|wxRIGHT|wxLEFT
- 1
-
-
- leftNetSelectBoxSizer
- wxVERTICAL
- none
-
- 5
- wxEXPAND
- 0
-
-
-
-
- 1
-
-
- 0
- ID_LEFT_CHOICE_CLICK
-
-
- m_leftClassChoice
- protected
-
- 0
-
-
-
-
-
-
-
- OnLeftCBSelection
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxEXPAND|wxTOP
- 1
-
-
-
- 1
-
-
- 0
- wxID_ANY
-
- 220,200
- m_leftListCtrl
- protected
-
-
- wxLC_HRULES|wxLC_REPORT|wxLC_VRULES
-
-
-
-
- wxSUNKEN_BORDER
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALIGN_CENTER_VERTICAL
- 0
-
-
- bmiddleSizerNetSelect
- wxVERTICAL
- none
-
- 5
- wxALL|wxALIGN_CENTER_HORIZONTAL
- 0
-
-
-
- 0
- 1
-
-
- 0
- ID_LEFT_TO_RIGHT_COPY
- <<<
-
-
- m_buttonRightToLeft
- protected
-
-
-
-
- Move the selected nets in the right list to the left list
-
-
-
- OnRightToLeftCopyButton
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALL|wxALIGN_CENTER_HORIZONTAL
- 0
-
-
-
- 0
- 1
-
-
- 0
- ID_RIGHT_TO_LEFT_COPY
- >>>
-
-
- m_buttonLeftToRight
- protected
-
-
-
-
- Move the selected nets in the left list to the right list
-
-
-
- OnLeftToRightCopyButton
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALL|wxALIGN_CENTER_HORIZONTAL
- 0
-
-
-
- 0
- 1
-
-
- 0
- wxID_ANY
- << Select All
-
-
- m_buttonLeftSelAll
- protected
-
-
-
-
- Select all nets in the left list
-
-
-
- OnLeftSelectAllButton
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALIGN_BOTTOM|wxALL|wxALIGN_CENTER_HORIZONTAL
- 0
-
-
-
- 0
- 1
-
-
- 0
- wxID_ANY
- Select All >>
-
-
- m_buttonRightSelAll
- protected
-
-
-
-
- Select all nets in the right list
-
-
-
- OnRightSelectAllButton
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxEXPAND|wxRIGHT|wxLEFT
- 1
-
-
- rghtNetSelectBoxSizer
- wxVERTICAL
- none
-
- 5
- wxEXPAND
- 0
-
-
-
-
- 1
-
-
- 0
- ID_RIGHT_CHOICE_CLICK
-
-
- m_rightClassChoice
- protected
-
- 0
-
-
-
-
-
-
-
- OnRightCBSelection
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxEXPAND|wxTOP
- 1
-
-
-
- 1
-
-
- 0
- wxID_ANY
-
- 220,-1
- m_rightListCtrl
- protected
-
-
- wxLC_HRULES|wxLC_REPORT|wxLC_VRULES
-
-
-
-
- wxSUNKEN_BORDER
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Global Design Rules
- 0
-
-
-
- 1
-
-
- 0
- wxID_ANY
-
-
- m_panelGolbalDesignRules
- protected
-
-
-
-
-
-
- wxSUNKEN_BORDER|wxTAB_TRAVERSAL
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- bpanelGlobRulesSizer
- wxVERTICAL
- none
-
- 5
- wxEXPAND
- 0
-
-
- bDesignRulesUpperSizer
- wxHORIZONTAL
- none
-
- 5
- wxALIGN_CENTER_VERTICAL
- 1
-
- wxID_ANY
- Via Options:
-
- sbViasOptionSizer
- wxVERTICAL
- none
-
-
- 5
- wxALL|wxEXPAND
- 0
-
-
- "Through via" "Blind or buried via"
-
- 1
-
-
- 0
- wxID_ANY
- Default Via Type
- 1
-
-
- m_OptViaType
- protected
-
- 0
-
- wxRA_SPECIFY_COLS
-
- Select the current via type.
Trough via is the usual selection
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxEXPAND
- 0
-
- 2
- wxBOTH
- 1
-
- 0
-
- fgViasMinValuesSizer
- wxFLEX_GROWMODE_SPECIFIED
- none
- 1
- 0
-
- 5
- wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT
- 0
-
-
-
- 1
-
-
- 0
- wxID_ANY
- Min via diameter
-
-
- m_ViaMinTitle
- protected
-
-
-
-
-
-
-
-
- -1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxEXPAND|wxALL
- 0
-
-
-
- 1
-
-
- 0
- wxID_ANY
-
- 0
-
- m_SetViasMinSizeCtrl
- protected
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxTOP|wxBOTTOM|wxLEFT|wxALIGN_RIGHT
- 0
-
-
-
- 1
-
-
- 0
- wxID_ANY
- Min via drill dia
-
-
- m_ViaMinDrillTitle
- protected
-
-
-
-
-
-
-
-
- -1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALL|wxEXPAND
- 0
-
-
-
- 1
-
-
- 0
- wxID_ANY
-
- 0
-
- m_SetViasMinDrillCtrl
- protected
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALIGN_CENTER_VERTICAL
- 1
-
- wxID_ANY
- Micro Via Options:
-
- sbuViasSizer
- wxVERTICAL
- none
-
-
- 5
- wxALL|wxEXPAND
- 0
-
-
- "Do not allow micro vias" "Allow micro vias"
-
- 1
-
-
- 0
- wxID_ANY
- Micro Vias:
- 1
-
-
- m_AllowMicroViaCtrl
- protected
-
- 0
-
- wxRA_SPECIFY_COLS
-
- Allows or do not allow use of micro vias
They are very small vias only from an external copper layer to its near neightbour
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxEXPAND
- 1
-
- 2
- wxBOTH
- 1
-
- 0
-
- fgMinMicroviasValuesSizer
- wxFLEX_GROWMODE_SPECIFIED
- none
- 1
- 0
-
- 5
- wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT
- 0
-
-
-
- 1
-
-
- 0
- wxID_ANY
- Min uvia diameter
-
-
- m_MicroViaMinSizeTitle
- protected
-
-
-
-
-
-
-
-
- -1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALL|wxEXPAND
- 0
-
-
-
- 1
-
-
- 0
- wxID_ANY
-
- 6
-
- m_SetMicroViasMinSizeCtrl
- protected
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT
- 0
-
-
-
- 1
-
-
- 0
- wxID_ANY
- Min uvia drill dia
-
-
- m_MicroViaMinDrillTitle
- protected
-
-
-
-
-
-
-
-
- -1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALL|wxEXPAND
- 0
-
-
-
- 1
-
-
- 0
- wxID_ANY
-
- 6
-
- m_SetMicroViasMinDrillCtrl
- protected
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxEXPAND
- 1
-
- wxID_ANY
- Minimum Allowed Values:
-
- sbMinSizesSizer
- wxVERTICAL
- none
-
-
- 5
-
- 0
-
- 2
- wxBOTH
- 1
-
- 0
-
- fgMinValuesSizer
- wxFLEX_GROWMODE_SPECIFIED
- none
- 1
- 0
-
- 5
- wxALIGN_CENTER_VERTICAL|wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT
- 0
-
-
-
- 1
-
-
- 0
- wxID_ANY
- Min track width
-
-
- m_TrackMinWidthTitle
- protected
-
-
-
-
-
-
-
-
- -1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALL|wxEXPAND
- 0
-
-
-
- 1
-
-
- 0
- wxID_ANY
-
- 0
-
- m_SetTrackMinWidthCtrl
- protected
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxEXPAND | wxALL
- 0
-
-
-
- 1
-
-
- 0
- wxID_ANY
-
-
- m_staticline1
- protected
-
-
- wxLI_HORIZONTAL
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALL|wxALIGN_CENTER_HORIZONTAL
- 0
-
-
-
- 1
-
-
- 0
- wxID_ANY
- Specific via diameters and track widths, which
can be used to replace default Netclass values
on demand, for arbitrary via or track segments.
-
-
- m_staticTextInfo
- protected
-
-
-
-
-
-
-
-
- -1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALIGN_CENTER_HORIZONTAL|wxEXPAND
- 0
-
-
- bDesignRulesLowerSizer
- wxHORIZONTAL
- none
-
- 5
- wxALIGN_CENTER_HORIZONTAL|wxALL|wxEXPAND
- 1
-
- wxID_ANY
- Custom Via Sizes:
-
- sViaSizeBox
- wxVERTICAL
- none
-
-
- 5
- wxALL
- 0
-
-
-
- 1
-
-
- 0
- wxID_ANY
- Drill value: a blank or 0 => default Netclass value
-
-
- m_staticText7
- protected
-
-
-
-
-
-
-
-
- -1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALL
- 0
-
- 0
- 0
-
-
-
- wxALIGN_LEFT
-
- wxALIGN_TOP
- wxALIGN_CENTRE
- 30
- "Diameter" "Drill"
- wxALIGN_CENTRE
- 2
-
-
- 0
- 1
- 0
- 1
- 1
- 1
-
-
-
- 1
- 0
- wxID_ANY
-
-
-
- 0
- 0
-
-
- m_gridViaSizeList
- protected
-
- wxALIGN_CENTRE
- 80
- "Via 1" "Via 2" "Via 3" "Via 4" "Via 5" "Via 6" "Via 7"
- wxALIGN_CENTRE
-
- 7
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALIGN_CENTER_HORIZONTAL|wxALL|wxEXPAND
- 1
-
- wxID_ANY
- Custom Track Widths:
-
- sbTracksListSizer
- wxVERTICAL
- none
-
-
- 5
- wxALL
- 0
-
-
-
- 1
-
-
- 0
- wxID_ANY
-
-
-
- m_staticText8
- protected
-
-
-
-
-
-
-
-
- -1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALL
- 0
-
- 0
- 0
-
-
-
- wxALIGN_LEFT
-
- wxALIGN_TOP
- wxALIGN_CENTRE
- 30
- "Width"
- wxALIGN_CENTRE
- 1
-
-
- 0
- 1
- 0
- 1
- 1
- 1
-
-
-
- 1
- 0
- wxID_ANY
-
-
-
- 0
- 0
-
-
- m_gridTrackWidthList
- protected
-
- wxALIGN_CENTRE
- 80
- "Track 1" "Track 2" "Track 3" "Track 4" "Track 5" "Track 6" "Track 7"
- wxALIGN_CENTRE
-
- 7
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxEXPAND|wxRIGHT|wxLEFT
- 0
-
- wxID_ANY
- Messages:
-
- sbSizer2
- wxHORIZONTAL
- none
-
-
- 5
- wxEXPAND
- 1
-
-
-
- 1
-
-
- 0
- wxID_ANY
-
- -1,90
- m_MessagesList
- protected
-
-
- wxHW_SCROLLBAR_AUTO
-
-
-
-
- wxSUNKEN_BORDER
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
-
- 0
-
-
- bSizerButtons
- wxVERTICAL
- none
-
- 5
- wxALL|wxEXPAND
- 0
-
-
-
- 1
- 1
-
-
- 0
- wxID_OK
- OK
-
-
- m_buttonOk
- protected
-
-
-
-
-
-
-
-
- OnOkButtonClick
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 5
- wxALL|wxEXPAND
- 0
-
-
-
- 0
- 1
-
-
- 0
- wxID_CANCEL
- Cancel
-
-
- m_buttonCancel
- protected
-
-
-
-
-
-
-
-
- OnCancelButtonClick
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+ C++
+ 1
+ UTF-8
+ connect
+ dialog_design_rules_base
+ 1000
+ none
+ 1
+ dialog_design_rules_base
+
+ .
+
+ 1
+ 1
+ 0
+
+
+
+
+ 1
+
+
+
+ 0
+ wxID_ANY
+
+ -1,-1
+ DIALOG_DESIGN_RULES_BASE
+
+ 777,640
+ wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER
+
+ Design Rules Editor
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ bMainSizer
+ wxVERTICAL
+ none
+
+ 5
+ wxEXPAND|wxRIGHT|wxLEFT
+ 1
+
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+
+
+ m_DRnotebook
+ protected
+
+
+ wxNB_TOP
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Net Classes Editor
+ 1
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+
+
+ m_panelNetClassesEditor
+ protected
+
+
+
+
+
+
+ wxSUNKEN_BORDER|wxTAB_TRAVERSAL
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ bpanelNetClassesSizer
+ wxVERTICAL
+ none
+
+ 5
+ wxRIGHT|wxLEFT|wxEXPAND
+ 1
+
+ wxID_ANY
+ Net Classes:
+
+ sbSizer1
+ wxVERTICAL
+ none
+
+
+ 5
+ wxEXPAND
+ 1
+
+ 0
+ 1
+
+
+
+ wxALIGN_LEFT
+
+ wxALIGN_TOP
+ wxALIGN_CENTRE
+ 40
+ "Clearance" "Track Width" "Via Dia" "Via Drill" "uVia Dia" "uVia Drill"
+ wxALIGN_CENTRE
+ 6
+ 100,120,84,85,81,90
+
+ 0
+ 1
+ 0
+ 1
+ 1
+ 1
+
+
+
+ 1
+ 0
+ wxID_ANY
+
+
+
+ 0
+ 0
+
+ -1,-1
+ m_grid
+ protected
+
+ wxALIGN_LEFT
+ 120
+ "Default"
+ wxALIGN_CENTRE
+
+ 1
+
+
+ Net Class parameters
+
+
+ wxHSCROLL|wxSIMPLE_BORDER|wxVSCROLL
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ OnNetClassesNameLeftClick
+
+ OnNetClassesNameRightClick
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALIGN_CENTER_HORIZONTAL|wxRIGHT|wxLEFT
+ 0
+
+
+ buttonBoxSizer
+ wxHORIZONTAL
+ none
+
+ 5
+ wxALIGN_CENTER_HORIZONTAL|wxTOP|wxRIGHT|wxLEFT
+ 0
+
+
+
+ 0
+ 1
+
+
+ 0
+ wxID_ADD_NETCLASS
+ Add
+
+
+ m_addButton
+ protected
+
+
+
+
+ Add another Net Class
+
+
+
+ OnAddNetclassClick
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALIGN_CENTER_HORIZONTAL|wxTOP|wxRIGHT|wxLEFT
+ 0
+
+
+
+ 0
+ 1
+
+
+ 0
+ wxID_REMOVE_NETCLASS
+ Remove
+
+
+ m_removeButton
+ protected
+
+
+
+
+ Remove the currently select Net Class
The default Net Class cannot be removed
+
+
+
+ OnRemoveNetclassClick
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxTOP|wxRIGHT|wxLEFT
+ 0
+
+
+
+ 0
+ 1
+
+
+ 0
+ wxID_ANY
+ Move Up
+
+
+ m_moveUpButton
+ protected
+
+
+
+
+ Move the currently selected Net Class up one row
+
+
+
+ OnMoveUpSelectedNetClass
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxEXPAND|wxRIGHT|wxLEFT
+ 2
+
+ wxID_ANY
+ Membership:
+
+ sbSizer4
+ wxHORIZONTAL
+ none
+
+
+ 5
+ wxEXPAND|wxRIGHT|wxLEFT
+ 1
+
+
+ leftNetSelectBoxSizer
+ wxVERTICAL
+ none
+
+ 5
+ wxEXPAND
+ 0
+
+
+
+
+ 1
+
+
+ 0
+ ID_LEFT_CHOICE_CLICK
+
+
+ m_leftClassChoice
+ protected
+
+ 0
+
+
+
+
+
+
+
+ OnLeftCBSelection
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxEXPAND|wxTOP
+ 1
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+
+ 220,200
+ m_leftListCtrl
+ protected
+
+
+ wxLC_HRULES|wxLC_REPORT|wxLC_VIRTUAL|wxLC_VRULES
+ NETS_LIST_CTRL; dialog_design_rules_aux_helper_class.h
+
+
+
+ wxSUNKEN_BORDER
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALIGN_CENTER_VERTICAL
+ 0
+
+
+ bmiddleSizerNetSelect
+ wxVERTICAL
+ none
+
+ 5
+ wxALL|wxALIGN_CENTER_HORIZONTAL
+ 0
+
+
+
+ 0
+ 1
+
+
+ 0
+ ID_LEFT_TO_RIGHT_COPY
+ <<<
+
+
+ m_buttonRightToLeft
+ protected
+
+
+
+
+ Move the selected nets in the right list to the left list
+
+
+
+ OnRightToLeftCopyButton
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALL|wxALIGN_CENTER_HORIZONTAL
+ 0
+
+
+
+ 0
+ 1
+
+
+ 0
+ ID_RIGHT_TO_LEFT_COPY
+ >>>
+
+
+ m_buttonLeftToRight
+ protected
+
+
+
+
+ Move the selected nets in the left list to the right list
+
+
+
+ OnLeftToRightCopyButton
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALL|wxALIGN_CENTER_HORIZONTAL
+ 0
+
+
+
+ 0
+ 1
+
+
+ 0
+ wxID_ANY
+ << Select All
+
+
+ m_buttonLeftSelAll
+ protected
+
+
+
+
+ Select all nets in the left list
+
+
+
+ OnLeftSelectAllButton
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALIGN_BOTTOM|wxALL|wxALIGN_CENTER_HORIZONTAL
+ 0
+
+
+
+ 0
+ 1
+
+
+ 0
+ wxID_ANY
+ Select All >>
+
+
+ m_buttonRightSelAll
+ protected
+
+
+
+
+ Select all nets in the right list
+
+
+
+ OnRightSelectAllButton
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxEXPAND|wxRIGHT|wxLEFT
+ 1
+
+
+ rghtNetSelectBoxSizer
+ wxVERTICAL
+ none
+
+ 5
+ wxEXPAND
+ 0
+
+
+
+
+ 1
+
+
+ 0
+ ID_RIGHT_CHOICE_CLICK
+
+
+ m_rightClassChoice
+ protected
+
+ 0
+
+
+
+
+
+
+
+ OnRightCBSelection
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxEXPAND|wxTOP
+ 1
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+
+ 220,-1
+ m_rightListCtrl
+ protected
+
+
+ wxLC_HRULES|wxLC_REPORT|wxLC_VIRTUAL|wxLC_VRULES
+ NETS_LIST_CTRL; dialog_design_rules_aux_helper_class.h
+
+
+
+ wxSUNKEN_BORDER
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Global Design Rules
+ 0
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+
+
+ m_panelGolbalDesignRules
+ protected
+
+
+
+
+
+
+ wxSUNKEN_BORDER|wxTAB_TRAVERSAL
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ bpanelGlobRulesSizer
+ wxVERTICAL
+ none
+
+ 5
+ wxEXPAND
+ 0
+
+
+ bDesignRulesUpperSizer
+ wxHORIZONTAL
+ none
+
+ 5
+ wxALIGN_CENTER_VERTICAL
+ 1
+
+ wxID_ANY
+ Via Options:
+
+ sbViasOptionSizer
+ wxVERTICAL
+ none
+
+
+ 5
+ wxALL|wxEXPAND
+ 0
+
+
+ "Through via" "Blind or buried via"
+
+ 1
+
+
+ 0
+ wxID_ANY
+ Default Via Type
+ 1
+
+
+ m_OptViaType
+ protected
+
+ 0
+
+ wxRA_SPECIFY_COLS
+
+ Select the current via type.
Trough via is the usual selection
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxEXPAND
+ 0
+
+ 2
+ wxBOTH
+ 1
+
+ 0
+
+ fgViasMinValuesSizer
+ wxFLEX_GROWMODE_SPECIFIED
+ none
+ 1
+ 0
+
+ 5
+ wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT
+ 0
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+ Min via diameter
+
+
+ m_ViaMinTitle
+ protected
+
+
+
+
+
+
+
+
+ -1
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxEXPAND|wxALL
+ 0
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+
+ 0
+
+ m_SetViasMinSizeCtrl
+ protected
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxTOP|wxBOTTOM|wxLEFT|wxALIGN_RIGHT
+ 0
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+ Min via drill dia
+
+
+ m_ViaMinDrillTitle
+ protected
+
+
+
+
+
+
+
+
+ -1
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALL|wxEXPAND
+ 0
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+
+ 0
+
+ m_SetViasMinDrillCtrl
+ protected
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALIGN_CENTER_VERTICAL
+ 1
+
+ wxID_ANY
+ Micro Via Options:
+
+ sbuViasSizer
+ wxVERTICAL
+ none
+
+
+ 5
+ wxALL|wxEXPAND
+ 0
+
+
+ "Do not allow micro vias" "Allow micro vias"
+
+ 1
+
+
+ 0
+ wxID_ANY
+ Micro Vias:
+ 1
+
+
+ m_AllowMicroViaCtrl
+ protected
+
+ 0
+
+ wxRA_SPECIFY_COLS
+
+ Allows or do not allow use of micro vias
They are very small vias only from an external copper layer to its near neightbour
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxEXPAND
+ 1
+
+ 2
+ wxBOTH
+ 1
+
+ 0
+
+ fgMinMicroviasValuesSizer
+ wxFLEX_GROWMODE_SPECIFIED
+ none
+ 1
+ 0
+
+ 5
+ wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxLEFT
+ 0
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+ Min uvia diameter
+
+
+ m_MicroViaMinSizeTitle
+ protected
+
+
+
+
+
+
+
+
+ -1
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALL|wxEXPAND
+ 0
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+
+ 6
+
+ m_SetMicroViasMinSizeCtrl
+ protected
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT
+ 0
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+ Min uvia drill dia
+
+
+ m_MicroViaMinDrillTitle
+ protected
+
+
+
+
+
+
+
+
+ -1
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALL|wxEXPAND
+ 0
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+
+ 6
+
+ m_SetMicroViasMinDrillCtrl
+ protected
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxEXPAND
+ 1
+
+ wxID_ANY
+ Minimum Allowed Values:
+
+ sbMinSizesSizer
+ wxVERTICAL
+ none
+
+
+ 5
+
+ 0
+
+ 2
+ wxBOTH
+ 1
+
+ 0
+
+ fgMinValuesSizer
+ wxFLEX_GROWMODE_SPECIFIED
+ none
+ 1
+ 0
+
+ 5
+ wxALIGN_CENTER_VERTICAL|wxALIGN_RIGHT|wxTOP|wxBOTTOM|wxLEFT
+ 0
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+ Min track width
+
+
+ m_TrackMinWidthTitle
+ protected
+
+
+
+
+
+
+
+
+ -1
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALL|wxEXPAND
+ 0
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+
+ 0
+
+ m_SetTrackMinWidthCtrl
+ protected
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxEXPAND | wxALL
+ 0
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+
+
+ m_staticline1
+ protected
+
+
+ wxLI_HORIZONTAL
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALL|wxALIGN_CENTER_HORIZONTAL
+ 0
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+ Specific via diameters and track widths, which
can be used to replace default Netclass values
on demand, for arbitrary via or track segments.
+
+
+ m_staticTextInfo
+ protected
+
+
+
+
+
+
+
+
+ -1
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALIGN_CENTER_HORIZONTAL|wxEXPAND
+ 0
+
+
+ bDesignRulesLowerSizer
+ wxHORIZONTAL
+ none
+
+ 5
+ wxALIGN_CENTER_HORIZONTAL|wxALL|wxEXPAND
+ 1
+
+ wxID_ANY
+ Custom Via Sizes:
+
+ sViaSizeBox
+ wxVERTICAL
+ none
+
+
+ 5
+ wxALL
+ 0
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+ Drill value: a blank or 0 => default Netclass value
+
+
+ m_staticText7
+ protected
+
+
+
+
+
+
+
+
+ -1
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALL
+ 0
+
+ 0
+ 0
+
+
+
+ wxALIGN_LEFT
+
+ wxALIGN_TOP
+ wxALIGN_CENTRE
+ 30
+ "Diameter" "Drill"
+ wxALIGN_CENTRE
+ 2
+
+
+ 0
+ 1
+ 0
+ 1
+ 1
+ 1
+
+
+
+ 1
+ 0
+ wxID_ANY
+
+
+
+ 0
+ 0
+
+
+ m_gridViaSizeList
+ protected
+
+ wxALIGN_CENTRE
+ 80
+ "Via 1" "Via 2" "Via 3" "Via 4" "Via 5" "Via 6" "Via 7"
+ wxALIGN_CENTRE
+
+ 7
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALIGN_CENTER_HORIZONTAL|wxALL|wxEXPAND
+ 1
+
+ wxID_ANY
+ Custom Track Widths:
+
+ sbTracksListSizer
+ wxVERTICAL
+ none
+
+
+ 5
+ wxALL
+ 0
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+
+
+
+ m_staticText8
+ protected
+
+
+
+
+
+
+
+
+ -1
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALL
+ 0
+
+ 0
+ 0
+
+
+
+ wxALIGN_LEFT
+
+ wxALIGN_TOP
+ wxALIGN_CENTRE
+ 30
+ "Width"
+ wxALIGN_CENTRE
+ 1
+
+
+ 0
+ 1
+ 0
+ 1
+ 1
+ 1
+
+
+
+ 1
+ 0
+ wxID_ANY
+
+
+
+ 0
+ 0
+
+
+ m_gridTrackWidthList
+ protected
+
+ wxALIGN_CENTRE
+ 80
+ "Track 1" "Track 2" "Track 3" "Track 4" "Track 5" "Track 6" "Track 7"
+ wxALIGN_CENTRE
+
+ 7
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxEXPAND|wxRIGHT|wxLEFT
+ 0
+
+ wxID_ANY
+ Messages:
+
+ sbSizer2
+ wxHORIZONTAL
+ none
+
+
+ 5
+ wxEXPAND
+ 1
+
+
+
+ 1
+
+
+ 0
+ wxID_ANY
+
+ -1,90
+ m_MessagesList
+ protected
+
+
+ wxHW_SCROLLBAR_AUTO
+
+
+
+
+ wxSUNKEN_BORDER
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+
+ 0
+
+
+ bSizerButtons
+ wxVERTICAL
+ none
+
+ 5
+ wxALL|wxEXPAND
+ 0
+
+
+
+ 1
+ 1
+
+
+ 0
+ wxID_OK
+ OK
+
+
+ m_buttonOk
+ protected
+
+
+
+
+
+
+
+
+ OnOkButtonClick
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+ wxALL|wxEXPAND
+ 0
+
+
+
+ 0
+ 1
+
+
+ 0
+ wxID_CANCEL
+ Cancel
+
+
+ m_buttonCancel
+ protected
+
+
+
+
+
+
+
+
+ OnCancelButtonClick
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/pcbnew/dialog_design_rules_base.h b/pcbnew/dialog_design_rules_base.h
index 7bdb416e7a..07153b5f38 100644
--- a/pcbnew/dialog_design_rules_base.h
+++ b/pcbnew/dialog_design_rules_base.h
@@ -1,115 +1,117 @@
-///////////////////////////////////////////////////////////////////////////
-// C++ code generated with wxFormBuilder (version Apr 16 2008)
-// http://www.wxformbuilder.org/
-//
-// PLEASE DO "NOT" EDIT THIS FILE!
-///////////////////////////////////////////////////////////////////////////
-
-#ifndef __dialog_design_rules_base__
-#define __dialog_design_rules_base__
-
-#include
-
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-
-///////////////////////////////////////////////////////////////////////////
-
-///////////////////////////////////////////////////////////////////////////////
-/// Class DIALOG_DESIGN_RULES_BASE
-///////////////////////////////////////////////////////////////////////////////
-class DIALOG_DESIGN_RULES_BASE : public wxDialog
-{
- private:
-
- protected:
- enum
- {
- wxID_ADD_NETCLASS = 1000,
- wxID_REMOVE_NETCLASS,
- ID_LEFT_CHOICE_CLICK,
- ID_LEFT_TO_RIGHT_COPY,
- ID_RIGHT_TO_LEFT_COPY,
- ID_RIGHT_CHOICE_CLICK,
- };
-
- wxNotebook* m_DRnotebook;
- wxPanel* m_panelNetClassesEditor;
- wxGrid* m_grid;
- wxButton* m_addButton;
- wxButton* m_removeButton;
- wxButton* m_moveUpButton;
- wxChoice* m_leftClassChoice;
- wxListCtrl* m_leftListCtrl;
- wxButton* m_buttonRightToLeft;
- wxButton* m_buttonLeftToRight;
- wxButton* m_buttonLeftSelAll;
- wxButton* m_buttonRightSelAll;
- wxChoice* m_rightClassChoice;
- wxListCtrl* m_rightListCtrl;
- wxPanel* m_panelGolbalDesignRules;
- wxRadioBox* m_OptViaType;
- wxStaticText* m_ViaMinTitle;
- wxTextCtrl* m_SetViasMinSizeCtrl;
- wxStaticText* m_ViaMinDrillTitle;
- wxTextCtrl* m_SetViasMinDrillCtrl;
- wxRadioBox* m_AllowMicroViaCtrl;
- wxStaticText* m_MicroViaMinSizeTitle;
- wxTextCtrl* m_SetMicroViasMinSizeCtrl;
- wxStaticText* m_MicroViaMinDrillTitle;
- wxTextCtrl* m_SetMicroViasMinDrillCtrl;
- wxStaticText* m_TrackMinWidthTitle;
- wxTextCtrl* m_SetTrackMinWidthCtrl;
- wxStaticLine* m_staticline1;
- wxStaticText* m_staticTextInfo;
- wxStaticText* m_staticText7;
- wxGrid* m_gridViaSizeList;
- wxStaticText* m_staticText8;
- wxGrid* m_gridTrackWidthList;
- wxHtmlWindow* m_MessagesList;
- wxButton* m_buttonOk;
- wxButton* m_buttonCancel;
-
- // Virtual event handlers, overide them in your derived class
- virtual void OnNetClassesNameLeftClick( wxGridEvent& event ){ event.Skip(); }
- virtual void OnNetClassesNameRightClick( wxGridEvent& event ){ event.Skip(); }
- virtual void OnAddNetclassClick( wxCommandEvent& event ){ event.Skip(); }
- virtual void OnRemoveNetclassClick( wxCommandEvent& event ){ event.Skip(); }
- virtual void OnMoveUpSelectedNetClass( wxCommandEvent& event ){ event.Skip(); }
- virtual void OnLeftCBSelection( wxCommandEvent& event ){ event.Skip(); }
- virtual void OnRightToLeftCopyButton( wxCommandEvent& event ){ event.Skip(); }
- virtual void OnLeftToRightCopyButton( wxCommandEvent& event ){ event.Skip(); }
- virtual void OnLeftSelectAllButton( wxCommandEvent& event ){ event.Skip(); }
- virtual void OnRightSelectAllButton( wxCommandEvent& event ){ event.Skip(); }
- virtual void OnRightCBSelection( wxCommandEvent& event ){ event.Skip(); }
- virtual void OnOkButtonClick( wxCommandEvent& event ){ event.Skip(); }
- virtual void OnCancelButtonClick( wxCommandEvent& event ){ event.Skip(); }
-
-
- public:
- DIALOG_DESIGN_RULES_BASE( wxWindow* parent, wxWindowID id = wxID_ANY, const wxString& title = _("Design Rules Editor"), const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxSize( 777,640 ), long style = wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER );
- ~DIALOG_DESIGN_RULES_BASE();
-
-};
-
-#endif //__dialog_design_rules_base__
+///////////////////////////////////////////////////////////////////////////
+// C++ code generated with wxFormBuilder (version Apr 16 2008)
+// http://www.wxformbuilder.org/
+//
+// PLEASE DO "NOT" EDIT THIS FILE!
+///////////////////////////////////////////////////////////////////////////
+
+#ifndef __dialog_design_rules_base__
+#define __dialog_design_rules_base__
+
+#include
+
+class NETS_LIST_CTRL;
+
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+
+///////////////////////////////////////////////////////////////////////////
+
+///////////////////////////////////////////////////////////////////////////////
+/// Class DIALOG_DESIGN_RULES_BASE
+///////////////////////////////////////////////////////////////////////////////
+class DIALOG_DESIGN_RULES_BASE : public wxDialog
+{
+ private:
+
+ protected:
+ enum
+ {
+ wxID_ADD_NETCLASS = 1000,
+ wxID_REMOVE_NETCLASS,
+ ID_LEFT_CHOICE_CLICK,
+ ID_LEFT_TO_RIGHT_COPY,
+ ID_RIGHT_TO_LEFT_COPY,
+ ID_RIGHT_CHOICE_CLICK,
+ };
+
+ wxNotebook* m_DRnotebook;
+ wxPanel* m_panelNetClassesEditor;
+ wxGrid* m_grid;
+ wxButton* m_addButton;
+ wxButton* m_removeButton;
+ wxButton* m_moveUpButton;
+ wxChoice* m_leftClassChoice;
+ NETS_LIST_CTRL* m_leftListCtrl;
+ wxButton* m_buttonRightToLeft;
+ wxButton* m_buttonLeftToRight;
+ wxButton* m_buttonLeftSelAll;
+ wxButton* m_buttonRightSelAll;
+ wxChoice* m_rightClassChoice;
+ NETS_LIST_CTRL* m_rightListCtrl;
+ wxPanel* m_panelGolbalDesignRules;
+ wxRadioBox* m_OptViaType;
+ wxStaticText* m_ViaMinTitle;
+ wxTextCtrl* m_SetViasMinSizeCtrl;
+ wxStaticText* m_ViaMinDrillTitle;
+ wxTextCtrl* m_SetViasMinDrillCtrl;
+ wxRadioBox* m_AllowMicroViaCtrl;
+ wxStaticText* m_MicroViaMinSizeTitle;
+ wxTextCtrl* m_SetMicroViasMinSizeCtrl;
+ wxStaticText* m_MicroViaMinDrillTitle;
+ wxTextCtrl* m_SetMicroViasMinDrillCtrl;
+ wxStaticText* m_TrackMinWidthTitle;
+ wxTextCtrl* m_SetTrackMinWidthCtrl;
+ wxStaticLine* m_staticline1;
+ wxStaticText* m_staticTextInfo;
+ wxStaticText* m_staticText7;
+ wxGrid* m_gridViaSizeList;
+ wxStaticText* m_staticText8;
+ wxGrid* m_gridTrackWidthList;
+ wxHtmlWindow* m_MessagesList;
+ wxButton* m_buttonOk;
+ wxButton* m_buttonCancel;
+
+ // Virtual event handlers, overide them in your derived class
+ virtual void OnNetClassesNameLeftClick( wxGridEvent& event ){ event.Skip(); }
+ virtual void OnNetClassesNameRightClick( wxGridEvent& event ){ event.Skip(); }
+ virtual void OnAddNetclassClick( wxCommandEvent& event ){ event.Skip(); }
+ virtual void OnRemoveNetclassClick( wxCommandEvent& event ){ event.Skip(); }
+ virtual void OnMoveUpSelectedNetClass( wxCommandEvent& event ){ event.Skip(); }
+ virtual void OnLeftCBSelection( wxCommandEvent& event ){ event.Skip(); }
+ virtual void OnRightToLeftCopyButton( wxCommandEvent& event ){ event.Skip(); }
+ virtual void OnLeftToRightCopyButton( wxCommandEvent& event ){ event.Skip(); }
+ virtual void OnLeftSelectAllButton( wxCommandEvent& event ){ event.Skip(); }
+ virtual void OnRightSelectAllButton( wxCommandEvent& event ){ event.Skip(); }
+ virtual void OnRightCBSelection( wxCommandEvent& event ){ event.Skip(); }
+ virtual void OnOkButtonClick( wxCommandEvent& event ){ event.Skip(); }
+ virtual void OnCancelButtonClick( wxCommandEvent& event ){ event.Skip(); }
+
+
+ public:
+ DIALOG_DESIGN_RULES_BASE( wxWindow* parent, wxWindowID id = wxID_ANY, const wxString& title = _("Design Rules Editor"), const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxSize( 777,640 ), long style = wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER );
+ ~DIALOG_DESIGN_RULES_BASE();
+
+};
+
+#endif //__dialog_design_rules_base__