n3.smali
7.5 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
.class public Lcom/bytedance/bdtracker/n3;
.super Landroid/database/sqlite/SQLiteOpenHelper;
.source ""
# instance fields
.field public final a:Lcom/bytedance/bdtracker/c0;
# direct methods
.method public constructor <init>(Lcom/bytedance/bdtracker/c0;Ljava/lang/String;Landroid/database/sqlite/SQLiteDatabase$CursorFactory;I)V
.locals 1
invoke-virtual {p1}, Lcom/bytedance/bdtracker/c0;->b()Landroid/content/Context;
move-result-object v0
invoke-direct {p0, v0, p2, p3, p4}, Landroid/database/sqlite/SQLiteOpenHelper;-><init>(Landroid/content/Context;Ljava/lang/String;Landroid/database/sqlite/SQLiteDatabase$CursorFactory;I)V
iput-object p1, p0, Lcom/bytedance/bdtracker/n3;->a:Lcom/bytedance/bdtracker/c0;
return-void
.end method
# virtual methods
.method public a(Ljava/lang/Throwable;)V
.locals 2
iget-object v0, p0, Lcom/bytedance/bdtracker/n3;->a:Lcom/bytedance/bdtracker/c0;
.line 1
iget-object v0, v0, Lcom/bytedance/bdtracker/c0;->q:Lcom/bytedance/bdtracker/z1;
if-nez v0, :cond_0
return-void
.line 2
:cond_0
new-instance v1, Lcom/bytedance/bdtracker/j2;
invoke-direct {v1, p1}, Lcom/bytedance/bdtracker/j2;-><init>(Ljava/lang/Throwable;)V
check-cast v0, Lcom/bytedance/bdtracker/d2;
invoke-virtual {v0, v1}, Lcom/bytedance/bdtracker/d2;->a(Lcom/bytedance/bdtracker/g2;)V
return-void
.end method
.method public onCreate(Landroid/database/sqlite/SQLiteDatabase;)V
.locals 5
:try_start_0
invoke-virtual {p1}, Landroid/database/sqlite/SQLiteDatabase;->beginTransaction()V
invoke-static {}, Lcom/bytedance/bdtracker/j3;->j()Ljava/util/HashMap;
move-result-object v0
invoke-virtual {v0}, Ljava/util/HashMap;->values()Ljava/util/Collection;
move-result-object v0
invoke-interface {v0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v0
:cond_0
:goto_0
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_1
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/bytedance/bdtracker/j3;
invoke-virtual {v1}, Lcom/bytedance/bdtracker/j3;->a()Ljava/lang/String;
move-result-object v1
if-eqz v1, :cond_0
invoke-virtual {p1, v1}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
goto :goto_0
:cond_1
invoke-virtual {p1}, Landroid/database/sqlite/SQLiteDatabase;->setTransactionSuccessful()V
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
goto :goto_1
:catchall_0
move-exception v0
:try_start_1
iget-object v1, p0, Lcom/bytedance/bdtracker/n3;->a:Lcom/bytedance/bdtracker/c0;
.line 1
iget-object v1, v1, Lcom/bytedance/bdtracker/c0;->d:Lcom/bytedance/bdtracker/d;
.line 2
iget-object v1, v1, Lcom/bytedance/bdtracker/d;->D:Lcom/bytedance/applog/log/IAppLogLogger;
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_1
const/4 v2, 0x5
const-string v3, "Create table failed"
const/4 v4, 0x0
.line 3
:try_start_2
new-array v4, v4, [Ljava/lang/Object;
invoke-interface {v1, v2, v3, v0, v4}, Lcom/bytedance/applog/log/IAppLogLogger;->error(ILjava/lang/String;Ljava/lang/Throwable;[Ljava/lang/Object;)V
:try_end_2
.catchall {:try_start_2 .. :try_end_2} :catchall_1
:goto_1
invoke-static {p1}, Lcom/bytedance/bdtracker/n0;->a(Landroid/database/sqlite/SQLiteDatabase;)V
return-void
:catchall_1
move-exception v0
invoke-static {p1}, Lcom/bytedance/bdtracker/n0;->a(Landroid/database/sqlite/SQLiteDatabase;)V
throw v0
.end method
.method public onDowngrade(Landroid/database/sqlite/SQLiteDatabase;II)V
.locals 0
invoke-virtual {p0, p1, p2, p3}, Lcom/bytedance/bdtracker/n3;->onUpgrade(Landroid/database/sqlite/SQLiteDatabase;II)V
return-void
.end method
.method public onUpgrade(Landroid/database/sqlite/SQLiteDatabase;II)V
.locals 4
iget-object v0, p0, Lcom/bytedance/bdtracker/n3;->a:Lcom/bytedance/bdtracker/c0;
.line 1
iget-object v0, v0, Lcom/bytedance/bdtracker/c0;->d:Lcom/bytedance/bdtracker/d;
.line 2
iget-object v0, v0, Lcom/bytedance/bdtracker/d;->D:Lcom/bytedance/applog/log/IAppLogLogger;
const/4 v1, 0x2
.line 3
new-array v1, v1, [Ljava/lang/Object;
invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p2
const/4 v2, 0x0
aput-object p2, v1, v2
invoke-static {p3}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p2
const/4 p3, 0x1
aput-object p2, v1, p3
const/4 p2, 0x5
const-string p3, "Database upgrade from:{} to:{}"
invoke-interface {v0, p2, p3, v1}, Lcom/bytedance/applog/log/IAppLogLogger;->debug(ILjava/lang/String;[Ljava/lang/Object;)V
:try_start_0
invoke-virtual {p1}, Landroid/database/sqlite/SQLiteDatabase;->beginTransaction()V
invoke-static {}, Lcom/bytedance/bdtracker/j3;->j()Ljava/util/HashMap;
move-result-object p3
invoke-virtual {p3}, Ljava/util/HashMap;->values()Ljava/util/Collection;
move-result-object p3
invoke-interface {p3}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object p3
:goto_0
invoke-interface {p3}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_0
invoke-interface {p3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/bytedance/bdtracker/j3;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "DROP TABLE IF EXISTS "
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Lcom/bytedance/bdtracker/j3;->f()Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {p1, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
goto :goto_0
:cond_0
invoke-virtual {p1}, Landroid/database/sqlite/SQLiteDatabase;->setTransactionSuccessful()V
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
goto :goto_1
:catchall_0
move-exception p3
:try_start_1
iget-object v0, p0, Lcom/bytedance/bdtracker/n3;->a:Lcom/bytedance/bdtracker/c0;
.line 4
iget-object v0, v0, Lcom/bytedance/bdtracker/c0;->d:Lcom/bytedance/bdtracker/d;
.line 5
iget-object v0, v0, Lcom/bytedance/bdtracker/d;->D:Lcom/bytedance/applog/log/IAppLogLogger;
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_1
const-string v1, "drop tables failed when upgrade."
.line 6
:try_start_2
new-array v2, v2, [Ljava/lang/Object;
invoke-interface {v0, p2, v1, p3, v2}, Lcom/bytedance/applog/log/IAppLogLogger;->error(ILjava/lang/String;Ljava/lang/Throwable;[Ljava/lang/Object;)V
:try_end_2
.catchall {:try_start_2 .. :try_end_2} :catchall_1
:goto_1
invoke-static {p1}, Lcom/bytedance/bdtracker/n0;->a(Landroid/database/sqlite/SQLiteDatabase;)V
invoke-virtual {p0, p1}, Lcom/bytedance/bdtracker/n3;->onCreate(Landroid/database/sqlite/SQLiteDatabase;)V
return-void
:catchall_1
move-exception p2
invoke-static {p1}, Lcom/bytedance/bdtracker/n0;->a(Landroid/database/sqlite/SQLiteDatabase;)V
throw p2
.end method