diff options
Diffstat (limited to 'cvpcb/dialogs/dialog_config_equfiles.cpp')
-rw-r--r-- | cvpcb/dialogs/dialog_config_equfiles.cpp | 308 |
1 files changed, 308 insertions, 0 deletions
diff --git a/cvpcb/dialogs/dialog_config_equfiles.cpp b/cvpcb/dialogs/dialog_config_equfiles.cpp new file mode 100644 index 0000000..3ae03fd --- /dev/null +++ b/cvpcb/dialogs/dialog_config_equfiles.cpp @@ -0,0 +1,308 @@ +/** + * @file dialog_config_equfiles.cpp + */ + +/* + * This program source code file is part of KiCad, a free EDA CAD application. + * + * Copyright (C) 2015 Jean-Pierre Charras, jp.charras at wanadoo.fr + * Copyright (C) 1992-2015 KiCad Developers, see AUTHORS.txt for contributors. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, you may find one here: + * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html + * or you may search the http://www.gnu.org website for the version 2 license, + * or you may write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA + */ + +#include <fctsys.h> +#include <pgm_base.h> +#include <common.h> +#include <confirm.h> +#include <gestfich.h> +#include <id.h> +#include <project.h> // For PROJECT_VAR_NAME definition +#include <fp_lib_table.h> // For KISYSMOD definition + +#include <cvpcb.h> +#include <cvpcb_mainframe.h> + +#include <dialog_config_equfiles.h> +#include <wildcards_and_files_ext.h> + + +DIALOG_CONFIG_EQUFILES::DIALOG_CONFIG_EQUFILES( CVPCB_MAINFRAME* aParent ) : + DIALOG_CONFIG_EQUFILES_BASE( aParent ) +{ + m_Parent = aParent; + m_Config = Pgm().CommonSettings(); + + PROJECT& prj = Prj(); + SetTitle( wxString::Format( _( "Project file: '%s'" ), GetChars( prj.GetProjectFullName() ) ) ); + + Init( ); + + GetSizer()->SetSizeHints( this ); + Center(); +} + +void CVPCB_MAINFRAME::OnEditEquFilesList( wxCommandEvent& aEvent ) +{ + DIALOG_CONFIG_EQUFILES dlg( this ); + + dlg.ShowModal(); +} + + +void DIALOG_CONFIG_EQUFILES::Init() +{ + m_sdbSizerOK->SetDefault(); + m_ListChanged = false; + m_ListEquiv->InsertItems( m_Parent->m_EquFilesNames, 0 ); + + if( getEnvVarCount() < 2 ) + m_gridEnvVars->AppendRows(2 - getEnvVarCount() ); + + wxString evValue; + int row = 0; + + m_gridEnvVars->SetCellValue( row++, 0, PROJECT_VAR_NAME ); + m_gridEnvVars->SetCellValue( row, 0, FP_LIB_TABLE::GlobalPathEnvVariableName() ); + + for( row = 0; row < getEnvVarCount(); row++ ) + { + if( wxGetEnv( m_gridEnvVars->GetCellValue( row, 0 ), &evValue ) ) + m_gridEnvVars->SetCellValue( row, 1, evValue ); + } + + m_gridEnvVars->AutoSizeColumns(); + +} + +void DIALOG_CONFIG_EQUFILES::OnEditEquFile( wxCommandEvent& event ) +{ + wxString editorname = Pgm().GetEditorName(); + + if( editorname.IsEmpty() ) + { + wxMessageBox( _( "No editor defined in Kicad. Please chose it" ) ); + return; + } + + wxArrayInt selections; + m_ListEquiv->GetSelections( selections ); + + wxString fullFileNames, tmp; + + for( unsigned ii = 0; ii < selections.GetCount(); ii++ ) + { + tmp = m_ListEquiv->GetString( selections[ii] ); + fullFileNames << wxT( " \"" ) << wxExpandEnvVars( tmp ) << wxT( "\"" ); + m_ListChanged = true; + } + + ExecuteFile( this, editorname, fullFileNames ); +} + + +void DIALOG_CONFIG_EQUFILES::OnCancelClick( wxCommandEvent& event ) +{ + EndModal( wxID_CANCEL ); +} + + +void DIALOG_CONFIG_EQUFILES::OnOkClick( wxCommandEvent& event ) +{ + // Save new equ file list if the files list was modified + if( m_ListChanged ) + { + // Recreate equ list + m_Parent->m_EquFilesNames.Clear(); + + for( unsigned ii = 0; ii < m_ListEquiv->GetCount(); ii++ ) + m_Parent->m_EquFilesNames.Add( m_ListEquiv->GetString( ii ) ); + + wxCommandEvent evt( ID_SAVE_PROJECT ); + m_Parent->SaveProjectFile( evt ); + } + + EndModal( wxID_OK ); +} + + +void DIALOG_CONFIG_EQUFILES::OnCloseWindow( wxCloseEvent& event ) +{ + EndModal( wxID_CANCEL ); +} + + +/********************************************************************/ +void DIALOG_CONFIG_EQUFILES::OnButtonMoveUp( wxCommandEvent& event ) +/********************************************************************/ +{ + wxArrayInt selections; + + m_ListEquiv->GetSelections( selections ); + + if ( selections.GetCount() <= 0 ) // No selection. + return; + + if( selections[0] == 0 ) // The first lib is selected. cannot move up it + return; + + wxArrayString libnames = m_ListEquiv->GetStrings(); + + for( size_t ii = 0; ii < selections.GetCount(); ii++ ) + { + int jj = selections[ii]; + std::swap( libnames[jj], libnames[jj-1] ); + } + + m_ListEquiv->Set( libnames ); + + // Reselect previously selected names + for( size_t ii = 0; ii < selections.GetCount(); ii++ ) + { + int jj = selections[ii]; + m_ListEquiv->SetSelection( jj-1 ); + } + + m_ListChanged = true; +} + + +/*********************************************************************/ +void DIALOG_CONFIG_EQUFILES::OnButtonMoveDown( wxCommandEvent& event ) +/*********************************************************************/ +{ + wxArrayInt selections; + m_ListEquiv->GetSelections( selections ); + + if ( selections.GetCount() <= 0 ) // No selection. + return; + + // The last lib is selected. cannot move down it + if( selections.Last() == int( m_ListEquiv->GetCount()-1 ) ) + return; + + wxArrayString libnames = m_ListEquiv->GetStrings(); + + for( int ii = selections.GetCount()-1; ii >= 0; ii-- ) + { + int jj = selections[ii]; + std::swap( libnames[jj], libnames[jj+1]); + } + + m_ListEquiv->Set( libnames ); + + // Reselect previously selected names + for( size_t ii = 0; ii < selections.GetCount(); ii++ ) + { + int jj = selections[ii]; + m_ListEquiv->SetSelection(jj+1); + } + + m_ListChanged = true; +} + + +/* Remove a library to the library list. + * The real list (g_LibName_List) is not changed, so the change can be canceled + */ +void DIALOG_CONFIG_EQUFILES::OnRemoveFiles( wxCommandEvent& event ) +{ + wxArrayInt selections; + m_ListEquiv->GetSelections( selections ); + + std::sort( selections.begin(), selections.end() ); + + for( int ii = selections.GetCount()-1; ii >= 0; ii-- ) + { + m_ListEquiv->Delete(selections[ii] ); + m_ListChanged = true; + } +} + + +/* Insert or add a library to the library list: + * The new library is put in list before (insert button) the selection, + * or added (add button) to end of list + */ +void DIALOG_CONFIG_EQUFILES::OnAddFiles( wxCommandEvent& event ) +{ + wxString equFilename, wildcard; + wxFileName fn; + + wildcard = EquFilesWildcard; + wxListBox* list = m_ListEquiv; + + // Get a default path to open the file dialog: + wxString libpath; + wxArrayInt selectedRows = m_gridEnvVars->GetSelectedRows(); + + int row = selectedRows.GetCount() ? selectedRows[0] : + m_gridEnvVars->GetGridCursorRow(); + + libpath = m_gridEnvVars->GetCellValue( wxGridCellCoords( row, 1 ) ); + + wxFileDialog FilesDialog( this, _( "Equ files:" ), libpath, + wxEmptyString, wildcard, + wxFD_DEFAULT_STYLE | wxFD_MULTIPLE ); + + if( FilesDialog.ShowModal() != wxID_OK ) + return; + + wxArrayString Filenames; + FilesDialog.GetPaths( Filenames ); + + for( unsigned jj = 0; jj < Filenames.GetCount(); jj++ ) + { + fn = Filenames[jj]; + equFilename.Empty(); + + if( isPathRelativeAllowed() ) // try to use relative path + { + for( row = 0; row < getEnvVarCount(); row++ ) + { + libpath = m_gridEnvVars->GetCellValue( wxGridCellCoords( row, 1 ) ); + + if( fn.MakeRelativeTo( libpath ) ) + { + equFilename.Printf( wxT("${%s}%c%s"), + GetChars( m_gridEnvVars->GetCellValue( wxGridCellCoords( row, 0 ) ) ), + fn.GetPathSeparator(), + GetChars( fn.GetFullPath() ) ); + break; + } + } + } + + if( equFilename.IsEmpty() ) + equFilename = Filenames[jj]; + + // Add or insert new library name, if not already in list + if( list->FindString( equFilename, fn.IsCaseSensitive() ) == wxNOT_FOUND ) + { + m_ListChanged = true; + equFilename.Replace( wxT("\\"), wxT("/") ); // Use unix separators only. + list->Append( equFilename ); + } + else + { + wxString msg; + msg.Printf( _( "File '%s' already exists in list" ), equFilename.GetData() ); + DisplayError( this, msg ); + } + } +} |