Files
runelite/runescape-client/src/main/java/Huffman.java
Lucwousin e7a1983158 rev185
2019-10-31 16:57:45 +01:00

325 lines
6.2 KiB
Java

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;
}
}
}