mirror of
https://github.com/Pinball3D/Rabbit-R1.git
synced 2025-01-09 13:43:22 +00:00
280 lines
7.4 KiB
Java
280 lines
7.4 KiB
Java
package com.google.zxing.common;
|
|
|
|
import java.util.Arrays;
|
|
import okhttp3.internal.ws.WebSocketProtocol;
|
|
|
|
/* loaded from: classes3.dex */
|
|
public final class BitArray implements Cloneable {
|
|
private int[] bits;
|
|
private int size;
|
|
|
|
public int[] getBitArray() {
|
|
return this.bits;
|
|
}
|
|
|
|
public int getSize() {
|
|
return this.size;
|
|
}
|
|
|
|
public BitArray() {
|
|
this.size = 0;
|
|
this.bits = new int[1];
|
|
}
|
|
|
|
public BitArray(int i) {
|
|
this.size = i;
|
|
this.bits = makeArray(i);
|
|
}
|
|
|
|
BitArray(int[] iArr, int i) {
|
|
this.bits = iArr;
|
|
this.size = i;
|
|
}
|
|
|
|
public int getSizeInBytes() {
|
|
return (this.size + 7) / 8;
|
|
}
|
|
|
|
private void ensureCapacity(int i) {
|
|
if (i > (this.bits.length << 5)) {
|
|
int[] makeArray = makeArray(i);
|
|
int[] iArr = this.bits;
|
|
System.arraycopy(iArr, 0, makeArray, 0, iArr.length);
|
|
this.bits = makeArray;
|
|
}
|
|
}
|
|
|
|
public boolean get(int i) {
|
|
return (this.bits[i / 32] & (1 << (i & 31))) != 0;
|
|
}
|
|
|
|
public void set(int i) {
|
|
int[] iArr = this.bits;
|
|
int i2 = i / 32;
|
|
iArr[i2] = (1 << (i & 31)) | iArr[i2];
|
|
}
|
|
|
|
public void flip(int i) {
|
|
int[] iArr = this.bits;
|
|
int i2 = i / 32;
|
|
iArr[i2] = (1 << (i & 31)) ^ iArr[i2];
|
|
}
|
|
|
|
public int getNextSet(int i) {
|
|
int i2 = this.size;
|
|
if (i >= i2) {
|
|
return i2;
|
|
}
|
|
int i3 = i / 32;
|
|
int i4 = (-(1 << (i & 31))) & this.bits[i3];
|
|
while (i4 == 0) {
|
|
i3++;
|
|
int[] iArr = this.bits;
|
|
if (i3 == iArr.length) {
|
|
return this.size;
|
|
}
|
|
i4 = iArr[i3];
|
|
}
|
|
return Math.min((i3 << 5) + Integer.numberOfTrailingZeros(i4), this.size);
|
|
}
|
|
|
|
public int getNextUnset(int i) {
|
|
int i2 = this.size;
|
|
if (i >= i2) {
|
|
return i2;
|
|
}
|
|
int i3 = i / 32;
|
|
int i4 = (-(1 << (i & 31))) & (~this.bits[i3]);
|
|
while (i4 == 0) {
|
|
i3++;
|
|
int[] iArr = this.bits;
|
|
if (i3 == iArr.length) {
|
|
return this.size;
|
|
}
|
|
i4 = ~iArr[i3];
|
|
}
|
|
return Math.min((i3 << 5) + Integer.numberOfTrailingZeros(i4), this.size);
|
|
}
|
|
|
|
public void setBulk(int i, int i2) {
|
|
this.bits[i / 32] = i2;
|
|
}
|
|
|
|
public void setRange(int i, int i2) {
|
|
if (i2 < i || i < 0 || i2 > this.size) {
|
|
throw new IllegalArgumentException();
|
|
}
|
|
if (i2 == i) {
|
|
return;
|
|
}
|
|
int i3 = i2 - 1;
|
|
int i4 = i / 32;
|
|
int i5 = i3 / 32;
|
|
int i6 = i4;
|
|
while (i6 <= i5) {
|
|
int i7 = 31;
|
|
int i8 = i6 > i4 ? 0 : i & 31;
|
|
if (i6 >= i5) {
|
|
i7 = 31 & i3;
|
|
}
|
|
int i9 = (2 << i7) - (1 << i8);
|
|
int[] iArr = this.bits;
|
|
iArr[i6] = i9 | iArr[i6];
|
|
i6++;
|
|
}
|
|
}
|
|
|
|
public void clear() {
|
|
int length = this.bits.length;
|
|
for (int i = 0; i < length; i++) {
|
|
this.bits[i] = 0;
|
|
}
|
|
}
|
|
|
|
public boolean isRange(int i, int i2, boolean z) {
|
|
if (i2 < i || i < 0 || i2 > this.size) {
|
|
throw new IllegalArgumentException();
|
|
}
|
|
if (i2 == i) {
|
|
return true;
|
|
}
|
|
int i3 = i2 - 1;
|
|
int i4 = i / 32;
|
|
int i5 = i3 / 32;
|
|
int i6 = i4;
|
|
while (i6 <= i5) {
|
|
int i7 = (2 << (i6 >= i5 ? 31 & i3 : 31)) - (1 << (i6 > i4 ? 0 : i & 31));
|
|
int i8 = this.bits[i6] & i7;
|
|
if (!z) {
|
|
i7 = 0;
|
|
}
|
|
if (i8 != i7) {
|
|
return false;
|
|
}
|
|
i6++;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
public void appendBit(boolean z) {
|
|
ensureCapacity(this.size + 1);
|
|
if (z) {
|
|
int[] iArr = this.bits;
|
|
int i = this.size;
|
|
int i2 = i / 32;
|
|
iArr[i2] = (1 << (i & 31)) | iArr[i2];
|
|
}
|
|
this.size++;
|
|
}
|
|
|
|
public void appendBits(int i, int i2) {
|
|
if (i2 < 0 || i2 > 32) {
|
|
throw new IllegalArgumentException("Num bits must be between 0 and 32");
|
|
}
|
|
ensureCapacity(this.size + i2);
|
|
while (i2 > 0) {
|
|
boolean z = true;
|
|
if (((i >> (i2 - 1)) & 1) != 1) {
|
|
z = false;
|
|
}
|
|
appendBit(z);
|
|
i2--;
|
|
}
|
|
}
|
|
|
|
public void appendBitArray(BitArray bitArray) {
|
|
int i = bitArray.size;
|
|
ensureCapacity(this.size + i);
|
|
for (int i2 = 0; i2 < i; i2++) {
|
|
appendBit(bitArray.get(i2));
|
|
}
|
|
}
|
|
|
|
public void xor(BitArray bitArray) {
|
|
if (this.size != bitArray.size) {
|
|
throw new IllegalArgumentException("Sizes don't match");
|
|
}
|
|
int i = 0;
|
|
while (true) {
|
|
int[] iArr = this.bits;
|
|
if (i >= iArr.length) {
|
|
return;
|
|
}
|
|
iArr[i] = iArr[i] ^ bitArray.bits[i];
|
|
i++;
|
|
}
|
|
}
|
|
|
|
public void toBytes(int i, byte[] bArr, int i2, int i3) {
|
|
for (int i4 = 0; i4 < i3; i4++) {
|
|
int i5 = 0;
|
|
for (int i6 = 0; i6 < 8; i6++) {
|
|
if (get(i)) {
|
|
i5 |= 1 << (7 - i6);
|
|
}
|
|
i++;
|
|
}
|
|
bArr[i2 + i4] = (byte) i5;
|
|
}
|
|
}
|
|
|
|
public void reverse() {
|
|
int[] iArr = new int[this.bits.length];
|
|
int i = (this.size - 1) / 32;
|
|
int i2 = i + 1;
|
|
for (int i3 = 0; i3 < i2; i3++) {
|
|
long j = this.bits[i3];
|
|
long j2 = ((j & 1431655765) << 1) | ((j >> 1) & 1431655765);
|
|
long j3 = ((j2 & 858993459) << 2) | ((j2 >> 2) & 858993459);
|
|
long j4 = ((j3 & 252645135) << 4) | ((j3 >> 4) & 252645135);
|
|
long j5 = ((j4 & 16711935) << 8) | ((j4 >> 8) & 16711935);
|
|
iArr[i - i3] = (int) (((j5 & WebSocketProtocol.PAYLOAD_SHORT_MAX) << 16) | ((j5 >> 16) & WebSocketProtocol.PAYLOAD_SHORT_MAX));
|
|
}
|
|
int i4 = this.size;
|
|
int i5 = i2 << 5;
|
|
if (i4 != i5) {
|
|
int i6 = i5 - i4;
|
|
int i7 = iArr[0] >>> i6;
|
|
for (int i8 = 1; i8 < i2; i8++) {
|
|
int i9 = iArr[i8];
|
|
iArr[i8 - 1] = i7 | (i9 << (32 - i6));
|
|
i7 = i9 >>> i6;
|
|
}
|
|
iArr[i] = i7;
|
|
}
|
|
this.bits = iArr;
|
|
}
|
|
|
|
private static int[] makeArray(int i) {
|
|
return new int[(i + 31) / 32];
|
|
}
|
|
|
|
public boolean equals(Object obj) {
|
|
if (!(obj instanceof BitArray)) {
|
|
return false;
|
|
}
|
|
BitArray bitArray = (BitArray) obj;
|
|
return this.size == bitArray.size && Arrays.equals(this.bits, bitArray.bits);
|
|
}
|
|
|
|
public int hashCode() {
|
|
return (this.size * 31) + Arrays.hashCode(this.bits);
|
|
}
|
|
|
|
public String toString() {
|
|
int i = this.size;
|
|
StringBuilder sb = new StringBuilder(i + (i / 8) + 1);
|
|
for (int i2 = 0; i2 < this.size; i2++) {
|
|
if ((i2 & 7) == 0) {
|
|
sb.append(' ');
|
|
}
|
|
sb.append(get(i2) ? 'X' : '.');
|
|
}
|
|
return sb.toString();
|
|
}
|
|
|
|
/* renamed from: clone, reason: merged with bridge method [inline-methods] */
|
|
public BitArray m5585clone() {
|
|
return new BitArray((int[]) this.bits.clone(), this.size);
|
|
}
|
|
}
|