mirror of
https://github.com/crskycode/GARbro.git
synced 2024-11-27 23:54:02 +08:00
further VFS fixes.
This commit is contained in:
parent
8ef162709a
commit
c3c5261458
@ -66,7 +66,6 @@ namespace GARbro.GUI
|
|||||||
{
|
{
|
||||||
var source = entry.Source.Name;
|
var source = entry.Source.Name;
|
||||||
SetBusyState();
|
SetBusyState();
|
||||||
VFS.ChDir (source);
|
|
||||||
if (string.IsNullOrEmpty (destination))
|
if (string.IsNullOrEmpty (destination))
|
||||||
{
|
{
|
||||||
// extract into directory named after archive
|
// extract into directory named after archive
|
||||||
@ -75,7 +74,7 @@ namespace GARbro.GUI
|
|||||||
else
|
else
|
||||||
destination = vm.Path.First();
|
destination = vm.Path.First();
|
||||||
}
|
}
|
||||||
extractor = new GarExtract (this, source, VFS.CurrentArchive);
|
extractor = new GarExtract (this, source);
|
||||||
extractor.ExtractAll (destination);
|
extractor.ExtractAll (destination);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -84,7 +83,7 @@ namespace GARbro.GUI
|
|||||||
if (string.IsNullOrEmpty (destination))
|
if (string.IsNullOrEmpty (destination))
|
||||||
destination = Path.GetDirectoryName (vm.Path.First());
|
destination = Path.GetDirectoryName (vm.Path.First());
|
||||||
var archive_name = vm.Path[vm.Path.Count-2];
|
var archive_name = vm.Path[vm.Path.Count-2];
|
||||||
extractor = new GarExtract (this, archive_name, VFS.CurrentArchive);
|
extractor = new GarExtract (this, archive_name, VFS.Top as ArchiveFileSystem);
|
||||||
if (null == entry || (entry.Name == ".." && string.IsNullOrEmpty (vm.Path.Last()))) // root entry
|
if (null == entry || (entry.Name == ".." && string.IsNullOrEmpty (vm.Path.Last()))) // root entry
|
||||||
extractor.ExtractAll (destination);
|
extractor.ExtractAll (destination);
|
||||||
else
|
else
|
||||||
@ -99,14 +98,20 @@ namespace GARbro.GUI
|
|||||||
{
|
{
|
||||||
PopupError (X.Message, guiStrings.MsgErrorExtracting);
|
PopupError (X.Message, guiStrings.MsgErrorExtracting);
|
||||||
}
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
if (null != extractor && !extractor.IsActive)
|
||||||
|
extractor.Dispose();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
sealed internal class GarExtract
|
sealed internal class GarExtract : IDisposable
|
||||||
{
|
{
|
||||||
private MainWindow m_main;
|
private MainWindow m_main;
|
||||||
private string m_arc_name;
|
private string m_arc_name;
|
||||||
private ArcFile m_arc;
|
private ArchiveFileSystem m_fs;
|
||||||
|
private readonly bool m_should_dispose;
|
||||||
private bool m_skip_images = false;
|
private bool m_skip_images = false;
|
||||||
private bool m_skip_script = false;
|
private bool m_skip_script = false;
|
||||||
private bool m_skip_audio = false;
|
private bool m_skip_audio = false;
|
||||||
@ -120,11 +125,33 @@ namespace GARbro.GUI
|
|||||||
|
|
||||||
public bool IsActive { get { return m_extract_in_progress; } }
|
public bool IsActive { get { return m_extract_in_progress; } }
|
||||||
|
|
||||||
public GarExtract (MainWindow parent, string source, ArcFile arc)
|
public GarExtract (MainWindow parent, string source)
|
||||||
{
|
{
|
||||||
m_main = parent;
|
m_main = parent;
|
||||||
m_arc_name = Path.GetFileName (source);
|
m_arc_name = Path.GetFileName (source);
|
||||||
m_arc = arc;
|
FormatCatalog.Instance.LastError = null;
|
||||||
|
var arc = ArcFile.TryOpen (source);
|
||||||
|
if (null == arc)
|
||||||
|
{
|
||||||
|
string error_message;
|
||||||
|
if (FormatCatalog.Instance.LastError != null)
|
||||||
|
error_message = FormatCatalog.Instance.LastError.Message;
|
||||||
|
else
|
||||||
|
error_message = garStrings.MsgUnknownFormat;
|
||||||
|
throw new OperationCanceledException (string.Format ("{1}: {0}", error_message, m_arc_name));
|
||||||
|
}
|
||||||
|
m_fs = arc.CreateFileSystem();
|
||||||
|
m_should_dispose = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public GarExtract (MainWindow parent, string source, ArchiveFileSystem fs)
|
||||||
|
{
|
||||||
|
if (null == fs)
|
||||||
|
throw new UnknownFormatException();
|
||||||
|
m_fs = fs;
|
||||||
|
m_main = parent;
|
||||||
|
m_arc_name = Path.GetFileName (source);
|
||||||
|
m_should_dispose = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void PrepareDestination (string destination)
|
private void PrepareDestination (string destination)
|
||||||
@ -147,7 +174,8 @@ namespace GARbro.GUI
|
|||||||
|
|
||||||
public void ExtractAll (string destination)
|
public void ExtractAll (string destination)
|
||||||
{
|
{
|
||||||
if (0 == m_arc.Dir.Count)
|
var file_list = m_fs.GetFilesRecursive();
|
||||||
|
if (!file_list.Any())
|
||||||
{
|
{
|
||||||
m_main.SetStatusText (string.Format ("{1}: {0}", guiStrings.MsgEmptyArchive, m_arc_name));
|
m_main.SetStatusText (string.Format ("{1}: {0}", guiStrings.MsgEmptyArchive, m_arc_name));
|
||||||
return;
|
return;
|
||||||
@ -173,7 +201,7 @@ namespace GARbro.GUI
|
|||||||
m_image_format = extractDialog.GetImageFormat (extractDialog.ImageConversionFormat);
|
m_image_format = extractDialog.GetImageFormat (extractDialog.ImageConversionFormat);
|
||||||
|
|
||||||
m_main.SetStatusText (string.Format(guiStrings.MsgExtractingTo, m_arc_name, destination));
|
m_main.SetStatusText (string.Format(guiStrings.MsgExtractingTo, m_arc_name, destination));
|
||||||
ExtractFilesFromArchive (string.Format (guiStrings.MsgExtractingArchive, m_arc_name), m_arc.Dir);
|
ExtractFilesFromArchive (string.Format (guiStrings.MsgExtractingArchive, m_arc_name), file_list);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Extract (EntryViewModel entry, string destination)
|
public void Extract (EntryViewModel entry, string destination)
|
||||||
@ -184,8 +212,8 @@ namespace GARbro.GUI
|
|||||||
selected = view_model;
|
selected = view_model;
|
||||||
|
|
||||||
IEnumerable<Entry> file_list = selected.Select (e => e.Source);
|
IEnumerable<Entry> file_list = selected.Select (e => e.Source);
|
||||||
if (VFS.Top is TreeArchiveFileSystem)
|
if (m_fs is TreeArchiveFileSystem)
|
||||||
file_list = (VFS.Top as TreeArchiveFileSystem).GetFilesRecursive (file_list);
|
file_list = (m_fs as TreeArchiveFileSystem).GetFilesRecursive (file_list);
|
||||||
|
|
||||||
if (!file_list.Any())
|
if (!file_list.Any())
|
||||||
{
|
{
|
||||||
@ -259,6 +287,7 @@ namespace GARbro.GUI
|
|||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
var arc = m_fs.Source;
|
||||||
int total = file_list.Count();
|
int total = file_list.Count();
|
||||||
foreach (var entry in file_list)
|
foreach (var entry in file_list)
|
||||||
{
|
{
|
||||||
@ -267,11 +296,11 @@ namespace GARbro.GUI
|
|||||||
if (total > 1)
|
if (total > 1)
|
||||||
m_progress_dialog.ReportProgress (m_extract_count*100/total, null, entry.Name);
|
m_progress_dialog.ReportProgress (m_extract_count*100/total, null, entry.Name);
|
||||||
if (null != m_image_format && entry.Type == "image")
|
if (null != m_image_format && entry.Type == "image")
|
||||||
ExtractImage (m_arc, entry, m_image_format);
|
ExtractImage (arc, entry, m_image_format);
|
||||||
else if (m_convert_audio && entry.Type == "audio")
|
else if (m_convert_audio && entry.Type == "audio")
|
||||||
ExtractAudio (m_arc, entry);
|
ExtractAudio (arc, entry);
|
||||||
else
|
else
|
||||||
m_arc.Extract (entry);
|
arc.Extract (entry);
|
||||||
++m_extract_count;
|
++m_extract_count;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -404,6 +433,22 @@ namespace GARbro.GUI
|
|||||||
m_main.PopupError (message, guiStrings.MsgErrorExtracting);
|
m_main.PopupError (message, guiStrings.MsgErrorExtracting);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
this.Dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
#region IDisposable Members
|
||||||
|
bool disposed = false;
|
||||||
|
|
||||||
|
public void Dispose ()
|
||||||
|
{
|
||||||
|
if (!disposed)
|
||||||
|
{
|
||||||
|
if (m_should_dispose)
|
||||||
|
m_fs.Dispose();
|
||||||
|
disposed = true;
|
||||||
|
}
|
||||||
|
GC.SuppressFinalize (this);
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user