Handle read-only libraries when saving symbol from canvas.
Fixes https://gitlab.com/kicad/code/kicad/-/issues/15519
(cherry picked from commit 1fd3f4e375
)
This commit is contained in:
parent
f1376396c2
commit
7e747085d3
|
@ -124,14 +124,20 @@ bool SYMBOL_EDIT_FRAME::saveCurrentSymbol()
|
|||
}
|
||||
else
|
||||
{
|
||||
LIB_ID libId = GetCurSymbol()->GetLibId();
|
||||
const wxString& libName = libId.GetLibNickname();
|
||||
const wxString& symbolName = libId.GetLibItemName();
|
||||
const wxString& libName = GetCurSymbol()->GetLibId().GetLibNickname();
|
||||
|
||||
if( m_libMgr->FlushSymbol( symbolName, libName ) )
|
||||
if( m_libMgr->IsLibraryReadOnly( libName ) )
|
||||
{
|
||||
m_libMgr->ClearSymbolModified( symbolName, libName );
|
||||
return true;
|
||||
wxString msg = wxString::Format( _( "Symbol library '%s' is not writable." ),
|
||||
libName );
|
||||
wxString msg2 = _( "You must save to a different location." );
|
||||
|
||||
if( OKOrCancelDialog( this, _( "Warning" ), msg, msg2 ) == wxID_OK )
|
||||
return saveLibrary( libName, true );
|
||||
}
|
||||
else
|
||||
{
|
||||
return saveLibrary( libName, false );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1183,12 +1189,7 @@ bool SYMBOL_EDIT_FRAME::saveAllLibraries( bool aRequireConfirmation )
|
|||
{
|
||||
// If saving under existing name fails then do a Save As..., and if that
|
||||
// fails then cancel close action.
|
||||
if( !m_libMgr->IsLibraryReadOnly( libNickname ) )
|
||||
{
|
||||
if( saveLibrary( libNickname, false ) )
|
||||
continue;
|
||||
}
|
||||
else
|
||||
if( m_libMgr->IsLibraryReadOnly( libNickname ) )
|
||||
{
|
||||
msg.Printf( _( "Symbol library '%s' is not writable." ), libNickname );
|
||||
msg2 = _( "You must save to a different location." );
|
||||
|
@ -1214,6 +1215,10 @@ bool SYMBOL_EDIT_FRAME::saveAllLibraries( bool aRequireConfirmation )
|
|||
continue;
|
||||
}
|
||||
}
|
||||
else if( saveLibrary( libNickname, false ) )
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
if( !saveLibrary( libNickname, true ) )
|
||||
retv = false;
|
||||
|
|
Loading…
Reference in New Issue