mirror of
https://github.com/aaru-dps/Aaru.git
synced 2025-12-16 19:24:25 +00:00
Override Marshal.SizeOf in Helpers and use it instead of System's.
This commit is contained in:
@@ -31,10 +31,10 @@
|
||||
// ****************************************************************************/
|
||||
|
||||
using System.IO;
|
||||
using System.Runtime.InteropServices;
|
||||
using System.Text.RegularExpressions;
|
||||
using DiscImageChef.CommonTypes.Interfaces;
|
||||
using DiscImageChef.Console;
|
||||
using DiscImageChef.Helpers;
|
||||
|
||||
namespace DiscImageChef.DiscImages
|
||||
{
|
||||
@@ -44,13 +44,13 @@ namespace DiscImageChef.DiscImages
|
||||
{
|
||||
Stream stream = imageFilter.GetDataForkStream();
|
||||
|
||||
if((stream.Length - Marshal.SizeOf(typeof(DriFooter))) % 512 != 0) return false;
|
||||
if((stream.Length - Marshal.SizeOf<DriFooter>()) % 512 != 0) return false;
|
||||
|
||||
byte[] buffer = new byte[Marshal.SizeOf(typeof(DriFooter))];
|
||||
byte[] buffer = new byte[Marshal.SizeOf<DriFooter>()];
|
||||
stream.Seek(-buffer.Length, SeekOrigin.End);
|
||||
stream.Read(buffer, 0, buffer.Length);
|
||||
|
||||
DriFooter tmpFooter = Helpers.Marshal.ByteArrayToStructureLittleEndian<DriFooter>(buffer);
|
||||
DriFooter tmpFooter = Marshal.ByteArrayToStructureLittleEndian<DriFooter>(buffer);
|
||||
|
||||
string sig = StringHandlers.CToString(tmpFooter.signature);
|
||||
|
||||
@@ -89,7 +89,7 @@ namespace DiscImageChef.DiscImages
|
||||
if(tmpFooter.bpb.sptrack * tmpFooter.bpb.cylinders * tmpFooter.bpb.heads != tmpFooter.bpb.sectors)
|
||||
return false;
|
||||
|
||||
return tmpFooter.bpb.sectors * tmpFooter.bpb.bps + Marshal.SizeOf(tmpFooter) == stream.Length;
|
||||
return tmpFooter.bpb.sectors * tmpFooter.bpb.bps + Marshal.SizeOf<DriFooter>() == stream.Length;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -32,12 +32,12 @@
|
||||
|
||||
using System;
|
||||
using System.IO;
|
||||
using System.Runtime.InteropServices;
|
||||
using System.Text.RegularExpressions;
|
||||
using DiscImageChef.CommonTypes;
|
||||
using DiscImageChef.CommonTypes.Enums;
|
||||
using DiscImageChef.CommonTypes.Interfaces;
|
||||
using DiscImageChef.Console;
|
||||
using DiscImageChef.Helpers;
|
||||
|
||||
namespace DiscImageChef.DiscImages
|
||||
{
|
||||
@@ -47,13 +47,13 @@ namespace DiscImageChef.DiscImages
|
||||
{
|
||||
Stream stream = imageFilter.GetDataForkStream();
|
||||
|
||||
if((stream.Length - Marshal.SizeOf(typeof(DriFooter))) % 512 != 0) return false;
|
||||
if((stream.Length - Marshal.SizeOf<DriFooter>()) % 512 != 0) return false;
|
||||
|
||||
byte[] buffer = new byte[Marshal.SizeOf(typeof(DriFooter))];
|
||||
byte[] buffer = new byte[Marshal.SizeOf<DriFooter>()];
|
||||
stream.Seek(-buffer.Length, SeekOrigin.End);
|
||||
stream.Read(buffer, 0, buffer.Length);
|
||||
|
||||
footer = Helpers.Marshal.ByteArrayToStructureLittleEndian<DriFooter>(buffer);
|
||||
footer = Marshal.ByteArrayToStructureLittleEndian<DriFooter>(buffer);
|
||||
|
||||
string sig = StringHandlers.CToString(footer.signature);
|
||||
|
||||
@@ -64,7 +64,7 @@ namespace DiscImageChef.DiscImages
|
||||
|
||||
if(footer.bpb.sptrack * footer.bpb.cylinders * footer.bpb.heads != footer.bpb.sectors) return false;
|
||||
|
||||
if(footer.bpb.sectors * footer.bpb.bps + Marshal.SizeOf(footer) != stream.Length) return false;
|
||||
if(footer.bpb.sectors * footer.bpb.bps + Marshal.SizeOf<DriFooter>() != stream.Length) return false;
|
||||
|
||||
imageInfo.Cylinders = footer.bpb.cylinders;
|
||||
imageInfo.Heads = footer.bpb.heads;
|
||||
@@ -75,7 +75,7 @@ namespace DiscImageChef.DiscImages
|
||||
|
||||
driImageFilter = imageFilter;
|
||||
|
||||
imageInfo.ImageSize = (ulong)(stream.Length - Marshal.SizeOf(footer));
|
||||
imageInfo.ImageSize = (ulong)(stream.Length - Marshal.SizeOf<DriFooter>());
|
||||
imageInfo.CreationTime = imageFilter.GetCreationTime();
|
||||
imageInfo.LastModificationTime = imageFilter.GetLastWriteTime();
|
||||
|
||||
|
||||
@@ -34,11 +34,11 @@ using System;
|
||||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Runtime.InteropServices;
|
||||
using System.Text;
|
||||
using DiscImageChef.CommonTypes;
|
||||
using DiscImageChef.CommonTypes.Enums;
|
||||
using DiscImageChef.CommonTypes.Structs;
|
||||
using DiscImageChef.Helpers;
|
||||
using Schemas;
|
||||
|
||||
namespace DiscImageChef.DiscImages
|
||||
@@ -184,11 +184,11 @@ namespace DiscImageChef.DiscImages
|
||||
return false;
|
||||
}
|
||||
|
||||
byte[] hdr = new byte[Marshal.SizeOf(footer)];
|
||||
IntPtr hdrPtr = Marshal.AllocHGlobal(Marshal.SizeOf(footer));
|
||||
Marshal.StructureToPtr(footer, hdrPtr, true);
|
||||
Marshal.Copy(hdrPtr, hdr, 0, hdr.Length);
|
||||
Marshal.FreeHGlobal(hdrPtr);
|
||||
byte[] hdr = new byte[Marshal.SizeOf<DriFooter>()];
|
||||
IntPtr hdrPtr = System.Runtime.InteropServices.Marshal.AllocHGlobal(Marshal.SizeOf<DriFooter>());
|
||||
System.Runtime.InteropServices.Marshal.StructureToPtr(footer, hdrPtr, true);
|
||||
System.Runtime.InteropServices.Marshal.Copy(hdrPtr, hdr, 0, hdr.Length);
|
||||
System.Runtime.InteropServices.Marshal.FreeHGlobal(hdrPtr);
|
||||
|
||||
writingStream.Seek(0, SeekOrigin.End);
|
||||
writingStream.Write(hdr, 0, hdr.Length);
|
||||
|
||||
Reference in New Issue
Block a user