mirror of
				https://github.com/cookiengineer/audacity
				synced 2025-10-25 07:43:54 +02:00 
			
		
		
		
	Bug1831: Export Multi fails? Erase incomplete, restore original file!
This commit is contained in:
		| @@ -585,6 +585,9 @@ void ExportMultiple::OnExport(wxCommandEvent& WXUNUSED(event)) | |||||||
|          FileList += '\n'; |          FileList += '\n'; | ||||||
|       } |       } | ||||||
|  |  | ||||||
|  |       // TODO: give some warning dialog first, when only some files exported | ||||||
|  |       // successfully. | ||||||
|  |  | ||||||
|       GuardedCall( [&] { |       GuardedCall( [&] { | ||||||
|          // This results dialog is a child of this dialog. |          // This results dialog is a child of this dialog. | ||||||
|          HelpSystem::ShowInfoDialog( this, |          HelpSystem::ShowInfoDialog( this, | ||||||
| @@ -945,12 +948,23 @@ ProgressResult ExportMultiple::DoExport(unsigned channels, | |||||||
|    else |    else | ||||||
|       wxLogDebug(wxT("Whole Project")); |       wxLogDebug(wxT("Whole Project")); | ||||||
|  |  | ||||||
|  |    wxFileName backup; | ||||||
|    if (mOverwrite->GetValue()) { |    if (mOverwrite->GetValue()) { | ||||||
|       // Make sure we don't overwrite (corrupt) alias files |       // Make sure we don't overwrite (corrupt) alias files | ||||||
|       if (!mProject->GetDirManager()->EnsureSafeFilename(inName)) { |       if (!mProject->GetDirManager()->EnsureSafeFilename(inName)) { | ||||||
|          return ProgressResult::Cancelled; |          return ProgressResult::Cancelled; | ||||||
|       } |       } | ||||||
|       name = inName; |       name = inName; | ||||||
|  |       backup.Assign(name); | ||||||
|  |  | ||||||
|  |       int suffix = 0; | ||||||
|  |       do { | ||||||
|  |          backup.SetName(name.GetName() + | ||||||
|  |                            wxString::Format(wxT("%d"), suffix)); | ||||||
|  |          ++suffix; | ||||||
|  |       } | ||||||
|  |       while (backup.FileExists()); | ||||||
|  |       ::wxRenameFile(inName.GetFullPath(), backup.GetFullPath()); | ||||||
|    } |    } | ||||||
|    else { |    else { | ||||||
|       name = inName; |       name = inName; | ||||||
| @@ -961,9 +975,32 @@ ProgressResult ExportMultiple::DoExport(unsigned channels, | |||||||
|       } |       } | ||||||
|    } |    } | ||||||
|  |  | ||||||
|    // Call the format export routine |    ProgressResult success = ProgressResult::Cancelled; | ||||||
|    const wxString fullPath{name.GetFullPath()}; |    const wxString fullPath{name.GetFullPath()}; | ||||||
|    auto success = mPlugins[mPluginIndex]->Export(mProject, |  | ||||||
|  |    auto cleanup = finally( [&] { | ||||||
|  |       bool ok = | ||||||
|  |          success == ProgressResult::Stopped || | ||||||
|  |          success == ProgressResult::Success; | ||||||
|  |       if (backup.IsOk()) { | ||||||
|  |          if ( ok ) | ||||||
|  |             // Remove backup | ||||||
|  |             ::wxRemoveFile(backup.GetFullPath()); | ||||||
|  |          else { | ||||||
|  |             // Restore original | ||||||
|  |             ::wxRemoveFile(fullPath); | ||||||
|  |             ::wxRenameFile(backup.GetFullPath(), fullPath); | ||||||
|  |          } | ||||||
|  |       } | ||||||
|  |       else { | ||||||
|  |          if ( ! ok ) | ||||||
|  |             // Remove any new, and only partially written, file. | ||||||
|  |             ::wxRemoveFile(fullPath); | ||||||
|  |       } | ||||||
|  |    } ); | ||||||
|  |  | ||||||
|  |    // Call the format export routine | ||||||
|  |    success = mPlugins[mPluginIndex]->Export(mProject, | ||||||
|                                                 channels, |                                                 channels, | ||||||
|                                                 fullPath, |                                                 fullPath, | ||||||
|                                                 selectedOnly, |                                                 selectedOnly, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user