LinkedHashTreeMap$AvlBuilder.smali
8.7 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
.class final Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;
.super Ljava/lang/Object;
.source "LinkedHashTreeMap.java"
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lcom/dwx/gson/internal/LinkedHashTreeMap;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x18
name = "AvlBuilder"
.end annotation
.annotation system Ldalvik/annotation/Signature;
value = {
"<K:",
"Ljava/lang/Object;",
"V:",
"Ljava/lang/Object;",
">",
"Ljava/lang/Object;"
}
.end annotation
# instance fields
.field private leavesSkipped:I
.field private leavesToSkip:I
.field private size:I
.field private stack:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lcom/dwx/gson/internal/LinkedHashTreeMap$Node<",
"TK;TV;>;"
}
.end annotation
.end field
# direct methods
.method constructor <init>()V
.locals 0
.line 670
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
# virtual methods
.method add(Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;)V
.locals 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/dwx/gson/internal/LinkedHashTreeMap$Node<",
"TK;TV;>;)V"
}
.end annotation
const/4 v0, 0x0
.line 687
iput-object v0, p1, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->right:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
iput-object v0, p1, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
iput-object v0, p1, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->left:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
const/4 v0, 0x1
.line 688
iput v0, p1, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->height:I
.line 691
iget v1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesToSkip:I
if-lez v1, :cond_0
iget v2, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->size:I
and-int/lit8 v3, v2, 0x1
if-nez v3, :cond_0
add-int/2addr v2, v0
.line 692
iput v2, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->size:I
sub-int/2addr v1, v0
.line 693
iput v1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesToSkip:I
.line 694
iget v1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesSkipped:I
add-int/2addr v1, v0
iput v1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesSkipped:I
.line 697
:cond_0
iget-object v1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->stack:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
iput-object v1, p1, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.line 698
iput-object p1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->stack:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.line 699
iget p1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->size:I
add-int/2addr p1, v0
iput p1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->size:I
.line 702
iget p1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesToSkip:I
if-lez p1, :cond_1
iget v1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->size:I
and-int/lit8 v2, v1, 0x1
if-nez v2, :cond_1
add-int/2addr v1, v0
.line 703
iput v1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->size:I
sub-int/2addr p1, v0
.line 704
iput p1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesToSkip:I
.line 705
iget p1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesSkipped:I
add-int/2addr p1, v0
iput p1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesSkipped:I
:cond_1
const/4 p1, 0x4
.line 721
:goto_0
iget v1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->size:I
add-int/lit8 v2, p1, -0x1
and-int/2addr v1, v2
if-ne v1, v2, :cond_5
.line 722
iget v1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesSkipped:I
if-nez v1, :cond_2
.line 724
iget-object v1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->stack:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.line 725
iget-object v2, v1, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.line 726
iget-object v3, v2, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.line 727
iget-object v4, v3, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
iput-object v4, v2, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.line 728
iput-object v2, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->stack:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.line 730
iput-object v3, v2, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->left:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.line 731
iput-object v1, v2, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->right:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.line 732
iget v4, v1, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->height:I
add-int/2addr v4, v0
iput v4, v2, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->height:I
.line 733
iput-object v2, v3, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.line 734
iput-object v2, v1, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
goto :goto_1
:cond_2
const/4 v2, 0x0
if-ne v1, v0, :cond_3
.line 737
iget-object v1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->stack:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.line 738
iget-object v3, v1, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.line 739
iput-object v3, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->stack:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.line 741
iput-object v1, v3, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->right:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.line 742
iget v4, v1, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->height:I
add-int/2addr v4, v0
iput v4, v3, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->height:I
.line 743
iput-object v3, v1, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.line 744
iput v2, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesSkipped:I
goto :goto_1
:cond_3
const/4 v3, 0x2
if-ne v1, v3, :cond_4
.line 746
iput v2, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesSkipped:I
:cond_4
:goto_1
mul-int/lit8 p1, p1, 0x2
goto :goto_0
:cond_5
return-void
.end method
.method reset(I)V
.locals 1
.line 679
invoke-static {p1}, Ljava/lang/Integer;->highestOneBit(I)I
move-result v0
mul-int/lit8 v0, v0, 0x2
add-int/lit8 v0, v0, -0x1
sub-int/2addr v0, p1
.line 680
iput v0, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesToSkip:I
const/4 p1, 0x0
.line 681
iput p1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->size:I
.line 682
iput p1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesSkipped:I
const/4 p1, 0x0
.line 683
iput-object p1, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->stack:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
return-void
.end method
.method root()Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.locals 2
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Lcom/dwx/gson/internal/LinkedHashTreeMap$Node<",
"TK;TV;>;"
}
.end annotation
.line 752
iget-object v0, p0, Lcom/dwx/gson/internal/LinkedHashTreeMap$AvlBuilder;->stack:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
.line 753
iget-object v1, v0, Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/dwx/gson/internal/LinkedHashTreeMap$Node;
if-nez v1, :cond_0
return-object v0
.line 754
:cond_0
new-instance v0, Ljava/lang/IllegalStateException;
invoke-direct {v0}, Ljava/lang/IllegalStateException;-><init>()V
throw v0
.end method