more fp_lib_table work
This commit is contained in:
parent
58299fc921
commit
9e41a8127d
|
@ -100,7 +100,9 @@ public:
|
||||||
|
|
||||||
typedef IO_MGR::PCB_FILE_T LIB_T;
|
typedef IO_MGR::PCB_FILE_T LIB_T;
|
||||||
|
|
||||||
ROW(){}
|
ROW() : type( IO_MGR::KICAD )
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
ROW( const wxString& aNick, const wxString& aURI, const wxString& aType, const wxString& aOptions ) :
|
ROW( const wxString& aNick, const wxString& aURI, const wxString& aType, const wxString& aOptions ) :
|
||||||
nickName( aNick ),
|
nickName( aNick ),
|
||||||
|
@ -222,6 +224,23 @@ public:
|
||||||
*/
|
*/
|
||||||
FP_LIB_TABLE( FP_LIB_TABLE* aFallBackTable = NULL );
|
FP_LIB_TABLE( FP_LIB_TABLE* aFallBackTable = NULL );
|
||||||
|
|
||||||
|
bool operator==( const FP_LIB_TABLE& r ) const
|
||||||
|
{
|
||||||
|
if( rows.size() == r.rows.size() )
|
||||||
|
{
|
||||||
|
unsigned i;
|
||||||
|
for( i = 0; i < rows.size() && rows[i] == r.rows[i]; ++i )
|
||||||
|
;
|
||||||
|
|
||||||
|
if( i == rows.size() )
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool operator!=( const FP_LIB_TABLE& r ) const { return !( *this == r ); }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Function Parse
|
* Function Parse
|
||||||
* fills this table fragment from information in the input stream \a aParser, which
|
* fills this table fragment from information in the input stream \a aParser, which
|
||||||
|
|
|
@ -28,13 +28,12 @@
|
||||||
#include <dialog_fp_lib_table_base.h>
|
#include <dialog_fp_lib_table_base.h>
|
||||||
#include <fp_lib_table.h>
|
#include <fp_lib_table.h>
|
||||||
#include <wx/grid.h>
|
#include <wx/grid.h>
|
||||||
#include <wx/grid.h>
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class FP_TBL_MODEL
|
* Class FP_TBL_MODEL
|
||||||
* mixes in wxGridTableBase into FP_LIB_TABLE so that the latter can be used
|
* mixes in wxGridTableBase into FP_LIB_TABLE so that the latter can be used
|
||||||
* as table within wxGrid.
|
* as a table within wxGrid.
|
||||||
*/
|
*/
|
||||||
class FP_TBL_MODEL : public wxGridTableBase, public FP_LIB_TABLE
|
class FP_TBL_MODEL : public wxGridTableBase, public FP_LIB_TABLE
|
||||||
{
|
{
|
||||||
|
@ -42,23 +41,14 @@ public:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor FP_TBL_MODEL
|
* Constructor FP_TBL_MODEL
|
||||||
* builds a wxGridTableBase (table model) by wrapping an FP_LIB_TABLE.
|
* is a copy constructor that builds a wxGridTableBase (table model) by wrapping
|
||||||
* @a aFallBackTable. Loading of this table fragment is done by using Parse().
|
* an FP_LIB_TABLE.
|
||||||
*
|
|
||||||
* @param aFallBackTable is another FP_LIB_TABLE which is searched only when
|
|
||||||
* a record is not found in this table. No ownership is
|
|
||||||
* taken of aFallBackTable.
|
|
||||||
*/
|
*/
|
||||||
FP_TBL_MODEL( const FP_LIB_TABLE& aTableToEdit ) :
|
FP_TBL_MODEL( const FP_LIB_TABLE& aTableToEdit ) :
|
||||||
FP_LIB_TABLE( aTableToEdit ) // copy constructor
|
FP_LIB_TABLE( aTableToEdit ) // copy constructor
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
~FP_TBL_MODEL()
|
|
||||||
{
|
|
||||||
D(printf("%s\n", __func__ );)
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----<wxGridTableBase overloads>-------------------------------------------
|
//-----<wxGridTableBase overloads>-------------------------------------------
|
||||||
|
|
||||||
int GetNumberRows () { return rows.size(); }
|
int GetNumberRows () { return rows.size(); }
|
||||||
|
@ -93,8 +83,8 @@ public:
|
||||||
switch( aCol )
|
switch( aCol )
|
||||||
{
|
{
|
||||||
case 0: r.SetNickName( aValue ); break;
|
case 0: r.SetNickName( aValue ); break;
|
||||||
case 1: r.SetType( aValue ); break;
|
case 1: r.SetFullURI( aValue ); break;
|
||||||
case 2: r.SetFullURI( aValue ); break;
|
case 2: r.SetType( aValue ); break;
|
||||||
case 3: r.SetOptions( aValue ); break;
|
case 3: r.SetOptions( aValue ); break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -112,6 +102,18 @@ public:
|
||||||
if( aPos < rows.size() )
|
if( aPos < rows.size() )
|
||||||
{
|
{
|
||||||
rows.insert( rows.begin() + aPos, aNumRows, ROW() );
|
rows.insert( rows.begin() + aPos, aNumRows, ROW() );
|
||||||
|
|
||||||
|
// use the (wxGridStringTable) source Luke.
|
||||||
|
if( GetView() )
|
||||||
|
{
|
||||||
|
wxGridTableMessage msg( this,
|
||||||
|
wxGRIDTABLE_NOTIFY_ROWS_INSERTED,
|
||||||
|
aPos,
|
||||||
|
aNumRows );
|
||||||
|
|
||||||
|
GetView()->ProcessTableMessage( msg );
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
@ -119,8 +121,19 @@ public:
|
||||||
|
|
||||||
bool AppendRows( size_t aNumRows = 1 )
|
bool AppendRows( size_t aNumRows = 1 )
|
||||||
{
|
{
|
||||||
while( aNumRows-- )
|
// do not modify aNumRows, original value needed for wxGridTableMessage below
|
||||||
|
for( int i = aNumRows; i; --i )
|
||||||
rows.push_back( ROW() );
|
rows.push_back( ROW() );
|
||||||
|
|
||||||
|
if( GetView() )
|
||||||
|
{
|
||||||
|
wxGridTableMessage msg( this,
|
||||||
|
wxGRIDTABLE_NOTIFY_ROWS_APPENDED,
|
||||||
|
aNumRows );
|
||||||
|
|
||||||
|
GetView()->ProcessTableMessage( msg );
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -130,6 +143,17 @@ public:
|
||||||
{
|
{
|
||||||
ROWS_ITER start = rows.begin() + aPos;
|
ROWS_ITER start = rows.begin() + aPos;
|
||||||
rows.erase( start, start + aNumRows );
|
rows.erase( start, start + aNumRows );
|
||||||
|
|
||||||
|
if( GetView() )
|
||||||
|
{
|
||||||
|
wxGridTableMessage msg( this,
|
||||||
|
wxGRIDTABLE_NOTIFY_ROWS_DELETED,
|
||||||
|
aPos,
|
||||||
|
aNumRows );
|
||||||
|
|
||||||
|
GetView()->ProcessTableMessage( msg );
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
@ -168,6 +192,39 @@ class DIALOG_FP_LIB_TABLE : public DIALOG_FP_LIB_TABLE_BASE
|
||||||
{
|
{
|
||||||
typedef FP_LIB_TABLE::ROW ROW;
|
typedef FP_LIB_TABLE::ROW ROW;
|
||||||
|
|
||||||
|
/* row & col "selection" acquisition, not currently used but works.
|
||||||
|
// selected area by cell coordinate and count
|
||||||
|
int selRowStart;
|
||||||
|
int selColStart;
|
||||||
|
int selRowCount;
|
||||||
|
int selColCount;
|
||||||
|
|
||||||
|
/// Gets the selected area into a sensible rectable of sel{Row,Col}{Start,Count} above.
|
||||||
|
void getSelectedArea()
|
||||||
|
{
|
||||||
|
wxGridCellCoordsArray topLeft = m_cur_grid->GetSelectionBlockTopLeft();
|
||||||
|
wxGridCellCoordsArray botRight = m_cur_grid->GetSelectionBlockBottomRight();
|
||||||
|
|
||||||
|
if( topLeft.Count() && botRight.Count() )
|
||||||
|
{
|
||||||
|
selRowStart = topLeft[0].GetRow();
|
||||||
|
selColStart = topLeft[0].GetCol();
|
||||||
|
|
||||||
|
selRowCount = botRight[0].GetRow() - selRowStart + 1;
|
||||||
|
selColCount = botRight[0].GetCol() - selColStart + 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
selRowStart = -1;
|
||||||
|
selColStart = -1;
|
||||||
|
selRowCount = 0;
|
||||||
|
selColCount = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
D(printf("selRowStart:%d selColStart:%d selRowCount:%d selColCount:%d\n",
|
||||||
|
selRowStart, selColStart, selRowCount, selColCount );)
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
//-----<event handlers>----------------------------------
|
//-----<event handlers>----------------------------------
|
||||||
|
|
||||||
|
@ -175,22 +232,52 @@ class DIALOG_FP_LIB_TABLE : public DIALOG_FP_LIB_TABLE_BASE
|
||||||
{
|
{
|
||||||
int pageNdx = m_auinotebook->GetSelection();
|
int pageNdx = m_auinotebook->GetSelection();
|
||||||
|
|
||||||
m_cur_grid = pageNdx ? m_global_grid : m_project_grid;
|
m_cur_grid = pageNdx==0 ? m_global_grid : m_project_grid;
|
||||||
|
|
||||||
|
D(printf("%s cur_grid is %s\n", __func__, pageNdx==0 ? "global" : "project" );)
|
||||||
}
|
}
|
||||||
|
|
||||||
void appendRowHandler( wxMouseEvent& event )
|
void appendRowHandler( wxMouseEvent& event )
|
||||||
{
|
{
|
||||||
D(printf("%s\n", __func__);)
|
D(printf("%s\n", __func__);)
|
||||||
|
m_cur_grid->AppendRows( 1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
void deleteRowHandler( wxMouseEvent& event )
|
void deleteRowHandler( wxMouseEvent& event )
|
||||||
{
|
{
|
||||||
D(printf("%s\n", __func__);)
|
D(printf("%s\n", __func__);)
|
||||||
|
|
||||||
|
int curRow = m_cur_grid->GetGridCursorRow();
|
||||||
|
|
||||||
|
m_cur_grid->DeleteRows( curRow );
|
||||||
}
|
}
|
||||||
|
|
||||||
void moveUpHandler( wxMouseEvent& event )
|
void moveUpHandler( wxMouseEvent& event )
|
||||||
{
|
{
|
||||||
D(printf("%s\n", __func__);)
|
D(printf("%s\n", __func__);)
|
||||||
|
|
||||||
|
int curRow = m_cur_grid->GetGridCursorRow();
|
||||||
|
if( curRow >= 1 )
|
||||||
|
{
|
||||||
|
FP_TBL_MODEL* tbl = (FP_TBL_MODEL*) m_cur_grid->GetTable();
|
||||||
|
|
||||||
|
ROW save = tbl->rows[curRow];
|
||||||
|
|
||||||
|
tbl->DeleteRows( curRow, 1 );
|
||||||
|
tbl->InsertRows( --curRow, 1 );
|
||||||
|
|
||||||
|
tbl->rows[curRow] = save;
|
||||||
|
|
||||||
|
if( tbl->GetView() )
|
||||||
|
{
|
||||||
|
wxGridTableMessage msg( tbl,
|
||||||
|
wxGRIDTABLE_NOTIFY_ROWS_INSERTED,
|
||||||
|
curRow,
|
||||||
|
0 );
|
||||||
|
|
||||||
|
tbl->GetView()->ProcessTableMessage( msg );
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void moveDownHandler( wxMouseEvent& event )
|
void moveDownHandler( wxMouseEvent& event )
|
||||||
|
@ -200,19 +287,31 @@ class DIALOG_FP_LIB_TABLE : public DIALOG_FP_LIB_TABLE_BASE
|
||||||
|
|
||||||
void onCancelButtonClick( wxCommandEvent& event )
|
void onCancelButtonClick( wxCommandEvent& event )
|
||||||
{
|
{
|
||||||
EndModal( wxID_CANCEL );
|
EndModal( 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
void onOKButtonClick( wxCommandEvent& event )
|
void onOKButtonClick( wxCommandEvent& event )
|
||||||
{
|
{
|
||||||
|
int dialogRet = 0;
|
||||||
|
|
||||||
|
if( m_global_model != *m_global )
|
||||||
|
{
|
||||||
|
dialogRet |= 1;
|
||||||
|
|
||||||
*m_global = m_global_model;
|
*m_global = m_global_model;
|
||||||
*m_project = m_project_model;
|
m_global->reindex();
|
||||||
|
|
||||||
// @todo reindex, or add member function for wholesale row replacement
|
|
||||||
|
|
||||||
EndModal( wxID_OK );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if( m_project_model != *m_project )
|
||||||
|
{
|
||||||
|
dialogRet |= 2;
|
||||||
|
|
||||||
|
*m_project = m_project_model;
|
||||||
|
m_project->reindex();
|
||||||
|
}
|
||||||
|
|
||||||
|
EndModal( dialogRet );
|
||||||
|
}
|
||||||
|
|
||||||
//-----</event handlers>---------------------------------
|
//-----</event handlers>---------------------------------
|
||||||
|
|
||||||
|
@ -244,6 +343,10 @@ public:
|
||||||
m_project_grid->AutoSizeColumns( false );
|
m_project_grid->AutoSizeColumns( false );
|
||||||
|
|
||||||
m_path_subs_grid->AutoSizeColumns( false );
|
m_path_subs_grid->AutoSizeColumns( false );
|
||||||
|
|
||||||
|
// fire pageChangedHandler() so m_cur_grid gets set
|
||||||
|
wxAuiNotebookEvent uneventful;
|
||||||
|
pageChangedHandler( uneventful );
|
||||||
}
|
}
|
||||||
|
|
||||||
~DIALOG_FP_LIB_TABLE()
|
~DIALOG_FP_LIB_TABLE()
|
||||||
|
@ -264,16 +367,8 @@ int InvokePcbLibTableEditor( wxFrame* aParent, FP_LIB_TABLE* aGlobal, FP_LIB_TAB
|
||||||
{
|
{
|
||||||
DIALOG_FP_LIB_TABLE dlg( aParent, aGlobal, aProject );
|
DIALOG_FP_LIB_TABLE dlg( aParent, aGlobal, aProject );
|
||||||
|
|
||||||
int ret = dlg.ShowModal();
|
int dialogRet = dlg.ShowModal(); // returns value passed to EndModal() above
|
||||||
switch( ret )
|
|
||||||
{
|
|
||||||
case wxID_OK:
|
|
||||||
break;
|
|
||||||
|
|
||||||
case wxID_CANCEL:
|
return dialogRet;
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -102,11 +102,13 @@ void PCB_EDIT_FRAME::Process_Config( wxCommandEvent& event )
|
||||||
if( r & 1 )
|
if( r & 1 )
|
||||||
{
|
{
|
||||||
// save global table to disk and apply it
|
// save global table to disk and apply it
|
||||||
|
D( printf( "global has changed\n" );)
|
||||||
}
|
}
|
||||||
|
|
||||||
if( r & 2 )
|
if( r & 2 )
|
||||||
{
|
{
|
||||||
// save project table to disk and apply it
|
// save project table to disk and apply it
|
||||||
|
D( printf( "project has changed\n" );)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in New Issue