Files
rr3-apk/smali_classes3/com/google/protobuf/SmallSortedMap.smali
Daniel Elliott f3960ee359 Add Discord APKTool decompilation (Smali source for modding)
- Imported from https://github.com/supermegamestre/Project-Real-Resurrection-3
- APKTool decompilation (Smali bytecode) for modding and rebuilding APK
- Supports both 32-bit (armeabi-v7a) and 64-bit (arm64-v8a) architectures
- Includes full Smali source, resources, and native libraries
- Ready to rebuild APK after modifications with apktool b command
- Added comprehensive README-apktool.md with modding guide

This branch complements the JADX branches:
- Use JADX (main/discord-community) to UNDERSTAND code (readable Java)
- Use APKTool (this branch) to MODIFY and REBUILD APK (editable Smali)

Total: 44,417 files, 538.51 MB Smali source code
2026-02-18 16:13:44 -08:00

1271 lines
31 KiB
Smali

.class public Lcom/google/protobuf/SmallSortedMap;
.super Ljava/util/AbstractMap;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/google/protobuf/SmallSortedMap$EmptySet;,
Lcom/google/protobuf/SmallSortedMap$DescendingEntryIterator;,
Lcom/google/protobuf/SmallSortedMap$EntryIterator;,
Lcom/google/protobuf/SmallSortedMap$DescendingEntrySet;,
Lcom/google/protobuf/SmallSortedMap$EntrySet;,
Lcom/google/protobuf/SmallSortedMap$Entry;
}
.end annotation
# instance fields
.field private entryList:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Lcom/google/protobuf/SmallSortedMap.Entry;",
">;"
}
.end annotation
.end field
.field private isImmutable:Z
.field private volatile lazyDescendingEntrySet:Lcom/google/protobuf/SmallSortedMap$DescendingEntrySet;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lcom/google/protobuf/SmallSortedMap.DescendingEntrySet;"
}
.end annotation
.end field
.field private volatile lazyEntrySet:Lcom/google/protobuf/SmallSortedMap$EntrySet;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lcom/google/protobuf/SmallSortedMap.EntrySet;"
}
.end annotation
.end field
.field private final maxArraySize:I
.field private overflowEntries:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/Comparable<",
"Ljava/lang/Object;",
">;",
"Ljava/lang/Object;",
">;"
}
.end annotation
.end field
.field private overflowEntriesDescending:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/Comparable<",
"Ljava/lang/Object;",
">;",
"Ljava/lang/Object;",
">;"
}
.end annotation
.end field
# direct methods
.method private constructor <init>(I)V
.locals 0
.line 146
invoke-direct {p0}, Ljava/util/AbstractMap;-><init>()V
iput p1, p0, Lcom/google/protobuf/SmallSortedMap;->maxArraySize:I
.line 148
invoke-static {}, Ljava/util/Collections;->emptyList()Ljava/util/List;
move-result-object p1
iput-object p1, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 149
invoke-static {}, Ljava/util/Collections;->emptyMap()Ljava/util/Map;
move-result-object p1
iput-object p1, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 150
invoke-static {}, Ljava/util/Collections;->emptyMap()Ljava/util/Map;
move-result-object p1
iput-object p1, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntriesDescending:Ljava/util/Map;
return-void
.end method
.method public synthetic constructor <init>(ILcom/google/protobuf/SmallSortedMap$1;)V
.locals 0
.line 83
invoke-direct {p0, p1}, Lcom/google/protobuf/SmallSortedMap;-><init>(I)V
return-void
.end method
.method public static synthetic access$300(Lcom/google/protobuf/SmallSortedMap;)V
.locals 0
.line 83
invoke-direct {p0}, Lcom/google/protobuf/SmallSortedMap;->checkMutable()V
return-void
.end method
.method public static synthetic access$600(Lcom/google/protobuf/SmallSortedMap;)Ljava/util/List;
.locals 0
.line 83
iget-object p0, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
return-object p0
.end method
.method public static synthetic access$700(Lcom/google/protobuf/SmallSortedMap;)Ljava/util/Map;
.locals 0
.line 83
iget-object p0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
return-object p0
.end method
.method public static synthetic access$800(Lcom/google/protobuf/SmallSortedMap;I)Ljava/lang/Object;
.locals 0
.line 83
invoke-direct {p0, p1}, Lcom/google/protobuf/SmallSortedMap;->removeArrayEntryAt(I)Ljava/lang/Object;
move-result-object p0
return-object p0
.end method
.method public static synthetic access$900(Lcom/google/protobuf/SmallSortedMap;)Ljava/util/Map;
.locals 0
.line 83
iget-object p0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntriesDescending:Ljava/util/Map;
return-object p0
.end method
.method private binarySearchInArray(Ljava/lang/Comparable;)I
.locals 4
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/lang/Comparable<",
"Ljava/lang/Object;",
">;)I"
}
.end annotation
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 316
invoke-interface {v0}, Ljava/util/List;->size()I
move-result v0
add-int/lit8 v1, v0, -0x1
if-ltz v1, :cond_1
iget-object v2, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 322
invoke-interface {v2, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/google/protobuf/SmallSortedMap$Entry;
invoke-virtual {v2}, Lcom/google/protobuf/SmallSortedMap$Entry;->getKey()Ljava/lang/Comparable;
move-result-object v2
invoke-interface {p1, v2}, Ljava/lang/Comparable;->compareTo(Ljava/lang/Object;)I
move-result v2
if-lez v2, :cond_0
add-int/lit8 v0, v0, 0x1
:goto_0
neg-int p1, v0
return p1
:cond_0
if-nez v2, :cond_1
return v1
:cond_1
const/4 v0, 0x0
:goto_1
if-gt v0, v1, :cond_4
add-int v2, v0, v1
.line 331
div-int/lit8 v2, v2, 0x2
iget-object v3, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 332
invoke-interface {v3, v2}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v3
check-cast v3, Lcom/google/protobuf/SmallSortedMap$Entry;
invoke-virtual {v3}, Lcom/google/protobuf/SmallSortedMap$Entry;->getKey()Ljava/lang/Comparable;
move-result-object v3
invoke-interface {p1, v3}, Ljava/lang/Comparable;->compareTo(Ljava/lang/Object;)I
move-result v3
if-gez v3, :cond_2
add-int/lit8 v2, v2, -0x1
move v1, v2
goto :goto_1
:cond_2
if-lez v3, :cond_3
add-int/lit8 v2, v2, 0x1
move v0, v2
goto :goto_1
:cond_3
return v2
:cond_4
add-int/lit8 v0, v0, 0x1
goto :goto_0
.end method
.method private checkMutable()V
.locals 1
iget-boolean v0, p0, Lcom/google/protobuf/SmallSortedMap;->isImmutable:Z
if-nez v0, :cond_0
return-void
.line 369
:cond_0
new-instance v0, Ljava/lang/UnsupportedOperationException;
invoke-direct {v0}, Ljava/lang/UnsupportedOperationException;-><init>()V
throw v0
.end method
.method private ensureEntryArrayMutable()V
.locals 2
.line 388
invoke-direct {p0}, Lcom/google/protobuf/SmallSortedMap;->checkMutable()V
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 389
invoke-interface {v0}, Ljava/util/List;->isEmpty()Z
move-result v0
if-eqz v0, :cond_0
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
instance-of v0, v0, Ljava/util/ArrayList;
if-nez v0, :cond_0
.line 390
new-instance v0, Ljava/util/ArrayList;
iget v1, p0, Lcom/google/protobuf/SmallSortedMap;->maxArraySize:I
invoke-direct {v0, v1}, Ljava/util/ArrayList;-><init>(I)V
iput-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
:cond_0
return-void
.end method
.method private getOverflowEntriesMutable()Ljava/util/SortedMap;
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/SortedMap<",
"Ljava/lang/Comparable<",
"Ljava/lang/Object;",
">;",
"Ljava/lang/Object;",
">;"
}
.end annotation
.line 378
invoke-direct {p0}, Lcom/google/protobuf/SmallSortedMap;->checkMutable()V
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 379
invoke-interface {v0}, Ljava/util/Map;->isEmpty()Z
move-result v0
if-eqz v0, :cond_0
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
instance-of v0, v0, Ljava/util/TreeMap;
if-nez v0, :cond_0
.line 380
new-instance v0, Ljava/util/TreeMap;
invoke-direct {v0}, Ljava/util/TreeMap;-><init>()V
iput-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 381
invoke-virtual {v0}, Ljava/util/TreeMap;->descendingMap()Ljava/util/NavigableMap;
move-result-object v0
iput-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntriesDescending:Ljava/util/Map;
:cond_0
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 383
check-cast v0, Ljava/util/SortedMap;
return-object v0
.end method
.method public static newFieldMap(I)Lcom/google/protobuf/SmallSortedMap;
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"<FieldDescriptorType::",
"Lcom/google/protobuf/FieldSet$FieldDescriptorLite<",
"TFieldDescriptorType;>;>(I)",
"Lcom/google/protobuf/SmallSortedMap;"
}
.end annotation
.line 95
new-instance v0, Lcom/google/protobuf/SmallSortedMap$1;
invoke-direct {v0, p0}, Lcom/google/protobuf/SmallSortedMap$1;-><init>(I)V
return-object v0
.end method
.method public static newInstanceForTest(I)Lcom/google/protobuf/SmallSortedMap;
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"<K::",
"Ljava/lang/Comparable<",
"TK;>;V:",
"Ljava/lang/Object;",
">(I)",
"Lcom/google/protobuf/SmallSortedMap;"
}
.end annotation
.line 126
new-instance v0, Lcom/google/protobuf/SmallSortedMap;
invoke-direct {v0, p0}, Lcom/google/protobuf/SmallSortedMap;-><init>(I)V
return-object v0
.end method
.method private removeArrayEntryAt(I)Ljava/lang/Object;
.locals 4
.annotation system Ldalvik/annotation/Signature;
value = {
"(I)",
"Ljava/lang/Object;"
}
.end annotation
.line 297
invoke-direct {p0}, Lcom/google/protobuf/SmallSortedMap;->checkMutable()V
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 298
invoke-interface {v0, p1}, Ljava/util/List;->remove(I)Ljava/lang/Object;
move-result-object p1
check-cast p1, Lcom/google/protobuf/SmallSortedMap$Entry;
invoke-virtual {p1}, Lcom/google/protobuf/SmallSortedMap$Entry;->getValue()Ljava/lang/Object;
move-result-object p1
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 299
invoke-interface {v0}, Ljava/util/Map;->isEmpty()Z
move-result v0
if-nez v0, :cond_0
.line 302
invoke-direct {p0}, Lcom/google/protobuf/SmallSortedMap;->getOverflowEntriesMutable()Ljava/util/SortedMap;
move-result-object v0
invoke-interface {v0}, Ljava/util/SortedMap;->entrySet()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v0
iget-object v1, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 303
new-instance v2, Lcom/google/protobuf/SmallSortedMap$Entry;
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/util/Map$Entry;
invoke-direct {v2, p0, v3}, Lcom/google/protobuf/SmallSortedMap$Entry;-><init>(Lcom/google/protobuf/SmallSortedMap;Ljava/util/Map$Entry;)V
invoke-interface {v1, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 304
invoke-interface {v0}, Ljava/util/Iterator;->remove()V
:cond_0
return-object p1
.end method
# virtual methods
.method public clear()V
.locals 1
.line 264
invoke-direct {p0}, Lcom/google/protobuf/SmallSortedMap;->checkMutable()V
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 265
invoke-interface {v0}, Ljava/util/List;->isEmpty()Z
move-result v0
if-nez v0, :cond_0
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 266
invoke-interface {v0}, Ljava/util/List;->clear()V
:cond_0
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 268
invoke-interface {v0}, Ljava/util/Map;->isEmpty()Z
move-result v0
if-nez v0, :cond_1
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 269
invoke-interface {v0}, Ljava/util/Map;->clear()V
:cond_1
return-void
.end method
.method public containsKey(Ljava/lang/Object;)Z
.locals 1
.line 218
check-cast p1, Ljava/lang/Comparable;
.line 219
invoke-direct {p0, p1}, Lcom/google/protobuf/SmallSortedMap;->binarySearchInArray(Ljava/lang/Comparable;)I
move-result v0
if-gez v0, :cond_1
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
invoke-interface {v0, p1}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
move-result p1
if-eqz p1, :cond_0
goto :goto_0
:cond_0
const/4 p1, 0x0
goto :goto_1
:cond_1
:goto_0
const/4 p1, 0x1
:goto_1
return p1
.end method
.method public descendingEntrySet()Ljava/util/Set;
.locals 2
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/Set<",
"Ljava/util/Map$Entry<",
"Ljava/lang/Comparable<",
"Ljava/lang/Object;",
">;",
"Ljava/lang/Object;",
">;>;"
}
.end annotation
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->lazyDescendingEntrySet:Lcom/google/protobuf/SmallSortedMap$DescendingEntrySet;
if-nez v0, :cond_0
.line 361
new-instance v0, Lcom/google/protobuf/SmallSortedMap$DescendingEntrySet;
const/4 v1, 0x0
invoke-direct {v0, p0, v1}, Lcom/google/protobuf/SmallSortedMap$DescendingEntrySet;-><init>(Lcom/google/protobuf/SmallSortedMap;Lcom/google/protobuf/SmallSortedMap$1;)V
iput-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->lazyDescendingEntrySet:Lcom/google/protobuf/SmallSortedMap$DescendingEntrySet;
:cond_0
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->lazyDescendingEntrySet:Lcom/google/protobuf/SmallSortedMap$DescendingEntrySet;
return-object v0
.end method
.method public entrySet()Ljava/util/Set;
.locals 2
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/Set<",
"Ljava/util/Map$Entry<",
"Ljava/lang/Comparable<",
"Ljava/lang/Object;",
">;",
"Ljava/lang/Object;",
">;>;"
}
.end annotation
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->lazyEntrySet:Lcom/google/protobuf/SmallSortedMap$EntrySet;
if-nez v0, :cond_0
.line 354
new-instance v0, Lcom/google/protobuf/SmallSortedMap$EntrySet;
const/4 v1, 0x0
invoke-direct {v0, p0, v1}, Lcom/google/protobuf/SmallSortedMap$EntrySet;-><init>(Lcom/google/protobuf/SmallSortedMap;Lcom/google/protobuf/SmallSortedMap$1;)V
iput-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->lazyEntrySet:Lcom/google/protobuf/SmallSortedMap$EntrySet;
:cond_0
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->lazyEntrySet:Lcom/google/protobuf/SmallSortedMap$EntrySet;
return-object v0
.end method
.method public equals(Ljava/lang/Object;)Z
.locals 7
const/4 v0, 0x1
if-ne p0, p1, :cond_0
return v0
.line 668
:cond_0
instance-of v1, p1, Lcom/google/protobuf/SmallSortedMap;
if-nez v1, :cond_1
.line 669
invoke-super {p0, p1}, Ljava/util/AbstractMap;->equals(Ljava/lang/Object;)Z
move-result p1
return p1
.line 672
:cond_1
check-cast p1, Lcom/google/protobuf/SmallSortedMap;
.line 673
invoke-virtual {p0}, Lcom/google/protobuf/SmallSortedMap;->size()I
move-result v1
.line 674
invoke-virtual {p1}, Lcom/google/protobuf/SmallSortedMap;->size()I
move-result v2
const/4 v3, 0x0
if-eq v1, v2, :cond_2
return v3
.line 679
:cond_2
invoke-virtual {p0}, Lcom/google/protobuf/SmallSortedMap;->getNumArrayEntries()I
move-result v2
.line 680
invoke-virtual {p1}, Lcom/google/protobuf/SmallSortedMap;->getNumArrayEntries()I
move-result v4
if-eq v2, v4, :cond_3
.line 681
invoke-virtual {p0}, Lcom/google/protobuf/SmallSortedMap;->entrySet()Ljava/util/Set;
move-result-object v0
invoke-virtual {p1}, Lcom/google/protobuf/SmallSortedMap;->entrySet()Ljava/util/Set;
move-result-object p1
invoke-interface {v0, p1}, Ljava/util/Set;->equals(Ljava/lang/Object;)Z
move-result p1
return p1
:cond_3
move v4, v3
:goto_0
if-ge v4, v2, :cond_5
.line 685
invoke-virtual {p0, v4}, Lcom/google/protobuf/SmallSortedMap;->getArrayEntryAt(I)Ljava/util/Map$Entry;
move-result-object v5
invoke-virtual {p1, v4}, Lcom/google/protobuf/SmallSortedMap;->getArrayEntryAt(I)Ljava/util/Map$Entry;
move-result-object v6
invoke-interface {v5, v6}, Ljava/util/Map$Entry;->equals(Ljava/lang/Object;)Z
move-result v5
if-nez v5, :cond_4
return v3
:cond_4
add-int/lit8 v4, v4, 0x1
goto :goto_0
:cond_5
if-eq v2, v1, :cond_6
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 691
iget-object p1, p1, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
invoke-interface {v0, p1}, Ljava/util/Map;->equals(Ljava/lang/Object;)Z
move-result p1
return p1
:cond_6
return v0
.end method
.method public get(Ljava/lang/Object;)Ljava/lang/Object;
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/lang/Object;",
")",
"Ljava/lang/Object;"
}
.end annotation
.line 230
check-cast p1, Ljava/lang/Comparable;
.line 231
invoke-direct {p0, p1}, Lcom/google/protobuf/SmallSortedMap;->binarySearchInArray(Ljava/lang/Comparable;)I
move-result v0
if-ltz v0, :cond_0
iget-object p1, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 233
invoke-interface {p1, v0}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object p1
check-cast p1, Lcom/google/protobuf/SmallSortedMap$Entry;
invoke-virtual {p1}, Lcom/google/protobuf/SmallSortedMap$Entry;->getValue()Ljava/lang/Object;
move-result-object p1
return-object p1
:cond_0
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 235
invoke-interface {v0, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
return-object p1
.end method
.method public getArrayEntryAt(I)Ljava/util/Map$Entry;
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"(I)",
"Ljava/util/Map$Entry<",
"Ljava/lang/Comparable<",
"Ljava/lang/Object;",
">;",
"Ljava/lang/Object;",
">;"
}
.end annotation
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 184
invoke-interface {v0, p1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object p1
check-cast p1, Ljava/util/Map$Entry;
return-object p1
.end method
.method public getNumArrayEntries()I
.locals 1
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 179
invoke-interface {v0}, Ljava/util/List;->size()I
move-result v0
return v0
.end method
.method public getNumOverflowEntries()I
.locals 1
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 189
invoke-interface {v0}, Ljava/util/Map;->size()I
move-result v0
return v0
.end method
.method public getOverflowEntries()Ljava/lang/Iterable;
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/lang/Iterable<",
"Ljava/util/Map$Entry<",
"Ljava/lang/Comparable<",
"Ljava/lang/Object;",
">;",
"Ljava/lang/Object;",
">;>;"
}
.end annotation
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 194
invoke-interface {v0}, Ljava/util/Map;->isEmpty()Z
move-result v0
if-eqz v0, :cond_0
.line 195
invoke-static {}, Lcom/google/protobuf/SmallSortedMap$EmptySet;->iterable()Ljava/lang/Iterable;
move-result-object v0
goto :goto_0
:cond_0
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 196
invoke-interface {v0}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v0
:goto_0
return-object v0
.end method
.method public getOverflowEntriesDescending()Ljava/lang/Iterable;
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/lang/Iterable<",
"Ljava/util/Map$Entry<",
"Ljava/lang/Comparable<",
"Ljava/lang/Object;",
">;",
"Ljava/lang/Object;",
">;>;"
}
.end annotation
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntriesDescending:Ljava/util/Map;
.line 200
invoke-interface {v0}, Ljava/util/Map;->isEmpty()Z
move-result v0
if-eqz v0, :cond_0
.line 201
invoke-static {}, Lcom/google/protobuf/SmallSortedMap$EmptySet;->iterable()Ljava/lang/Iterable;
move-result-object v0
goto :goto_0
:cond_0
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntriesDescending:Ljava/util/Map;
.line 202
invoke-interface {v0}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v0
:goto_0
return-object v0
.end method
.method public hashCode()I
.locals 4
.line 700
invoke-virtual {p0}, Lcom/google/protobuf/SmallSortedMap;->getNumArrayEntries()I
move-result v0
const/4 v1, 0x0
move v2, v1
:goto_0
if-ge v1, v0, :cond_0
iget-object v3, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 702
invoke-interface {v3, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v3
check-cast v3, Lcom/google/protobuf/SmallSortedMap$Entry;
invoke-virtual {v3}, Lcom/google/protobuf/SmallSortedMap$Entry;->hashCode()I
move-result v3
add-int/2addr v2, v3
add-int/lit8 v1, v1, 0x1
goto :goto_0
.line 705
:cond_0
invoke-virtual {p0}, Lcom/google/protobuf/SmallSortedMap;->getNumOverflowEntries()I
move-result v0
if-lez v0, :cond_1
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 706
invoke-interface {v0}, Ljava/util/Map;->hashCode()I
move-result v0
add-int/2addr v2, v0
:cond_1
return v2
.end method
.method public isImmutable()Z
.locals 1
iget-boolean v0, p0, Lcom/google/protobuf/SmallSortedMap;->isImmutable:Z
return v0
.end method
.method public makeImmutable()V
.locals 1
iget-boolean v0, p0, Lcom/google/protobuf/SmallSortedMap;->isImmutable:Z
if-nez v0, :cond_2
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 161
invoke-interface {v0}, Ljava/util/Map;->isEmpty()Z
move-result v0
if-eqz v0, :cond_0
.line 162
invoke-static {}, Ljava/util/Collections;->emptyMap()Ljava/util/Map;
move-result-object v0
goto :goto_0
:cond_0
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 163
invoke-static {v0}, Ljava/util/Collections;->unmodifiableMap(Ljava/util/Map;)Ljava/util/Map;
move-result-object v0
:goto_0
iput-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntriesDescending:Ljava/util/Map;
.line 165
invoke-interface {v0}, Ljava/util/Map;->isEmpty()Z
move-result v0
if-eqz v0, :cond_1
.line 166
invoke-static {}, Ljava/util/Collections;->emptyMap()Ljava/util/Map;
move-result-object v0
goto :goto_1
:cond_1
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntriesDescending:Ljava/util/Map;
.line 167
invoke-static {v0}, Ljava/util/Collections;->unmodifiableMap(Ljava/util/Map;)Ljava/util/Map;
move-result-object v0
:goto_1
iput-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntriesDescending:Ljava/util/Map;
const/4 v0, 0x1
iput-boolean v0, p0, Lcom/google/protobuf/SmallSortedMap;->isImmutable:Z
:cond_2
return-void
.end method
.method public put(Ljava/lang/Comparable;Ljava/lang/Object;)Ljava/lang/Object;
.locals 4
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/lang/Comparable<",
"Ljava/lang/Object;",
">;",
"Ljava/lang/Object;",
")",
"Ljava/lang/Object;"
}
.end annotation
.line 240
invoke-direct {p0}, Lcom/google/protobuf/SmallSortedMap;->checkMutable()V
.line 241
invoke-direct {p0, p1}, Lcom/google/protobuf/SmallSortedMap;->binarySearchInArray(Ljava/lang/Comparable;)I
move-result v0
if-ltz v0, :cond_0
iget-object p1, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 244
invoke-interface {p1, v0}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object p1
check-cast p1, Lcom/google/protobuf/SmallSortedMap$Entry;
invoke-virtual {p1, p2}, Lcom/google/protobuf/SmallSortedMap$Entry;->setValue(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
return-object p1
.line 246
:cond_0
invoke-direct {p0}, Lcom/google/protobuf/SmallSortedMap;->ensureEntryArrayMutable()V
add-int/lit8 v0, v0, 0x1
neg-int v0, v0
iget v1, p0, Lcom/google/protobuf/SmallSortedMap;->maxArraySize:I
if-lt v0, v1, :cond_1
.line 250
invoke-direct {p0}, Lcom/google/protobuf/SmallSortedMap;->getOverflowEntriesMutable()Ljava/util/SortedMap;
move-result-object v0
invoke-interface {v0, p1, p2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
return-object p1
:cond_1
iget-object v1, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 253
invoke-interface {v1}, Ljava/util/List;->size()I
move-result v1
iget v2, p0, Lcom/google/protobuf/SmallSortedMap;->maxArraySize:I
if-ne v1, v2, :cond_2
iget-object v1, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
add-int/lit8 v2, v2, -0x1
.line 255
invoke-interface {v1, v2}, Ljava/util/List;->remove(I)Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/google/protobuf/SmallSortedMap$Entry;
.line 256
invoke-direct {p0}, Lcom/google/protobuf/SmallSortedMap;->getOverflowEntriesMutable()Ljava/util/SortedMap;
move-result-object v2
invoke-virtual {v1}, Lcom/google/protobuf/SmallSortedMap$Entry;->getKey()Ljava/lang/Comparable;
move-result-object v3
invoke-virtual {v1}, Lcom/google/protobuf/SmallSortedMap$Entry;->getValue()Ljava/lang/Object;
move-result-object v1
invoke-interface {v2, v3, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:cond_2
iget-object v1, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 258
new-instance v2, Lcom/google/protobuf/SmallSortedMap$Entry;
invoke-direct {v2, p0, p1, p2}, Lcom/google/protobuf/SmallSortedMap$Entry;-><init>(Lcom/google/protobuf/SmallSortedMap;Ljava/lang/Comparable;Ljava/lang/Object;)V
invoke-interface {v1, v0, v2}, Ljava/util/List;->add(ILjava/lang/Object;)V
const/4 p1, 0x0
return-object p1
.end method
.method public bridge synthetic put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.locals 0
.line 83
check-cast p1, Ljava/lang/Comparable;
invoke-virtual {p0, p1, p2}, Lcom/google/protobuf/SmallSortedMap;->put(Ljava/lang/Comparable;Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
return-object p1
.end method
.method public remove(Ljava/lang/Object;)Ljava/lang/Object;
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/lang/Object;",
")",
"Ljava/lang/Object;"
}
.end annotation
.line 280
invoke-direct {p0}, Lcom/google/protobuf/SmallSortedMap;->checkMutable()V
.line 282
check-cast p1, Ljava/lang/Comparable;
.line 283
invoke-direct {p0, p1}, Lcom/google/protobuf/SmallSortedMap;->binarySearchInArray(Ljava/lang/Comparable;)I
move-result v0
if-ltz v0, :cond_0
.line 285
invoke-direct {p0, v0}, Lcom/google/protobuf/SmallSortedMap;->removeArrayEntryAt(I)Ljava/lang/Object;
move-result-object p1
return-object p1
:cond_0
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 289
invoke-interface {v0}, Ljava/util/Map;->isEmpty()Z
move-result v0
if-eqz v0, :cond_1
const/4 p1, 0x0
return-object p1
:cond_1
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
.line 292
invoke-interface {v0, p1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
return-object p1
.end method
.method public size()I
.locals 2
iget-object v0, p0, Lcom/google/protobuf/SmallSortedMap;->entryList:Ljava/util/List;
.line 207
invoke-interface {v0}, Ljava/util/List;->size()I
move-result v0
iget-object v1, p0, Lcom/google/protobuf/SmallSortedMap;->overflowEntries:Ljava/util/Map;
invoke-interface {v1}, Ljava/util/Map;->size()I
move-result v1
add-int/2addr v0, v1
return v0
.end method