mirror of
https://github.com/kwsch/PKHeX
synced 2025-01-07 01:58:46 +00:00
52a67f2425
Introducing a new PKM format: SK2 Split ICaughtData2 off of PK2 so it can be shared with SK2 when type-checks occur Add conversion for PK2<->SK2 Split the split-buffer handling for GBPKM to GBPKML (what a name), so that I can reuse shared accessor logic for SK2.
67 lines
2.1 KiB
C#
67 lines
2.1 KiB
C#
using System;
|
|
|
|
namespace PKHeX.Core
|
|
{
|
|
public static class StadiumUtil
|
|
{
|
|
public static bool IsMagicPresentEither(byte[] data, int size, uint magic)
|
|
{
|
|
if (IsMagicPresent(data, size, magic))
|
|
return true;
|
|
|
|
if (IsMagicPresentSwap(data, size, magic))
|
|
return true;
|
|
|
|
return false;
|
|
}
|
|
|
|
public static bool IsMagicPresent(byte[] data, int size, uint magic)
|
|
{
|
|
// Check footers of first few teams to see if the magic value is there.
|
|
for (int i = 0; i < 10; i++)
|
|
{
|
|
if (BitConverter.ToUInt32(data, size - 6 + (i * size)) != magic)
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
public static bool IsMagicPresentSwap(byte[] data, int size, uint magic)
|
|
{
|
|
// Check footers of first few teams to see if the magic value is there.
|
|
var left = (ushort)magic;
|
|
var right = (ushort)(magic >> 16);
|
|
left = (ushort)((left >> 8) | (left << 8));
|
|
right = (ushort)((right >> 8) | (right << 8));
|
|
|
|
for (int i = 0; i < 10; i++)
|
|
{
|
|
var ofs = size - 6 + (i * size);
|
|
if (BitConverter.ToUInt16(data, ofs - 2) != left) // OP
|
|
return false;
|
|
if (BitConverter.ToUInt16(data, ofs + 4) != right) // EK
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
public static bool IsMagicPresentAbsolute(byte[] data, int offset, uint magic)
|
|
{
|
|
var actual = BitConverter.ToUInt32(data, offset);
|
|
if (actual == magic) // POKE
|
|
return true;
|
|
|
|
var left = (ushort)magic;
|
|
var right = (ushort)(magic >> 16);
|
|
left = (ushort)((left >> 8) | (left << 8));
|
|
right = (ushort)((right >> 8) | (right << 8));
|
|
|
|
if (BitConverter.ToUInt16(data, offset - 2) != left) // OP
|
|
return false;
|
|
if (BitConverter.ToUInt16(data, offset + 4) != right) // EK
|
|
return false;
|
|
|
|
return true;
|
|
}
|
|
}
|
|
}
|