mirror of
https://github.com/claunia/Claunia.RsrcFork.git
synced 2025-12-16 19:24:46 +00:00
Code refactor.
This commit is contained in:
@@ -23,16 +23,17 @@
|
||||
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
// THE SOFTWARE.
|
||||
|
||||
using System;
|
||||
using System.IO;
|
||||
using System.Text;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
|
||||
namespace Claunia.RsrcFork.CLI
|
||||
{
|
||||
class MainClass
|
||||
{
|
||||
public static void Main (string [] args)
|
||||
public static void Main(string[] args)
|
||||
{
|
||||
Console.WriteLine("Claunia.RsrcFork.CLI");
|
||||
Console.WriteLine("© 2016 Natalia Portillo");
|
||||
@@ -68,20 +69,17 @@ namespace Claunia.RsrcFork.CLI
|
||||
typeBytes = typeBytes.Reverse().ToArray();
|
||||
string typeName = Types.GetName(type);
|
||||
if(typeName != null)
|
||||
Console.WriteLine("\"{0}\" (0x{1:X8}) - {2}", Encoding.ASCII.GetString(typeBytes), type, typeName);
|
||||
else
|
||||
Console.WriteLine("\"{0}\" (0x{1:X8})", Encoding.ASCII.GetString(typeBytes), type);
|
||||
Console.WriteLine("\"{0}\" (0x{1:X8}) - {2}", Encoding.ASCII.GetString(typeBytes), type,
|
||||
typeName);
|
||||
else Console.WriteLine("\"{0}\" (0x{1:X8})", Encoding.ASCII.GetString(typeBytes), type);
|
||||
|
||||
Resource rez = rsrc.GetResource(type);
|
||||
Console.WriteLine("{0,6}{1,8}\t{2}", "ID", "Length", "Name");
|
||||
Console.WriteLine("{0,6}{1,8}--{2}", "------", "--------", "----------------");
|
||||
foreach(short id in rez.GetIds())
|
||||
{
|
||||
if(rez.GetName(id) != null)
|
||||
Console.WriteLine("{0,6}{1,8}\t\"{2}\"", id, rez.GetLength(id), rez.GetName(id));
|
||||
else
|
||||
Console.WriteLine("{0,6}{1,8}", id, rez.GetLength(id));
|
||||
}
|
||||
else Console.WriteLine("{0,6}{1,8}", id, rez.GetLength(id));
|
||||
|
||||
Console.WriteLine();
|
||||
}
|
||||
@@ -130,14 +128,15 @@ namespace Claunia.RsrcFork.CLI
|
||||
Resource rez = rsrc.GetResource(type);
|
||||
foreach(short id in rez.GetIds())
|
||||
{
|
||||
outStream = new FileStream(Path.Combine(args[2], Encoding.ASCII.GetString(typeBytes), string.Format("{0}", id)), FileMode.Create, FileAccess.ReadWrite);
|
||||
outStream =
|
||||
new
|
||||
FileStream(Path.Combine(args[2], Encoding.ASCII.GetString(typeBytes), string.Format("{0}", id)),
|
||||
FileMode.Create, FileAccess.ReadWrite);
|
||||
byte[] rez_b = rez.GetResource(id);
|
||||
outStream.Write(rez_b, 0, rez_b.Length);
|
||||
outStream.Close();
|
||||
}
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -23,30 +23,29 @@
|
||||
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
// THE SOFTWARE.
|
||||
|
||||
using System.Reflection;
|
||||
using System.Runtime.CompilerServices;
|
||||
|
||||
// Information about this assembly is defined by the following attributes.
|
||||
// Change them to the values specific to your project.
|
||||
|
||||
[assembly: AssemblyTitle ("Claunia.RsrcFork.CLI")]
|
||||
[assembly: AssemblyDescription ("")]
|
||||
[assembly: AssemblyConfiguration ("")]
|
||||
[assembly: AssemblyCompany ("Claunia.com")]
|
||||
[assembly: AssemblyProduct ("")]
|
||||
[assembly: AssemblyCopyright ("© Claunia.com")]
|
||||
[assembly: AssemblyTrademark ("")]
|
||||
[assembly: AssemblyCulture ("")]
|
||||
[assembly: AssemblyTitle("Claunia.RsrcFork.CLI")]
|
||||
[assembly: AssemblyDescription("")]
|
||||
[assembly: AssemblyConfiguration("")]
|
||||
[assembly: AssemblyCompany("Claunia.com")]
|
||||
[assembly: AssemblyProduct("")]
|
||||
[assembly: AssemblyCopyright("© Claunia.com")]
|
||||
[assembly: AssemblyTrademark("")]
|
||||
[assembly: AssemblyCulture("")]
|
||||
|
||||
// The assembly version has the format "{Major}.{Minor}.{Build}.{Revision}".
|
||||
// The form "{Major}.{Minor}.*" will automatically update the build and revision,
|
||||
// and "{Major}.{Minor}.{Build}.*" will update just the revision.
|
||||
|
||||
[assembly: AssemblyVersion ("1.0.*")]
|
||||
[assembly: AssemblyVersion("1.0.*")]
|
||||
|
||||
// The following attributes are used to specify the signing key for the assembly,
|
||||
// if desired. See the Mono documentation for more information about signing.
|
||||
|
||||
//[assembly: AssemblyDelaySign(false)]
|
||||
//[assembly: AssemblyKeyFile("")]
|
||||
|
||||
|
||||
@@ -33,9 +33,13 @@ namespace Claunia.RsrcFork.Test
|
||||
[TestFixture]
|
||||
public class Test
|
||||
{
|
||||
readonly byte[] DC42_Vers = { 0x06, 0x40, 0x80, 0x00, 0x00, 0x00, 0x09, 0x44, 0x69, 0x73, 0x6B, 0x20, 0x43, 0x6F, 0x70, 0x79, 0x1C, 0x34, 0x2E, 0x32, 0x2C,
|
||||
0x20, 0x64, 0x61, 0x74, 0x61, 0x20, 0x63, 0x68, 0x65, 0x63, 0x6B, 0x73, 0x75, 0x6D, 0x3D, 0x24, 0x41, 0x35, 0x31, 0x34, 0x37, 0x46, 0x37, 0x45 };
|
||||
readonly byte[] DC42_Str = { 0x09, 0x44, 0x69, 0x73, 0x6B, 0x20, 0x43, 0x6F, 0x70, 0x79 };
|
||||
readonly byte[] DC42_Vers =
|
||||
{
|
||||
0x06, 0x40, 0x80, 0x00, 0x00, 0x00, 0x09, 0x44, 0x69, 0x73, 0x6B, 0x20, 0x43, 0x6F, 0x70, 0x79, 0x1C,
|
||||
0x34, 0x2E, 0x32, 0x2C, 0x20, 0x64, 0x61, 0x74, 0x61, 0x20, 0x63, 0x68, 0x65, 0x63, 0x6B, 0x73, 0x75,
|
||||
0x6D, 0x3D, 0x24, 0x41, 0x35, 0x31, 0x34, 0x37, 0x46, 0x37, 0x45
|
||||
};
|
||||
readonly byte[] DC42_Str = {0x09, 0x44, 0x69, 0x73, 0x6B, 0x20, 0x43, 0x6F, 0x70, 0x79};
|
||||
|
||||
[Test]
|
||||
public void TestDC42()
|
||||
@@ -225,4 +229,3 @@ namespace Claunia.RsrcFork.Test
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -23,8 +23,10 @@
|
||||
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
// THE SOFTWARE.
|
||||
|
||||
using System;
|
||||
using System.Text;
|
||||
|
||||
namespace Claunia.RsrcFork
|
||||
{
|
||||
/// <summary>
|
||||
@@ -39,8 +41,7 @@ namespace Claunia.RsrcFork
|
||||
/// <param name="PStr">The ASCII Pascal string.</param>
|
||||
public static string GetString(byte[] PStr)
|
||||
{
|
||||
if(PStr == null || PStr[0] >= PStr.Length)
|
||||
return null;
|
||||
if(PStr == null || PStr[0] >= PStr.Length) return null;
|
||||
|
||||
return Encoding.ASCII.GetString(PStr, 1, PStr[0]);
|
||||
}
|
||||
@@ -52,16 +53,13 @@ namespace Claunia.RsrcFork
|
||||
/// <param name="str">The .NET string.</param>
|
||||
public static byte[] GetBytes(string str)
|
||||
{
|
||||
if(str == null)
|
||||
return new byte[1];
|
||||
if(str == null) return new byte[1];
|
||||
|
||||
byte[] str_b = Encoding.ASCII.GetBytes(str);
|
||||
byte[] PStr;
|
||||
|
||||
if(str_b.Length >= 256)
|
||||
PStr = new byte[256];
|
||||
else
|
||||
PStr = new byte[str_b.Length + 1];
|
||||
if(str_b.Length >= 256) PStr = new byte[256];
|
||||
else PStr = new byte[str_b.Length + 1];
|
||||
|
||||
Array.Copy(str_b, 0, PStr, 1, PStr.Length - 1);
|
||||
PStr[0] = (byte)(PStr.Length - 1);
|
||||
@@ -70,4 +68,3 @@ namespace Claunia.RsrcFork
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -37,17 +37,11 @@ namespace Claunia.RsrcFork
|
||||
/// </summary>
|
||||
public class Resource
|
||||
{
|
||||
readonly List<short> ids;
|
||||
readonly Dictionary<short, byte[]> resourceCache;
|
||||
readonly Dictionary<short, string> resourceNames;
|
||||
readonly Dictionary<short, ResourceData> resources;
|
||||
readonly Dictionary<short, byte[]> resourceCache;
|
||||
readonly Stream rsrcStream;
|
||||
readonly List<short> ids;
|
||||
|
||||
struct ResourceData
|
||||
{
|
||||
public long offset;
|
||||
public long length;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Initializates the specified resource type.
|
||||
@@ -58,10 +52,12 @@ namespace Claunia.RsrcFork
|
||||
/// <param name="resourceNameOffset">Offset from start of stream to resource name list.</param>
|
||||
/// <param name="resourceDataOffset">Offset from start of stream to resource data.</param>
|
||||
/// <param name="OSType">Resource type.</param>
|
||||
internal Resource(Stream stream, ushort resources, long referenceListOff, long resourceNameOffset, long resourceDataOffset, uint OSType)
|
||||
internal Resource(Stream stream, ushort resources, long referenceListOff, long resourceNameOffset,
|
||||
long resourceDataOffset, uint OSType)
|
||||
{
|
||||
rsrcStream = stream;
|
||||
Dictionary<short, ResourceTypeReferenceListItem> referenceLists = new Dictionary<short, ResourceTypeReferenceListItem>();
|
||||
Dictionary<short, ResourceTypeReferenceListItem> referenceLists =
|
||||
new Dictionary<short, ResourceTypeReferenceListItem>();
|
||||
resourceNames = new Dictionary<short, string>();
|
||||
this.resources = new Dictionary<short, ResourceData>();
|
||||
ids = new List<short>();
|
||||
@@ -93,8 +89,7 @@ namespace Claunia.RsrcFork
|
||||
string name;
|
||||
ResourceData data = new ResourceData();
|
||||
|
||||
if(item.nameOff == -1)
|
||||
name = null;
|
||||
if(item.nameOff == -1) name = null;
|
||||
else
|
||||
{
|
||||
rsrcStream.Seek(resourceNameOffset + item.nameOff, SeekOrigin.Begin);
|
||||
@@ -138,13 +133,11 @@ namespace Claunia.RsrcFork
|
||||
{
|
||||
byte[] resource;
|
||||
|
||||
if(resourceCache.TryGetValue(id, out resource))
|
||||
return resource;
|
||||
if(resourceCache.TryGetValue(id, out resource)) return resource;
|
||||
|
||||
ResourceData data;
|
||||
|
||||
if(!resources.TryGetValue(id, out data))
|
||||
return null;
|
||||
if(!resources.TryGetValue(id, out data)) return null;
|
||||
|
||||
resource = new byte[data.length];
|
||||
rsrcStream.Seek(data.offset, SeekOrigin.Begin);
|
||||
@@ -170,20 +163,19 @@ namespace Claunia.RsrcFork
|
||||
/// Gets the IDs of all the resources contained by this instance.
|
||||
/// </summary>
|
||||
/// <returns>The identifiers.</returns>
|
||||
public short[] GetIds()
|
||||
{
|
||||
return ids.ToArray();
|
||||
}
|
||||
public short[] GetIds() => ids.ToArray();
|
||||
|
||||
/// <summary>
|
||||
/// Checks if the resource specified by ID is contained by this instance.
|
||||
/// </summary>
|
||||
/// <returns><c>true</c>, if the resource is contained in this instance, <c>false</c> otherwise.</returns>
|
||||
/// <param name="id">Resource identifier.</param>
|
||||
public bool ContainsId(short id)
|
||||
public bool ContainsId(short id) => ids.Contains(id);
|
||||
|
||||
struct ResourceData
|
||||
{
|
||||
return ids.Contains(id);
|
||||
public long offset;
|
||||
public long length;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -35,12 +35,12 @@ namespace Claunia.RsrcFork
|
||||
/// </summary>
|
||||
public class ResourceFork
|
||||
{
|
||||
Stream rsrcStream;
|
||||
ResourceHeader header;
|
||||
ResourceMap map;
|
||||
Dictionary<uint, ResourceTypeListItem> resourceTypeList;
|
||||
Dictionary<uint, Resource> resourceCache;
|
||||
List<uint> osTypes;
|
||||
Dictionary<uint, Resource> resourceCache;
|
||||
Dictionary<uint, ResourceTypeListItem> resourceTypeList;
|
||||
readonly Stream rsrcStream;
|
||||
|
||||
/// <summary>
|
||||
/// Initializates a resource fork using a byte array as backend.
|
||||
@@ -67,8 +67,7 @@ namespace Claunia.RsrcFork
|
||||
/// </summary>
|
||||
~ResourceFork()
|
||||
{
|
||||
if(rsrcStream != null)
|
||||
rsrcStream.Dispose();
|
||||
if(rsrcStream != null) rsrcStream.Dispose();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -88,8 +87,8 @@ namespace Claunia.RsrcFork
|
||||
rsrcStream.Read(tmp, 0, 4);
|
||||
header.resourceMapLen = BitConverter.ToInt32(tmp.Reverse().ToArray(), 0);
|
||||
|
||||
if(header.resourceDataOff <= 0 || header.resourceMapOff <= 0 || header.resourceDataLen <= 0 || header.resourceMapLen <= 0)
|
||||
throw new InvalidCastException("Not a resource fork");
|
||||
if(header.resourceDataOff <= 0 || header.resourceMapOff <= 0 || header.resourceDataLen <= 0 ||
|
||||
header.resourceMapLen <= 0) throw new InvalidCastException("Not a resource fork");
|
||||
|
||||
if(header.resourceDataOff + header.resourceDataLen > rsrcStream.Length ||
|
||||
header.resourceMapOff + header.resourceMapLen > rsrcStream.Length)
|
||||
@@ -134,7 +133,8 @@ namespace Claunia.RsrcFork
|
||||
resourceTypeList = new Dictionary<uint, ResourceTypeListItem>();
|
||||
osTypes = new List<uint>();
|
||||
|
||||
for(int i = 0; i <= map.numberOfTypes; i++) {
|
||||
for(int i = 0; i <= map.numberOfTypes; i++)
|
||||
{
|
||||
ResourceTypeListItem typeList = new ResourceTypeListItem();
|
||||
tmp = new byte[4];
|
||||
rsrcStream.Read(tmp, 0, 4);
|
||||
@@ -161,14 +161,15 @@ namespace Claunia.RsrcFork
|
||||
{
|
||||
Resource rsrc;
|
||||
|
||||
if(resourceCache.TryGetValue(OSType, out rsrc))
|
||||
return rsrc;
|
||||
if(resourceCache.TryGetValue(OSType, out rsrc)) return rsrc;
|
||||
|
||||
ResourceTypeListItem typeList;
|
||||
if(!resourceTypeList.TryGetValue(OSType, out typeList))
|
||||
return null;
|
||||
if(!resourceTypeList.TryGetValue(OSType, out typeList)) return null;
|
||||
|
||||
rsrc = new Resource(rsrcStream, (ushort)(typeList.resources + 1), header.resourceMapOff + map.typeListOff + typeList.referenceOff - 2, header.resourceMapOff + map.nameListOff, header.resourceDataOff, OSType);
|
||||
rsrc = new Resource(rsrcStream, (ushort)(typeList.resources + 1),
|
||||
header.resourceMapOff + map.typeListOff + typeList.referenceOff - 2,
|
||||
header.resourceMapOff + map.nameListOff,
|
||||
header.resourceDataOff, OSType);
|
||||
|
||||
resourceCache.Add(OSType, rsrc);
|
||||
|
||||
@@ -179,19 +180,12 @@ namespace Claunia.RsrcFork
|
||||
/// Gets all OSTypes stored in this resource fork
|
||||
/// </summary>
|
||||
/// <returns>The types.</returns>
|
||||
public uint[] GetTypes()
|
||||
{
|
||||
return osTypes.ToArray();
|
||||
}
|
||||
public uint[] GetTypes() => osTypes.ToArray();
|
||||
|
||||
/// <summary>
|
||||
/// Returns true if the specified OSType is present in this resource fork.
|
||||
/// </summary>
|
||||
/// <param name="OSType">OSType.</param>
|
||||
public bool ContainsKey(uint OSType)
|
||||
{
|
||||
return resourceTypeList.ContainsKey(OSType);
|
||||
}
|
||||
public bool ContainsKey(uint OSType) => resourceTypeList.ContainsKey(OSType);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -35,7 +35,91 @@ namespace Resources
|
||||
/// </summary>
|
||||
public class Version
|
||||
{
|
||||
static uint ostype = 0x76657273;
|
||||
/// <summary>
|
||||
/// Known development stages
|
||||
/// </summary>
|
||||
public enum DevelopmentStage : byte
|
||||
{
|
||||
/// <summary>
|
||||
/// Pre-alpha.
|
||||
/// </summary>
|
||||
PreAlpha = 0x20,
|
||||
/// <summary>
|
||||
/// Alpha.
|
||||
/// </summary>
|
||||
Alpha = 0x40,
|
||||
/// <summary>
|
||||
/// Beta.
|
||||
/// </summary>
|
||||
Beta = 0x60,
|
||||
/// <summary>
|
||||
/// Final release.
|
||||
/// </summary>
|
||||
Final = 0x80
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Initializes a new instance of the <see cref="T:Resources.Version" /> class.
|
||||
/// </summary>
|
||||
/// <param name="resource">Byte array containing the "VERS" resource.</param>
|
||||
public Version(byte[] resource)
|
||||
{
|
||||
byte[] tmpShort, tmpStr, tmpMsg;
|
||||
|
||||
tmpShort = new byte[2];
|
||||
|
||||
MajorVersion = BCDToNumber(resource[0]);
|
||||
MinorVersion = BCDToNumber(resource[1]);
|
||||
DevStage = (DevelopmentStage)resource[2];
|
||||
PreReleaseVersion = BCDToNumber(resource[3]);
|
||||
Array.Copy(resource, 4, tmpShort, 0, 2);
|
||||
RegionCode = BitConverter.ToUInt16(tmpShort.Reverse().ToArray(), 0);
|
||||
tmpStr = new byte[resource[6] + 1];
|
||||
Array.Copy(resource, 6, tmpStr, 0, tmpStr.Length);
|
||||
VersionString = PascalString.GetString(tmpStr);
|
||||
tmpMsg = new byte[resource[6 + tmpStr.Length] + 1];
|
||||
Array.Copy(resource, 6 + tmpStr.Length, tmpMsg, 0, tmpMsg.Length);
|
||||
VersionMessage = PascalString.GetString(tmpMsg);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Gets the OSTYPE of this resource.
|
||||
/// </summary>
|
||||
/// <value>The OSTYPE.</value>
|
||||
public static uint OSType { get; } = 0x76657273;
|
||||
|
||||
/// <summary>
|
||||
/// Gets a byte array with the "VERS" resource contained by this instance.
|
||||
/// </summary>
|
||||
/// <returns>The "VERS" resource.</returns>
|
||||
public byte[] GetBytes()
|
||||
{
|
||||
byte[] tmpShort, tmpStr, tmpMsg;
|
||||
tmpShort = BitConverter.GetBytes(RegionCode).Reverse().ToArray();
|
||||
tmpStr = PascalString.GetBytes(VersionString);
|
||||
tmpMsg = PascalString.GetBytes(VersionMessage);
|
||||
|
||||
byte[] vers = new byte[6 + tmpStr.Length + tmpMsg.Length];
|
||||
|
||||
vers[0] = NumberToBCD(MajorVersion);
|
||||
vers[1] = NumberToBCD(MinorVersion);
|
||||
vers[2] = (byte)DevStage;
|
||||
vers[3] = NumberToBCD(PreReleaseVersion);
|
||||
Array.Copy(tmpShort, 0, vers, 4, 2);
|
||||
Array.Copy(tmpStr, 0, vers, 6, tmpStr.Length);
|
||||
Array.Copy(tmpMsg, 0, vers, 6 + tmpStr.Length, tmpMsg.Length);
|
||||
|
||||
return vers;
|
||||
}
|
||||
|
||||
byte BCDToNumber(byte bcd) => Convert.ToByte(string.Format("{0:X2}", bcd), 10);
|
||||
|
||||
byte NumberToBCD(byte number)
|
||||
{
|
||||
if(number >= 100) number = 99;
|
||||
|
||||
return Convert.ToByte(string.Format("{0:D2}", number), 16);
|
||||
}
|
||||
|
||||
#region On-disk structure
|
||||
/// <summary>
|
||||
@@ -67,100 +151,5 @@ namespace Resources
|
||||
/// </summary>
|
||||
public string VersionMessage;
|
||||
#endregion
|
||||
|
||||
/// <summary>
|
||||
/// Known development stages
|
||||
/// </summary>
|
||||
public enum DevelopmentStage : byte
|
||||
{
|
||||
/// <summary>
|
||||
/// Pre-alpha.
|
||||
/// </summary>
|
||||
PreAlpha = 0x20,
|
||||
/// <summary>
|
||||
/// Alpha.
|
||||
/// </summary>
|
||||
Alpha = 0x40,
|
||||
/// <summary>
|
||||
/// Beta.
|
||||
/// </summary>
|
||||
Beta = 0x60,
|
||||
/// <summary>
|
||||
/// Final release.
|
||||
/// </summary>
|
||||
Final = 0x80
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Initializes a new instance of the <see cref="T:Resources.Version"/> class.
|
||||
/// </summary>
|
||||
/// <param name="resource">Byte array containing the "VERS" resource.</param>
|
||||
public Version(byte[] resource)
|
||||
{
|
||||
byte[] tmpShort, tmpStr, tmpMsg;
|
||||
|
||||
tmpShort = new byte[2];
|
||||
|
||||
MajorVersion = BCDToNumber(resource[0]);
|
||||
MinorVersion = BCDToNumber(resource[1]);
|
||||
DevStage = (DevelopmentStage)resource[2];
|
||||
PreReleaseVersion = BCDToNumber(resource[3]);
|
||||
Array.Copy(resource, 4, tmpShort, 0, 2);
|
||||
RegionCode = BitConverter.ToUInt16(tmpShort.Reverse().ToArray(), 0);
|
||||
tmpStr = new byte[resource[6] + 1];
|
||||
Array.Copy(resource, 6, tmpStr, 0, tmpStr.Length);
|
||||
VersionString = PascalString.GetString(tmpStr);
|
||||
tmpMsg = new byte[resource[6 + tmpStr.Length] + 1];
|
||||
Array.Copy(resource, 6 + tmpStr.Length, tmpMsg, 0, tmpMsg.Length);
|
||||
VersionMessage = PascalString.GetString(tmpMsg);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Gets a byte array with the "VERS" resource contained by this instance.
|
||||
/// </summary>
|
||||
/// <returns>The "VERS" resource.</returns>
|
||||
public byte[] GetBytes()
|
||||
{
|
||||
byte[] tmpShort, tmpStr, tmpMsg;
|
||||
tmpShort = BitConverter.GetBytes(RegionCode).Reverse().ToArray();
|
||||
tmpStr = PascalString.GetBytes(VersionString);
|
||||
tmpMsg = PascalString.GetBytes(VersionMessage);
|
||||
|
||||
byte[] vers = new byte[6 + tmpStr.Length + tmpMsg.Length];
|
||||
|
||||
vers[0] = NumberToBCD(MajorVersion);
|
||||
vers[1] = NumberToBCD(MinorVersion);
|
||||
vers[2] = (byte)DevStage;
|
||||
vers[3] = NumberToBCD(PreReleaseVersion);
|
||||
Array.Copy(tmpShort, 0, vers, 4, 2);
|
||||
Array.Copy(tmpStr, 0, vers, 6, tmpStr.Length);
|
||||
Array.Copy(tmpMsg, 0, vers, 6 + tmpStr.Length, tmpMsg.Length);
|
||||
|
||||
return vers;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Gets the OSTYPE of this resource.
|
||||
/// </summary>
|
||||
/// <value>The OSTYPE.</value>
|
||||
public static uint OSType {
|
||||
get {
|
||||
return ostype;
|
||||
}
|
||||
}
|
||||
|
||||
byte BCDToNumber(byte bcd)
|
||||
{
|
||||
return Convert.ToByte(string.Format("{0:X2}", bcd), 10);
|
||||
}
|
||||
|
||||
byte NumberToBCD(byte number)
|
||||
{
|
||||
if(number >= 100)
|
||||
number = 99;
|
||||
|
||||
return Convert.ToByte(string.Format("{0:D2}", number), 16);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -109,7 +109,7 @@ namespace Claunia.RsrcFork
|
||||
/// </summary>
|
||||
public byte attributes;
|
||||
/// <summary>
|
||||
/// Offset from beginning of resource data to resource. First byte is <see cref="attributes"/>.
|
||||
/// Offset from beginning of resource data to resource. First byte is <see cref="attributes" />.
|
||||
/// </summary>
|
||||
public int dataOff;
|
||||
/// <summary>
|
||||
@@ -118,4 +118,3 @@ namespace Claunia.RsrcFork
|
||||
public uint handle;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -25,8 +25,8 @@
|
||||
// THE SOFTWARE.
|
||||
|
||||
using System;
|
||||
using System.Text;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
|
||||
namespace Claunia.RsrcFork
|
||||
{
|
||||
@@ -42,7 +42,8 @@ namespace Claunia.RsrcFork
|
||||
/// <param name="OSType">The OSTYPE.</param>
|
||||
public static string GetName(uint OSType)
|
||||
{
|
||||
switch(OSType) {
|
||||
switch(OSType)
|
||||
{
|
||||
case 0x2E58534C: // ".XSL"
|
||||
return "XML style sheet";
|
||||
case 0x33444D46: // "3DMF"
|
||||
@@ -683,8 +684,7 @@ namespace Claunia.RsrcFork
|
||||
return "MC680x0 Code";
|
||||
case 0x5F505043: // "_PPC"
|
||||
return "PowerPC Code";
|
||||
default:
|
||||
return null;
|
||||
default: return null;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -695,8 +695,7 @@ namespace Claunia.RsrcFork
|
||||
/// <param name="OSType">The OSTYPE.</param>
|
||||
public static string GetName(string OSType)
|
||||
{
|
||||
if(OSType.Length != 4)
|
||||
return null;
|
||||
if(OSType.Length != 4) return null;
|
||||
|
||||
byte[] typB = Encoding.ASCII.GetBytes(OSType);
|
||||
uint type = BitConverter.ToUInt32(typB.Reverse().ToArray(), 0);
|
||||
@@ -705,4 +704,3 @@ namespace Claunia.RsrcFork
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user