import net.runelite.mapping.Export; import net.runelite.mapping.Implements; import net.runelite.mapping.ObfuscatedGetter; import net.runelite.mapping.ObfuscatedName; import net.runelite.mapping.ObfuscatedSignature; @ObfuscatedName("hx") @Implements("Huffman") public class Huffman { @ObfuscatedName("as") @ObfuscatedGetter( intValue = 821038913 ) static int field2491; @ObfuscatedName("a") @Export("masks") int[] masks; @ObfuscatedName("t") @Export("bits") byte[] bits; @ObfuscatedName("n") @Export("keys") int[] keys; public Huffman(byte[] var1) { int var2 = var1.length; this.masks = new int[var2]; this.bits = var1; int[] var3 = new int[33]; this.keys = new int[8]; int var4 = 0; for (int var5 = 0; var5 < var2; ++var5) { byte var6 = var1[var5]; if (var6 != 0) { int var7 = 1 << 32 - var6; int var8 = var3[var6]; this.masks[var5] = var8; int var9; int var10; int var11; int var12; if ((var8 & var7) != 0) { var9 = var3[var6 - 1]; } else { var9 = var8 | var7; for (var10 = var6 - 1; var10 >= 1; --var10) { var11 = var3[var10]; if (var11 != var8) { break; } var12 = 1 << 32 - var10; if ((var11 & var12) != 0) { var3[var10] = var3[var10 - 1]; break; } var3[var10] = var11 | var12; } } var3[var6] = var9; for (var10 = var6 + 1; var10 <= 32; ++var10) { if (var8 == var3[var10]) { var3[var10] = var9; } } var10 = 0; for (var11 = 0; var11 < var6; ++var11) { var12 = Integer.MIN_VALUE >>> var11; if ((var8 & var12) != 0) { if (this.keys[var10] == 0) { this.keys[var10] = var4; } var10 = this.keys[var10]; } else { ++var10; } if (var10 >= this.keys.length) { int[] var13 = new int[this.keys.length * 2]; for (int var14 = 0; var14 < this.keys.length; ++var14) { var13[var14] = this.keys[var14]; } this.keys = var13; } var12 >>>= 1; } this.keys[var10] = ~var5; if (var10 >= var4) { var4 = var10 + 1; } } } } @ObfuscatedName("a") @ObfuscatedSignature( signature = "([BII[BIB)I", garbageValue = "14" ) @Export("compress") int compress(byte[] var1, int var2, int var3, byte[] var4, int var5) { int var6 = 0; int var7 = var5 << 3; for (var3 += var2; var2 < var3; ++var2) { int var8 = var1[var2] & 255; int var9 = this.masks[var8]; byte var10 = this.bits[var8]; if (var10 == 0) { throw new RuntimeException("" + var8); } int var11 = var7 >> 3; int var12 = var7 & 7; var6 &= -var12 >> 31; int var13 = (var10 + var12 - 1 >> 3) + var11; var12 += 24; var4[var11] = (byte)(var6 |= var9 >>> var12); if (var11 < var13) { ++var11; var12 -= 8; var4[var11] = (byte)(var6 = var9 >>> var12); if (var11 < var13) { ++var11; var12 -= 8; var4[var11] = (byte)(var6 = var9 >>> var12); if (var11 < var13) { ++var11; var12 -= 8; var4[var11] = (byte)(var6 = var9 >>> var12); if (var11 < var13) { ++var11; var12 -= 8; var4[var11] = (byte)(var6 = var9 << -var12); } } } } var7 += var10; } return (var7 + 7 >> 3) - var5; } @ObfuscatedName("t") @ObfuscatedSignature( signature = "([BI[BIIB)I", garbageValue = "-1" ) @Export("decompress") int decompress(byte[] var1, int var2, byte[] var3, int var4, int var5) { if (var5 == 0) { return 0; } else { int var6 = 0; var5 += var4; int var7 = var2; while (true) { byte var8 = var1[var7]; if (var8 < 0) { var6 = this.keys[var6]; } else { ++var6; } int var9; if ((var9 = this.keys[var6]) < 0) { var3[var4++] = (byte)(~var9); if (var4 >= var5) { break; } var6 = 0; } if ((var8 & 64) != 0) { var6 = this.keys[var6]; } else { ++var6; } if ((var9 = this.keys[var6]) < 0) { var3[var4++] = (byte)(~var9); if (var4 >= var5) { break; } var6 = 0; } if ((var8 & 32) != 0) { var6 = this.keys[var6]; } else { ++var6; } if ((var9 = this.keys[var6]) < 0) { var3[var4++] = (byte)(~var9); if (var4 >= var5) { break; } var6 = 0; } if ((var8 & 16) != 0) { var6 = this.keys[var6]; } else { ++var6; } if ((var9 = this.keys[var6]) < 0) { var3[var4++] = (byte)(~var9); if (var4 >= var5) { break; } var6 = 0; } if ((var8 & 8) != 0) { var6 = this.keys[var6]; } else { ++var6; } if ((var9 = this.keys[var6]) < 0) { var3[var4++] = (byte)(~var9); if (var4 >= var5) { break; } var6 = 0; } if ((var8 & 4) != 0) { var6 = this.keys[var6]; } else { ++var6; } if ((var9 = this.keys[var6]) < 0) { var3[var4++] = (byte)(~var9); if (var4 >= var5) { break; } var6 = 0; } if ((var8 & 2) != 0) { var6 = this.keys[var6]; } else { ++var6; } if ((var9 = this.keys[var6]) < 0) { var3[var4++] = (byte)(~var9); if (var4 >= var5) { break; } var6 = 0; } if ((var8 & 1) != 0) { var6 = this.keys[var6]; } else { ++var6; } if ((var9 = this.keys[var6]) < 0) { var3[var4++] = (byte)(~var9); if (var4 >= var5) { break; } var6 = 0; } ++var7; } return var7 + 1 - var2; } } @ObfuscatedName("a") @ObfuscatedSignature( signature = "([I[II)V", garbageValue = "1107408934" ) public static void method4104(int[] var0, int[] var1) { if (var0 != null && var1 != null) { ByteArrayPool.ByteArrayPool_alternativeSizes = var0; class222.ByteArrayPool_altSizeArrayCounts = new int[var0.length]; HorizontalAlignment.ByteArrayPool_arrays = new byte[var0.length][][]; for (int var2 = 0; var2 < ByteArrayPool.ByteArrayPool_alternativeSizes.length; ++var2) { HorizontalAlignment.ByteArrayPool_arrays[var2] = new byte[var1[var2]][]; } } else { ByteArrayPool.ByteArrayPool_alternativeSizes = null; class222.ByteArrayPool_altSizeArrayCounts = null; HorizontalAlignment.ByteArrayPool_arrays = null; } } }