(AutoEntry): file type detection moved to separate method.

This commit is contained in:
morkt 2016-01-18 20:27:40 +04:00
parent 15d17e80be
commit bb49a1376a
2 changed files with 23 additions and 9 deletions

View File

@ -57,14 +57,26 @@ namespace GameRes.Formats
public static AutoEntry Create (ArcView file, long offset, string base_name) public static AutoEntry Create (ArcView file, long offset, string base_name)
{ {
return new AutoEntry (base_name, () => { return new AutoEntry (base_name, () => DetectFileType (file, offset)) { Offset = offset };
}
public static IResource DetectFileType (ArcView file, long offset)
{
uint signature = file.View.ReadUInt32 (offset); uint signature = file.View.ReadUInt32 (offset);
if (0 == signature) return null; if (0 == signature) return null;
// resolve some special cases first
if (s_OggFormat.Value.Signature == signature)
return s_OggFormat.Value;
if (AudioFormat.Wav.Signature == signature)
return AudioFormat.Wav;
if (0x4D42 == (signature & 0xFFFF)) // 'BM'
return ImageFormat.Bmp;
var res = FormatCatalog.Instance.LookupSignature (signature); var res = FormatCatalog.Instance.LookupSignature (signature);
if (!res.Any() || res.Skip (1).Any()) // Count == 0 || Count > 1 if (!res.Any())
return null;
if (res.Skip (1).Any()) // type is ambiguous
return null; return null;
return res.First(); return res.First();
}) { Offset = offset };
} }
private string GetName (string name) private string GetName (string name)
@ -81,6 +93,8 @@ namespace GameRes.Formats
{ {
return null == m_res.Value ? "" : m_res.Value.Type; return null == m_res.Value ? "" : m_res.Value.Type;
} }
static readonly Lazy<AudioFormat> s_OggFormat = new Lazy<AudioFormat> (() => FormatCatalog.Instance.AudioFormats.FirstOrDefault (x => x.Tag == "OGG"));
} }
public class PrefixStream : Stream public class PrefixStream : Stream

View File

@ -60,7 +60,7 @@ namespace GameRes.Formats.TopCat
Offset = offset; Offset = offset;
} }
private static IResource DetectFileType (ArcView file, long offset) new private static IResource DetectFileType (ArcView file, long offset)
{ {
uint signature = file.View.ReadUInt32 (offset); uint signature = file.View.ReadUInt32 (offset);
return FormatCatalog.Instance.LookupSignature (signature).FirstOrDefault(); return FormatCatalog.Instance.LookupSignature (signature).FirstOrDefault();