From 07fb87b4413d9ac3cad1bdd780d30415f197b271 Mon Sep 17 00:00:00 2001 From: Ryan Teal Date: Wed, 3 Jul 2019 21:02:59 +0100 Subject: [PATCH] Use NRO0 verification instead of ASET verification --- .../java/gq/cyuubi/lightswitch/NroMeta.java | 18 ++---------------- 1 file changed, 2 insertions(+), 16 deletions(-) diff --git a/app/src/main/java/gq/cyuubi/lightswitch/NroMeta.java b/app/src/main/java/gq/cyuubi/lightswitch/NroMeta.java index 356246cb..0f959f45 100644 --- a/app/src/main/java/gq/cyuubi/lightswitch/NroMeta.java +++ b/app/src/main/java/gq/cyuubi/lightswitch/NroMeta.java @@ -73,24 +73,10 @@ public class NroMeta { public static boolean verifyFile(String file) { try { RandomAccessFile f = new RandomAccessFile(file, "r"); - f.seek(0x18); // Skip to NroHeader.size - int asetOffset = Integer.reverseBytes(f.readInt()); - f.seek(asetOffset); // Skip to the offset specified by NroHeader.size + f.seek(0x10); // Skip to NroHeader.magic byte[] buffer = new byte[4]; f.read(buffer); - if (!(new String(buffer).equals("ASET"))) - return false; - - f.skipBytes(0x4); - long iconOffset = Long.reverseBytes(f.readLong()); - int iconSize = Integer.reverseBytes(f.readInt()); - if (iconOffset == 0 || iconSize == 0) - return false; - - f.seek(asetOffset + 0x18); - long nacpOffset = Long.reverseBytes(f.readLong()); - long nacpSize = Long.reverseBytes(f.readLong()); - if (nacpOffset == 0 || nacpSize == 0) + if (!(new String(buffer).equals("NRO0"))) return false; } catch (IOException e) { return false;