SparseIntArray.smali
.class public Lcom/tencent/tinker/android/utils/SparseIntArray;
.super Ljava/lang/Object;
# interfaces
.implements Ljava/lang/Cloneable;
# static fields
.field private static final EMPTY_INT_ARRAY:[I
# instance fields
.field private mKeys:[I
.field private mSize:I
.field private mValues:[I
# direct methods
.method static constructor <clinit>()V
.registers 1
const/4 v0, 0x0
new-array v0, v0, [I
sput-object v0, Lcom/tencent/tinker/android/utils/SparseIntArray;->EMPTY_INT_ARRAY:[I
return-void
.end method
.method public constructor <init>()V
.registers 2
const/16 v0, 0xa
invoke-direct {p0, v0}, Lcom/tencent/tinker/android/utils/SparseIntArray;-><init>(I)V
return-void
.end method
.method public constructor <init>(I)V
.registers 3
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
if-nez p1, :cond_11
sget-object v0, Lcom/tencent/tinker/android/utils/SparseIntArray;->EMPTY_INT_ARRAY:[I
iput-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
sget-object v0, Lcom/tencent/tinker/android/utils/SparseIntArray;->EMPTY_INT_ARRAY:[I
iput-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mValues:[I
:goto_d
const/4 v0, 0x0
iput v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
return-void
:cond_11
new-array v0, p1, [I
iput-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
iget-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
array-length v0, v0
new-array v0, v0, [I
iput-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mValues:[I
goto :goto_d
.end method
.method private appendElementIntoIntArray([III)[I
.registers 7
const/4 v2, 0x0
array-length v0, p1
if-le p2, v0, :cond_2a
new-instance v0, Ljava/lang/IllegalArgumentException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v2, "Bad currentSize, originalSize: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
array-length v2, p1
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
const-string/jumbo v2, " currentSize: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
:cond_2a
add-int/lit8 v0, p2, 0x1
array-length v1, p1
if-le v0, v1, :cond_39
invoke-static {p2}, Lcom/tencent/tinker/android/utils/SparseIntArray;->growSize(I)I
move-result v0
new-array v0, v0, [I
invoke-static {p1, v2, v0, v2, p2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
move-object p1, v0
:cond_39
aput p3, p1, p2
return-object p1
.end method
.method private binarySearch([III)I
.registers 8
const/4 v1, 0x0
add-int/lit8 v0, p2, -0x1
:goto_3
if-gt v1, v0, :cond_17
add-int v2, v1, v0
ushr-int/lit8 v2, v2, 0x1
aget v3, p1, v2
if-ge v3, p3, :cond_10
add-int/lit8 v1, v2, 0x1
goto :goto_3
:cond_10
if-le v3, p3, :cond_15
add-int/lit8 v0, v2, -0x1
goto :goto_3
:cond_15
move v0, v2
:goto_16
return v0
:cond_17
xor-int/lit8 v0, v1, -0x1
goto :goto_16
.end method
.method public static growSize(I)I
.registers 2
const/4 v0, 0x4
if-gt p0, v0, :cond_6
const/16 v0, 0x8
:goto_5
return v0
:cond_6
shr-int/lit8 v0, p0, 0x1
add-int/2addr v0, p0
goto :goto_5
.end method
.method private insertElementIntoIntArray([IIII)[I
.registers 8
const/4 v2, 0x0
array-length v0, p1
if-le p2, v0, :cond_2a
new-instance v0, Ljava/lang/IllegalArgumentException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v2, "Bad currentSize, originalSize: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
array-length v2, p1
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
const-string/jumbo v2, " currentSize: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
:cond_2a
add-int/lit8 v0, p2, 0x1
array-length v1, p1
if-gt v0, v1, :cond_39
add-int/lit8 v0, p3, 0x1
sub-int v1, p2, p3
invoke-static {p1, p3, p1, v0, v1}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
aput p4, p1, p3
:goto_38
return-object p1
:cond_39
invoke-static {p2}, Lcom/tencent/tinker/android/utils/SparseIntArray;->growSize(I)I
move-result v0
new-array v0, v0, [I
invoke-static {p1, v2, v0, v2, p3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
aput p4, v0, p3
add-int/lit8 v1, p3, 0x1
array-length v2, p1
sub-int/2addr v2, p3
invoke-static {p1, p3, v0, v1, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
move-object p1, v0
goto :goto_38
.end method
# virtual methods
.method public append(II)V
.registers 5
iget v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
if-eqz v0, :cond_12
iget-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
iget v1, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
add-int/lit8 v1, v1, -0x1
aget v0, v0, v1
if-gt p1, v0, :cond_12
invoke-virtual {p0, p1, p2}, Lcom/tencent/tinker/android/utils/SparseIntArray;->put(II)V
:goto_11
return-void
:cond_12
iget-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
iget v1, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
invoke-direct {p0, v0, v1, p1}, Lcom/tencent/tinker/android/utils/SparseIntArray;->appendElementIntoIntArray([III)[I
move-result-object v0
iput-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
iget-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mValues:[I
iget v1, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
invoke-direct {p0, v0, v1, p2}, Lcom/tencent/tinker/android/utils/SparseIntArray;->appendElementIntoIntArray([III)[I
move-result-object v0
iput-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mValues:[I
iget v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
add-int/lit8 v0, v0, 0x1
iput v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
goto :goto_11
.end method
.method public clear()V
.registers 2
const/4 v0, 0x0
iput v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
return-void
.end method
.method public clone()Lcom/tencent/tinker/android/utils/SparseIntArray;
.registers 3
const/4 v1, 0x0
:try_start_1
invoke-super {p0}, Ljava/lang/Object;->clone()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/tencent/tinker/android/utils/SparseIntArray;
:try_end_7
.catch Ljava/lang/CloneNotSupportedException; {:try_start_1 .. :try_end_7} :catch_1c
:try_start_7
iget-object v1, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
invoke-virtual {v1}, [I->clone()Ljava/lang/Object;
move-result-object v1
check-cast v1, [I
iput-object v1, v0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
iget-object v1, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mValues:[I
invoke-virtual {v1}, [I->clone()Ljava/lang/Object;
move-result-object v1
check-cast v1, [I
iput-object v1, v0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mValues:[I
:try_end_1b
.catch Ljava/lang/CloneNotSupportedException; {:try_start_7 .. :try_end_1b} :catch_1f
:goto_1b
return-object v0
:catch_1c
move-exception v0
move-object v0, v1
goto :goto_1b
:catch_1f
move-exception v1
goto :goto_1b
.end method
.method public bridge synthetic clone()Ljava/lang/Object;
.registers 2
invoke-virtual {p0}, Lcom/tencent/tinker/android/utils/SparseIntArray;->clone()Lcom/tencent/tinker/android/utils/SparseIntArray;
move-result-object v0
return-object v0
.end method
.method public containsKey(I)Z
.registers 3
invoke-virtual {p0, p1}, Lcom/tencent/tinker/android/utils/SparseIntArray;->indexOfKey(I)I
move-result v0
if-ltz v0, :cond_8
const/4 v0, 0x1
:goto_7
return v0
:cond_8
const/4 v0, 0x0
goto :goto_7
.end method
.method public delete(I)V
.registers 4
iget-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
iget v1, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
invoke-direct {p0, v0, v1, p1}, Lcom/tencent/tinker/android/utils/SparseIntArray;->binarySearch([III)I
move-result v0
if-ltz v0, :cond_d
invoke-virtual {p0, v0}, Lcom/tencent/tinker/android/utils/SparseIntArray;->removeAt(I)V
:cond_d
return-void
.end method
.method public get(I)I
.registers 3
const/4 v0, 0x0
invoke-virtual {p0, p1, v0}, Lcom/tencent/tinker/android/utils/SparseIntArray;->get(II)I
move-result v0
return v0
.end method
.method public get(II)I
.registers 5
iget-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
iget v1, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
invoke-direct {p0, v0, v1, p1}, Lcom/tencent/tinker/android/utils/SparseIntArray;->binarySearch([III)I
move-result v0
if-gez v0, :cond_b
:goto_a
return p2
:cond_b
iget-object v1, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mValues:[I
aget p2, v1, v0
goto :goto_a
.end method
.method public indexOfKey(I)I
.registers 4
iget-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
iget v1, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
invoke-direct {p0, v0, v1, p1}, Lcom/tencent/tinker/android/utils/SparseIntArray;->binarySearch([III)I
move-result v0
return v0
.end method
.method public indexOfValue(I)I
.registers 4
const/4 v0, 0x0
:goto_1
iget v1, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
if-ge v0, v1, :cond_f
iget-object v1, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mValues:[I
aget v1, v1, v0
if-ne v1, p1, :cond_c
:goto_b
return v0
:cond_c
add-int/lit8 v0, v0, 0x1
goto :goto_1
:cond_f
const/4 v0, -0x1
goto :goto_b
.end method
.method public keyAt(I)I
.registers 3
iget-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
aget v0, v0, p1
return v0
.end method
.method public put(II)V
.registers 6
iget-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
iget v1, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
invoke-direct {p0, v0, v1, p1}, Lcom/tencent/tinker/android/utils/SparseIntArray;->binarySearch([III)I
move-result v0
if-ltz v0, :cond_f
iget-object v1, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mValues:[I
aput p2, v1, v0
:goto_e
return-void
:cond_f
xor-int/lit8 v0, v0, -0x1
iget-object v1, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
iget v2, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
invoke-direct {p0, v1, v2, v0, p1}, Lcom/tencent/tinker/android/utils/SparseIntArray;->insertElementIntoIntArray([IIII)[I
move-result-object v1
iput-object v1, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
iget-object v1, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mValues:[I
iget v2, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
invoke-direct {p0, v1, v2, v0, p2}, Lcom/tencent/tinker/android/utils/SparseIntArray;->insertElementIntoIntArray([IIII)[I
move-result-object v0
iput-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mValues:[I
iget v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
add-int/lit8 v0, v0, 0x1
iput v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
goto :goto_e
.end method
.method public removeAt(I)V
.registers 7
iget-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
add-int/lit8 v1, p1, 0x1
iget-object v2, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mKeys:[I
iget v3, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
add-int/lit8 v4, p1, 0x1
sub-int/2addr v3, v4
invoke-static {v0, v1, v2, p1, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
iget-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mValues:[I
add-int/lit8 v1, p1, 0x1
iget-object v2, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mValues:[I
iget v3, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
add-int/lit8 v4, p1, 0x1
sub-int/2addr v3, v4
invoke-static {v0, v1, v2, p1, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
iget v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
add-int/lit8 v0, v0, -0x1
iput v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
return-void
.end method
.method public size()I
.registers 2
iget v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
return v0
.end method
.method public toString()Ljava/lang/String;
.registers 4
invoke-virtual {p0}, Lcom/tencent/tinker/android/utils/SparseIntArray;->size()I
move-result v0
if-gtz v0, :cond_a
const-string/jumbo v0, "{}"
:goto_9
return-object v0
:cond_a
new-instance v1, Ljava/lang/StringBuilder;
iget v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
mul-int/lit8 v0, v0, 0x1c
invoke-direct {v1, v0}, Ljava/lang/StringBuilder;-><init>(I)V
const/16 v0, 0x7b
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
const/4 v0, 0x0
:goto_19
iget v2, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mSize:I
if-ge v0, v2, :cond_3b
if-lez v0, :cond_25
const-string/jumbo v2, ", "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
:cond_25
invoke-virtual {p0, v0}, Lcom/tencent/tinker/android/utils/SparseIntArray;->keyAt(I)I
move-result v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const/16 v2, 0x3d
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
invoke-virtual {p0, v0}, Lcom/tencent/tinker/android/utils/SparseIntArray;->valueAt(I)I
move-result v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
add-int/lit8 v0, v0, 0x1
goto :goto_19
:cond_3b
const/16 v0, 0x7d
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
goto :goto_9
.end method
.method public valueAt(I)I
.registers 3
iget-object v0, p0, Lcom/tencent/tinker/android/utils/SparseIntArray;->mValues:[I
aget v0, v0, p1
return v0
.end method