123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830 |
- .class final Landroid/support/multidex/MultiDexExtractor;
- .super Ljava/lang/Object;
- .source "MultiDexExtractor.java"
- # static fields
- .field private static final BUFFER_SIZE:I = 0x4000
- .field private static final DEX_PREFIX:Ljava/lang/String; = "classes"
- .field private static final DEX_SUFFIX:Ljava/lang/String; = ".dex"
- .field private static final EXTRACTED_NAME_EXT:Ljava/lang/String; = ".classes"
- .field private static final EXTRACTED_SUFFIX:Ljava/lang/String; = ".zip"
- .field private static final KEY_CRC:Ljava/lang/String; = "crc"
- .field private static final KEY_DEX_NUMBER:Ljava/lang/String; = "dex.number"
- .field private static final KEY_TIME_STAMP:Ljava/lang/String; = "timestamp"
- .field private static final MAX_EXTRACT_ATTEMPTS:I = 0x3
- .field private static final NO_VALUE:J = -0x1L
- .field private static final PREFS_FILE:Ljava/lang/String; = "multidex.version"
- .field private static final TAG:Ljava/lang/String; = "MultiDex"
- .field private static sApplyMethod:Ljava/lang/reflect/Method;
- # direct methods
- .method static constructor <clinit>()V
- .locals 4
- .prologue
- .line 360
- :try_start_0
- const-class v0, Landroid/content/SharedPreferences$Editor;
- .line 361
- .local v0, "cls":Ljava/lang/Class;, "Ljava/lang/Class<*>;"
- const-string v2, "apply"
- const/4 v3, 0x0
- new-array v3, v3, [Ljava/lang/Class;
- invoke-virtual {v0, v2, v3}, Ljava/lang/Class;->getMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
- move-result-object v2
- sput-object v2, Landroid/support/multidex/MultiDexExtractor;->sApplyMethod:Ljava/lang/reflect/Method;
- :try_end_0
- .catch Ljava/lang/NoSuchMethodException; {:try_start_0 .. :try_end_0} :catch_0
- .line 365
- :goto_0
- return-void
- .line 362
- :catch_0
- move-exception v1
- .line 363
- .local v1, "unused":Ljava/lang/NoSuchMethodException;
- const/4 v2, 0x0
- sput-object v2, Landroid/support/multidex/MultiDexExtractor;->sApplyMethod:Ljava/lang/reflect/Method;
- goto :goto_0
- .end method
- .method constructor <init>()V
- .locals 0
- .prologue
- .line 46
- invoke-direct {p0}, Ljava/lang/Object;-><init>()V
- return-void
- .end method
- .method private static apply(Landroid/content/SharedPreferences$Editor;)V
- .locals 2
- .param p0, "editor" # Landroid/content/SharedPreferences$Editor;
- .prologue
- .line 368
- sget-object v0, Landroid/support/multidex/MultiDexExtractor;->sApplyMethod:Ljava/lang/reflect/Method;
- if-eqz v0, :cond_0
- .line 370
- :try_start_0
- sget-object v0, Landroid/support/multidex/MultiDexExtractor;->sApplyMethod:Ljava/lang/reflect/Method;
- const/4 v1, 0x0
- new-array v1, v1, [Ljava/lang/Object;
- invoke-virtual {v0, p0, v1}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
- :try_end_0
- .catch Ljava/lang/reflect/InvocationTargetException; {:try_start_0 .. :try_end_0} :catch_1
- .catch Ljava/lang/IllegalAccessException; {:try_start_0 .. :try_end_0} :catch_0
- .line 379
- :goto_0
- return-void
- .line 374
- :catch_0
- move-exception v0
- .line 378
- :cond_0
- :goto_1
- invoke-interface {p0}, Landroid/content/SharedPreferences$Editor;->commit()Z
- goto :goto_0
- .line 372
- :catch_1
- move-exception v0
- goto :goto_1
- .end method
- .method private static closeQuietly(Ljava/io/Closeable;)V
- .locals 3
- .param p0, "closeable" # Ljava/io/Closeable;
- .prologue
- .line 349
- :try_start_0
- invoke-interface {p0}, Ljava/io/Closeable;->close()V
- :try_end_0
- .catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0
- .line 353
- :goto_0
- return-void
- .line 350
- :catch_0
- move-exception v0
- .line 351
- .local v0, "e":Ljava/io/IOException;
- const-string v1, "MultiDex"
- const-string v2, "Failed to close resource"
- invoke-static {v1, v2, v0}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
- goto :goto_0
- .end method
- .method private static extract(Ljava/util/zip/ZipFile;Ljava/util/zip/ZipEntry;Ljava/io/File;Ljava/lang/String;)V
- .locals 10
- .param p0, "apk" # Ljava/util/zip/ZipFile;
- .param p1, "dexFile" # Ljava/util/zip/ZipEntry;
- .param p2, "extractTo" # Ljava/io/File;
- .param p3, "extractedFilePrefix" # Ljava/lang/String;
- .annotation system Ldalvik/annotation/Throws;
- value = {
- Ljava/io/IOException;,
- Ljava/io/FileNotFoundException;
- }
- .end annotation
- .prologue
- .line 288
- invoke-virtual {p0, p1}, Ljava/util/zip/ZipFile;->getInputStream(Ljava/util/zip/ZipEntry;)Ljava/io/InputStream;
- move-result-object v2
- .line 289
- .local v2, "in":Ljava/io/InputStream;
- const/4 v4, 0x0
- .line 290
- .local v4, "out":Ljava/util/zip/ZipOutputStream;
- const-string v7, ".zip"
- .line 291
- invoke-virtual {p2}, Ljava/io/File;->getParentFile()Ljava/io/File;
- move-result-object v8
- .line 290
- invoke-static {p3, v7, v8}, Ljava/io/File;->createTempFile(Ljava/lang/String;Ljava/lang/String;Ljava/io/File;)Ljava/io/File;
- move-result-object v6
- .line 292
- .local v6, "tmp":Ljava/io/File;
- const-string v7, "MultiDex"
- new-instance v8, Ljava/lang/StringBuilder;
- const-string v9, "Extracting "
- invoke-direct {v8, v9}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {v6}, Ljava/io/File;->getPath()Ljava/lang/String;
- move-result-object v9
- invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v8
- invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v8
- invoke-static {v7, v8}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
- .line 294
- :try_start_0
- new-instance v5, Ljava/util/zip/ZipOutputStream;
- new-instance v7, Ljava/io/BufferedOutputStream;
- new-instance v8, Ljava/io/FileOutputStream;
- invoke-direct {v8, v6}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
- invoke-direct {v7, v8}, Ljava/io/BufferedOutputStream;-><init>(Ljava/io/OutputStream;)V
- invoke-direct {v5, v7}, Ljava/util/zip/ZipOutputStream;-><init>(Ljava/io/OutputStream;)V
- :try_end_0
- .catchall {:try_start_0 .. :try_end_0} :catchall_2
- .line 296
- .end local v4 # "out":Ljava/util/zip/ZipOutputStream;
- .local v5, "out":Ljava/util/zip/ZipOutputStream;
- :try_start_1
- new-instance v1, Ljava/util/zip/ZipEntry;
- const-string v7, "classes.dex"
- invoke-direct {v1, v7}, Ljava/util/zip/ZipEntry;-><init>(Ljava/lang/String;)V
- .line 298
- .local v1, "classesDex":Ljava/util/zip/ZipEntry;
- invoke-virtual {p1}, Ljava/util/zip/ZipEntry;->getTime()J
- move-result-wide v7
- invoke-virtual {v1, v7, v8}, Ljava/util/zip/ZipEntry;->setTime(J)V
- .line 299
- invoke-virtual {v5, v1}, Ljava/util/zip/ZipOutputStream;->putNextEntry(Ljava/util/zip/ZipEntry;)V
- .line 301
- const/16 v7, 0x4000
- new-array v0, v7, [B
- .line 302
- .local v0, "buffer":[B
- invoke-virtual {v2, v0}, Ljava/io/InputStream;->read([B)I
- move-result v3
- .line 303
- .local v3, "length":I
- :goto_0
- const/4 v7, -0x1
- if-ne v3, v7, :cond_0
- .line 307
- invoke-virtual {v5}, Ljava/util/zip/ZipOutputStream;->closeEntry()V
- :try_end_1
- .catchall {:try_start_1 .. :try_end_1} :catchall_1
- .line 309
- :try_start_2
- invoke-virtual {v5}, Ljava/util/zip/ZipOutputStream;->close()V
- .line 311
- const-string v7, "MultiDex"
- new-instance v8, Ljava/lang/StringBuilder;
- const-string v9, "Renaming to "
- invoke-direct {v8, v9}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {p2}, Ljava/io/File;->getPath()Ljava/lang/String;
- move-result-object v9
- invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v8
- invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v8
- invoke-static {v7, v8}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
- .line 312
- invoke-virtual {v6, p2}, Ljava/io/File;->renameTo(Ljava/io/File;)Z
- move-result v7
- if-nez v7, :cond_1
- .line 313
- new-instance v7, Ljava/io/IOException;
- new-instance v8, Ljava/lang/StringBuilder;
- const-string v9, "Failed to rename \""
- invoke-direct {v8, v9}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {v6}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
- move-result-object v9
- invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v8
- .line 314
- const-string v9, "\" to \""
- invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v8
- invoke-virtual {p2}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
- move-result-object v9
- invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v8
- const-string v9, "\""
- invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v8
- invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v8
- .line 313
- invoke-direct {v7, v8}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
- throw v7
- :try_end_2
- .catchall {:try_start_2 .. :try_end_2} :catchall_0
- .line 316
- .end local v0 # "buffer":[B
- .end local v1 # "classesDex":Ljava/util/zip/ZipEntry;
- .end local v3 # "length":I
- :catchall_0
- move-exception v7
- move-object v4, v5
- .line 317
- .end local v5 # "out":Ljava/util/zip/ZipOutputStream;
- .restart local v4 # "out":Ljava/util/zip/ZipOutputStream;
- :goto_1
- invoke-static {v2}, Landroid/support/multidex/MultiDexExtractor;->closeQuietly(Ljava/io/Closeable;)V
- .line 318
- invoke-virtual {v6}, Ljava/io/File;->delete()Z
- .line 319
- throw v7
- .line 304
- .end local v4 # "out":Ljava/util/zip/ZipOutputStream;
- .restart local v0 # "buffer":[B
- .restart local v1 # "classesDex":Ljava/util/zip/ZipEntry;
- .restart local v3 # "length":I
- .restart local v5 # "out":Ljava/util/zip/ZipOutputStream;
- :cond_0
- const/4 v7, 0x0
- :try_start_3
- invoke-virtual {v5, v0, v7, v3}, Ljava/util/zip/ZipOutputStream;->write([BII)V
- .line 305
- invoke-virtual {v2, v0}, Ljava/io/InputStream;->read([B)I
- :try_end_3
- .catchall {:try_start_3 .. :try_end_3} :catchall_1
- move-result v3
- goto :goto_0
- .line 308
- .end local v0 # "buffer":[B
- .end local v1 # "classesDex":Ljava/util/zip/ZipEntry;
- .end local v3 # "length":I
- :catchall_1
- move-exception v7
- .line 309
- :try_start_4
- invoke-virtual {v5}, Ljava/util/zip/ZipOutputStream;->close()V
- .line 310
- throw v7
- :try_end_4
- .catchall {:try_start_4 .. :try_end_4} :catchall_0
- .line 317
- .restart local v0 # "buffer":[B
- .restart local v1 # "classesDex":Ljava/util/zip/ZipEntry;
- .restart local v3 # "length":I
- :cond_1
- invoke-static {v2}, Landroid/support/multidex/MultiDexExtractor;->closeQuietly(Ljava/io/Closeable;)V
- .line 318
- invoke-virtual {v6}, Ljava/io/File;->delete()Z
- .line 320
- return-void
- .line 316
- .end local v0 # "buffer":[B
- .end local v1 # "classesDex":Ljava/util/zip/ZipEntry;
- .end local v3 # "length":I
- .end local v5 # "out":Ljava/util/zip/ZipOutputStream;
- .restart local v4 # "out":Ljava/util/zip/ZipOutputStream;
- :catchall_2
- move-exception v7
- goto :goto_1
- .end method
- .method private static getMultiDexPreferences(Landroid/content/Context;)Landroid/content/SharedPreferences;
- .locals 3
- .param p0, "context" # Landroid/content/Context;
- .prologue
- .line 245
- const-string v1, "multidex.version"
- .line 246
- sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
- const/16 v2, 0xb
- if-ge v0, v2, :cond_0
- .line 247
- const/4 v0, 0x0
- .line 245
- :goto_0
- invoke-virtual {p0, v1, v0}, Landroid/content/Context;->getSharedPreferences(Ljava/lang/String;I)Landroid/content/SharedPreferences;
- move-result-object v0
- return-object v0
- .line 248
- :cond_0
- const/4 v0, 0x4
- goto :goto_0
- .end method
- .method private static getTimeStamp(Ljava/io/File;)J
- .locals 4
- .param p0, "archive" # Ljava/io/File;
- .prologue
- .line 143
- invoke-virtual {p0}, Ljava/io/File;->lastModified()J
- move-result-wide v0
- .line 144
- .local v0, "timeStamp":J
- const-wide/16 v2, -0x1
- cmp-long v2, v0, v2
- if-nez v2, :cond_0
- .line 146
- const-wide/16 v2, 0x1
- sub-long/2addr v0, v2
- .line 148
- :cond_0
- return-wide v0
- .end method
- .method private static getZipCrc(Ljava/io/File;)J
- .locals 4
- .param p0, "archive" # Ljava/io/File;
- .annotation system Ldalvik/annotation/Throws;
- value = {
- Ljava/io/IOException;
- }
- .end annotation
- .prologue
- .line 153
- invoke-static {p0}, Landroid/support/multidex/ZipUtil;->getZipCrc(Ljava/io/File;)J
- move-result-wide v0
- .line 154
- .local v0, "computedValue":J
- const-wide/16 v2, -0x1
- cmp-long v2, v0, v2
- if-nez v2, :cond_0
- .line 156
- const-wide/16 v2, 0x1
- sub-long/2addr v0, v2
- .line 158
- :cond_0
- return-wide v0
- .end method
- .method private static isModified(Landroid/content/Context;Ljava/io/File;J)Z
- .locals 7
- .param p0, "context" # Landroid/content/Context;
- .param p1, "archive" # Ljava/io/File;
- .param p2, "currentCrc" # J
- .prologue
- const-wide/16 v5, -0x1
- .line 137
- invoke-static {p0}, Landroid/support/multidex/MultiDexExtractor;->getMultiDexPreferences(Landroid/content/Context;)Landroid/content/SharedPreferences;
- move-result-object v0
- .line 138
- .local v0, "prefs":Landroid/content/SharedPreferences;
- const-string v1, "timestamp"
- invoke-interface {v0, v1, v5, v6}, Landroid/content/SharedPreferences;->getLong(Ljava/lang/String;J)J
- move-result-wide v1
- invoke-static {p1}, Landroid/support/multidex/MultiDexExtractor;->getTimeStamp(Ljava/io/File;)J
- move-result-wide v3
- cmp-long v1, v1, v3
- if-nez v1, :cond_0
- .line 139
- const-string v1, "crc"
- invoke-interface {v0, v1, v5, v6}, Landroid/content/SharedPreferences;->getLong(Ljava/lang/String;J)J
- move-result-wide v1
- cmp-long v1, v1, p2
- if-nez v1, :cond_0
- .line 138
- const/4 v1, 0x0
- :goto_0
- return v1
- :cond_0
- const/4 v1, 0x1
- goto :goto_0
- .end method
- .method static load(Landroid/content/Context;Landroid/content/pm/ApplicationInfo;Ljava/io/File;Z)Ljava/util/List;
- .locals 9
- .param p0, "context" # Landroid/content/Context;
- .param p1, "applicationInfo" # Landroid/content/pm/ApplicationInfo;
- .param p2, "dexDir" # Ljava/io/File;
- .param p3, "forceReload" # Z
- .annotation system Ldalvik/annotation/Signature;
- value = {
- "(",
- "Landroid/content/Context;",
- "Landroid/content/pm/ApplicationInfo;",
- "Ljava/io/File;",
- "Z)",
- "Ljava/util/List",
- "<",
- "Ljava/io/File;",
- ">;"
- }
- .end annotation
- .annotation system Ldalvik/annotation/Throws;
- value = {
- Ljava/io/IOException;
- }
- .end annotation
- .prologue
- .line 84
- const-string v0, "MultiDex"
- new-instance v1, Ljava/lang/StringBuilder;
- const-string v2, "MultiDexExtractor.load("
- invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- iget-object v2, p1, Landroid/content/pm/ApplicationInfo;->sourceDir:Ljava/lang/String;
- invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v1
- const-string v2, ", "
- invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v1
- invoke-virtual {v1, p3}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
- move-result-object v1
- const-string v2, ")"
- invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v1
- invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v1
- invoke-static {v0, v1}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
- .line 85
- new-instance v8, Ljava/io/File;
- iget-object v0, p1, Landroid/content/pm/ApplicationInfo;->sourceDir:Ljava/lang/String;
- invoke-direct {v8, v0}, Ljava/io/File;-><init>(Ljava/lang/String;)V
- .line 87
- .local v8, "sourceApk":Ljava/io/File;
- invoke-static {v8}, Landroid/support/multidex/MultiDexExtractor;->getZipCrc(Ljava/io/File;)J
- move-result-wide v3
- .line 90
- .local v3, "currentCrc":J
- if-nez p3, :cond_0
- invoke-static {p0, v8, v3, v4}, Landroid/support/multidex/MultiDexExtractor;->isModified(Landroid/content/Context;Ljava/io/File;J)Z
- move-result v0
- if-nez v0, :cond_0
- .line 92
- :try_start_0
- invoke-static {p0, v8, p2}, Landroid/support/multidex/MultiDexExtractor;->loadExistingExtractions(Landroid/content/Context;Ljava/io/File;Ljava/io/File;)Ljava/util/List;
- :try_end_0
- .catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0
- move-result-object v6
- .line 106
- .local v6, "files":Ljava/util/List;, "Ljava/util/List<Ljava/io/File;>;"
- :goto_0
- const-string v0, "MultiDex"
- new-instance v1, Ljava/lang/StringBuilder;
- const-string v2, "load found "
- invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-interface {v6}, Ljava/util/List;->size()I
- move-result v2
- invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
- move-result-object v1
- const-string v2, " secondary dex files"
- invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v1
- invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v1
- invoke-static {v0, v1}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
- .line 107
- return-object v6
- .line 93
- .end local v6 # "files":Ljava/util/List;, "Ljava/util/List<Ljava/io/File;>;"
- :catch_0
- move-exception v7
- .line 94
- .local v7, "ioe":Ljava/io/IOException;
- const-string v0, "MultiDex"
- const-string v1, "Failed to reload existing extracted secondary dex files, falling back to fresh extraction"
- invoke-static {v0, v1, v7}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
- .line 96
- invoke-static {v8, p2}, Landroid/support/multidex/MultiDexExtractor;->performExtractions(Ljava/io/File;Ljava/io/File;)Ljava/util/List;
- move-result-object v6
- .line 97
- .restart local v6 # "files":Ljava/util/List;, "Ljava/util/List<Ljava/io/File;>;"
- invoke-static {v8}, Landroid/support/multidex/MultiDexExtractor;->getTimeStamp(Ljava/io/File;)J
- move-result-wide v1
- invoke-interface {v6}, Ljava/util/List;->size()I
- move-result v0
- add-int/lit8 v5, v0, 0x1
- move-object v0, p0
- invoke-static/range {v0 .. v5}, Landroid/support/multidex/MultiDexExtractor;->putStoredApkInfo(Landroid/content/Context;JJI)V
- goto :goto_0
- .line 101
- .end local v6 # "files":Ljava/util/List;, "Ljava/util/List<Ljava/io/File;>;"
- .end local v7 # "ioe":Ljava/io/IOException;
- :cond_0
- const-string v0, "MultiDex"
- const-string v1, "Detected that extraction must be performed."
- invoke-static {v0, v1}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
- .line 102
- invoke-static {v8, p2}, Landroid/support/multidex/MultiDexExtractor;->performExtractions(Ljava/io/File;Ljava/io/File;)Ljava/util/List;
- move-result-object v6
- .line 103
- .restart local v6 # "files":Ljava/util/List;, "Ljava/util/List<Ljava/io/File;>;"
- invoke-static {v8}, Landroid/support/multidex/MultiDexExtractor;->getTimeStamp(Ljava/io/File;)J
- move-result-wide v1
- invoke-interface {v6}, Ljava/util/List;->size()I
- move-result v0
- add-int/lit8 v5, v0, 0x1
- move-object v0, p0
- invoke-static/range {v0 .. v5}, Landroid/support/multidex/MultiDexExtractor;->putStoredApkInfo(Landroid/content/Context;JJI)V
- goto :goto_0
- .end method
- .method private static loadExistingExtractions(Landroid/content/Context;Ljava/io/File;Ljava/io/File;)Ljava/util/List;
- .locals 9
- .param p0, "context" # Landroid/content/Context;
- .param p1, "sourceApk" # Ljava/io/File;
- .param p2, "dexDir" # Ljava/io/File;
- .annotation system Ldalvik/annotation/Signature;
- value = {
- "(",
- "Landroid/content/Context;",
- "Ljava/io/File;",
- "Ljava/io/File;",
- ")",
- "Ljava/util/List",
- "<",
- "Ljava/io/File;",
- ">;"
- }
- .end annotation
- .annotation system Ldalvik/annotation/Throws;
- value = {
- Ljava/io/IOException;
- }
- .end annotation
- .prologue
- .line 112
- const-string v6, "MultiDex"
- const-string v7, "loading existing secondary dex files"
- invoke-static {v6, v7}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
- .line 114
- new-instance v6, Ljava/lang/StringBuilder;
- invoke-virtual {p1}, Ljava/io/File;->getName()Ljava/lang/String;
- move-result-object v7
- invoke-static {v7}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
- move-result-object v7
- invoke-direct {v6, v7}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- const-string v7, ".classes"
- invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v6
- invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v1
- .line 115
- .local v1, "extractedFilePrefix":Ljava/lang/String;
- invoke-static {p0}, Landroid/support/multidex/MultiDexExtractor;->getMultiDexPreferences(Landroid/content/Context;)Landroid/content/SharedPreferences;
- move-result-object v6
- const-string v7, "dex.number"
- const/4 v8, 0x1
- invoke-interface {v6, v7, v8}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I
- move-result v5
- .line 116
- .local v5, "totalDexNumber":I
- new-instance v3, Ljava/util/ArrayList;
- invoke-direct {v3, v5}, Ljava/util/ArrayList;-><init>(I)V
- .line 118
- .local v3, "files":Ljava/util/List;, "Ljava/util/List<Ljava/io/File;>;"
- const/4 v4, 0x2
- .local v4, "secondaryNumber":I
- :goto_0
- if-le v4, v5, :cond_0
- .line 133
- return-object v3
- .line 119
- :cond_0
- new-instance v6, Ljava/lang/StringBuilder;
- invoke-static {v1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
- move-result-object v7
- invoke-direct {v6, v7}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {v6, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
- move-result-object v6
- const-string v7, ".zip"
- invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v6
- invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v2
- .line 120
- .local v2, "fileName":Ljava/lang/String;
- new-instance v0, Ljava/io/File;
- invoke-direct {v0, p2, v2}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
- .line 121
- .local v0, "extractedFile":Ljava/io/File;
- invoke-virtual {v0}, Ljava/io/File;->isFile()Z
- move-result v6
- if-eqz v6, :cond_1
- .line 122
- invoke-interface {v3, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
- .line 123
- invoke-static {v0}, Landroid/support/multidex/MultiDexExtractor;->verifyZipFile(Ljava/io/File;)Z
- move-result v6
- if-nez v6, :cond_2
- .line 124
- const-string v6, "MultiDex"
- new-instance v7, Ljava/lang/StringBuilder;
- const-string v8, "Invalid zip file: "
- invoke-direct {v7, v8}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {v7, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
- move-result-object v7
- invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v7
- invoke-static {v6, v7}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
- .line 125
- new-instance v6, Ljava/io/IOException;
- const-string v7, "Invalid ZIP file."
- invoke-direct {v6, v7}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
- throw v6
- .line 128
- :cond_1
- new-instance v6, Ljava/io/IOException;
- new-instance v7, Ljava/lang/StringBuilder;
- const-string v8, "Missing extracted secondary dex file \'"
- invoke-direct {v7, v8}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- .line 129
- invoke-virtual {v0}, Ljava/io/File;->getPath()Ljava/lang/String;
- move-result-object v8
- invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v7
- const-string v8, "\'"
- invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v7
- invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v7
- .line 128
- invoke-direct {v6, v7}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
- throw v6
- .line 118
- :cond_2
- add-int/lit8 v4, v4, 0x1
- goto :goto_0
- .end method
- .method private static performExtractions(Ljava/io/File;Ljava/io/File;)Ljava/util/List;
- .locals 14
- .param p0, "sourceApk" # Ljava/io/File;
- .param p1, "dexDir" # Ljava/io/File;
- .annotation system Ldalvik/annotation/Signature;
- value = {
- "(",
- "Ljava/io/File;",
- "Ljava/io/File;",
- ")",
- "Ljava/util/List",
- "<",
- "Ljava/io/File;",
- ">;"
- }
- .end annotation
- .annotation system Ldalvik/annotation/Throws;
- value = {
- Ljava/io/IOException;
- }
- .end annotation
- .prologue
- .line 164
- new-instance v10, Ljava/lang/StringBuilder;
- invoke-virtual {p0}, Ljava/io/File;->getName()Ljava/lang/String;
- move-result-object v11
- invoke-static {v11}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
- move-result-object v11
- invoke-direct {v10, v11}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- const-string v11, ".classes"
- invoke-virtual {v10, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v10
- invoke-virtual {v10}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v4
- .line 170
- .local v4, "extractedFilePrefix":Ljava/lang/String;
- invoke-static {p1, v4}, Landroid/support/multidex/MultiDexExtractor;->prepareDexDir(Ljava/io/File;Ljava/lang/String;)V
- .line 172
- new-instance v6, Ljava/util/ArrayList;
- invoke-direct {v6}, Ljava/util/ArrayList;-><init>()V
- .line 174
- .local v6, "files":Ljava/util/List;, "Ljava/util/List<Ljava/io/File;>;"
- new-instance v0, Ljava/util/zip/ZipFile;
- invoke-direct {v0, p0}, Ljava/util/zip/ZipFile;-><init>(Ljava/io/File;)V
- .line 177
- .local v0, "apk":Ljava/util/zip/ZipFile;
- const/4 v9, 0x2
- .line 179
- .local v9, "secondaryNumber":I
- :try_start_0
- new-instance v10, Ljava/lang/StringBuilder;
- const-string v11, "classes"
- invoke-direct {v10, v11}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {v10, v9}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
- move-result-object v10
- const-string v11, ".dex"
- invoke-virtual {v10, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v10
- invoke-virtual {v10}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v10
- invoke-virtual {v0, v10}, Ljava/util/zip/ZipFile;->getEntry(Ljava/lang/String;)Ljava/util/zip/ZipEntry;
- :try_end_0
- .catchall {:try_start_0 .. :try_end_0} :catchall_0
- move-result-object v1
- .line 180
- .local v1, "dexFile":Ljava/util/zip/ZipEntry;
- :goto_0
- if-nez v1, :cond_0
- .line 221
- :try_start_1
- invoke-virtual {v0}, Ljava/util/zip/ZipFile;->close()V
- :try_end_1
- .catch Ljava/io/IOException; {:try_start_1 .. :try_end_1} :catch_1
- .line 227
- :goto_1
- return-object v6
- .line 181
- :cond_0
- :try_start_2
- new-instance v10, Ljava/lang/StringBuilder;
- invoke-static {v4}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
- move-result-object v11
- invoke-direct {v10, v11}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {v10, v9}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
- move-result-object v10
- const-string v11, ".zip"
- invoke-virtual {v10, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v10
- invoke-virtual {v10}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v5
- .line 182
- .local v5, "fileName":Ljava/lang/String;
- new-instance v3, Ljava/io/File;
- invoke-direct {v3, p1, v5}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
- .line 183
- .local v3, "extractedFile":Ljava/io/File;
- invoke-interface {v6, v3}, Ljava/util/List;->add(Ljava/lang/Object;)Z
- .line 185
- const-string v10, "MultiDex"
- new-instance v11, Ljava/lang/StringBuilder;
- const-string v12, "Extraction is needed for file "
- invoke-direct {v11, v12}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {v11, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
- move-result-object v11
- invoke-virtual {v11}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v11
- invoke-static {v10, v11}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
- .line 186
- const/4 v8, 0x0
- .line 187
- .local v8, "numAttempts":I
- const/4 v7, 0x0
- .line 188
- .local v7, "isExtractionSuccessful":Z
- :cond_1
- :goto_2
- const/4 v10, 0x3
- if-ge v8, v10, :cond_2
- if-eqz v7, :cond_3
- .line 211
- :cond_2
- if-nez v7, :cond_5
- .line 212
- new-instance v10, Ljava/io/IOException;
- new-instance v11, Ljava/lang/StringBuilder;
- const-string v12, "Could not create zip file "
- invoke-direct {v11, v12}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- .line 213
- invoke-virtual {v3}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
- move-result-object v12
- invoke-virtual {v11, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v11
- const-string v12, " for secondary dex ("
- invoke-virtual {v11, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v11
- .line 214
- invoke-virtual {v11, v9}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
- move-result-object v11
- const-string v12, ")"
- invoke-virtual {v11, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v11
- invoke-virtual {v11}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v11
- .line 212
- invoke-direct {v10, v11}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
- throw v10
- :try_end_2
- .catchall {:try_start_2 .. :try_end_2} :catchall_0
- .line 219
- .end local v1 # "dexFile":Ljava/util/zip/ZipEntry;
- .end local v3 # "extractedFile":Ljava/io/File;
- .end local v5 # "fileName":Ljava/lang/String;
- .end local v7 # "isExtractionSuccessful":Z
- .end local v8 # "numAttempts":I
- :catchall_0
- move-exception v10
- .line 221
- :try_start_3
- invoke-virtual {v0}, Ljava/util/zip/ZipFile;->close()V
- :try_end_3
- .catch Ljava/io/IOException; {:try_start_3 .. :try_end_3} :catch_0
- .line 225
- :goto_3
- throw v10
- .line 189
- .restart local v1 # "dexFile":Ljava/util/zip/ZipEntry;
- .restart local v3 # "extractedFile":Ljava/io/File;
- .restart local v5 # "fileName":Ljava/lang/String;
- .restart local v7 # "isExtractionSuccessful":Z
- .restart local v8 # "numAttempts":I
- :cond_3
- add-int/lit8 v8, v8, 0x1
- .line 193
- :try_start_4
- invoke-static {v0, v1, v3, v4}, Landroid/support/multidex/MultiDexExtractor;->extract(Ljava/util/zip/ZipFile;Ljava/util/zip/ZipEntry;Ljava/io/File;Ljava/lang/String;)V
- .line 196
- invoke-static {v3}, Landroid/support/multidex/MultiDexExtractor;->verifyZipFile(Ljava/io/File;)Z
- move-result v7
- .line 199
- const-string v11, "MultiDex"
- new-instance v12, Ljava/lang/StringBuilder;
- const-string v10, "Extraction "
- invoke-direct {v12, v10}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- if-eqz v7, :cond_4
- const-string v10, "success"
- :goto_4
- invoke-virtual {v12, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v10
- .line 200
- const-string v12, " - length "
- invoke-virtual {v10, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v10
- invoke-virtual {v3}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
- move-result-object v12
- invoke-virtual {v10, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v10
- const-string v12, ": "
- invoke-virtual {v10, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v10
- .line 201
- invoke-virtual {v3}, Ljava/io/File;->length()J
- move-result-wide v12
- invoke-virtual {v10, v12, v13}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
- move-result-object v10
- invoke-virtual {v10}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v10
- .line 199
- invoke-static {v11, v10}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
- .line 202
- if-nez v7, :cond_1
- .line 204
- invoke-virtual {v3}, Ljava/io/File;->delete()Z
- .line 205
- invoke-virtual {v3}, Ljava/io/File;->exists()Z
- move-result v10
- if-eqz v10, :cond_1
- .line 206
- const-string v10, "MultiDex"
- new-instance v11, Ljava/lang/StringBuilder;
- const-string v12, "Failed to delete corrupted secondary dex \'"
- invoke-direct {v11, v12}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- .line 207
- invoke-virtual {v3}, Ljava/io/File;->getPath()Ljava/lang/String;
- move-result-object v12
- invoke-virtual {v11, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v11
- const-string v12, "\'"
- invoke-virtual {v11, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v11
- invoke-virtual {v11}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v11
- .line 206
- invoke-static {v10, v11}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
- goto/16 :goto_2
- .line 199
- :cond_4
- const-string v10, "failed"
- goto :goto_4
- .line 216
- :cond_5
- add-int/lit8 v9, v9, 0x1
- .line 217
- new-instance v10, Ljava/lang/StringBuilder;
- const-string v11, "classes"
- invoke-direct {v10, v11}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {v10, v9}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
- move-result-object v10
- const-string v11, ".dex"
- invoke-virtual {v10, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v10
- invoke-virtual {v10}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v10
- invoke-virtual {v0, v10}, Ljava/util/zip/ZipFile;->getEntry(Ljava/lang/String;)Ljava/util/zip/ZipEntry;
- :try_end_4
- .catchall {:try_start_4 .. :try_end_4} :catchall_0
- move-result-object v1
- goto/16 :goto_0
- .line 222
- .end local v1 # "dexFile":Ljava/util/zip/ZipEntry;
- .end local v3 # "extractedFile":Ljava/io/File;
- .end local v5 # "fileName":Ljava/lang/String;
- .end local v7 # "isExtractionSuccessful":Z
- .end local v8 # "numAttempts":I
- :catch_0
- move-exception v2
- .line 223
- .local v2, "e":Ljava/io/IOException;
- const-string v11, "MultiDex"
- const-string v12, "Failed to close resource"
- invoke-static {v11, v12, v2}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
- goto/16 :goto_3
- .line 222
- .end local v2 # "e":Ljava/io/IOException;
- .restart local v1 # "dexFile":Ljava/util/zip/ZipEntry;
- :catch_1
- move-exception v2
- .line 223
- .restart local v2 # "e":Ljava/io/IOException;
- const-string v10, "MultiDex"
- const-string v11, "Failed to close resource"
- invoke-static {v10, v11, v2}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
- goto/16 :goto_1
- .end method
- .method private static prepareDexDir(Ljava/io/File;Ljava/lang/String;)V
- .locals 9
- .param p0, "dexDir" # Ljava/io/File;
- .param p1, "extractedFilePrefix" # Ljava/lang/String;
- .annotation system Ldalvik/annotation/Throws;
- value = {
- Ljava/io/IOException;
- }
- .end annotation
- .prologue
- .line 256
- invoke-virtual {p0}, Ljava/io/File;->mkdirs()Z
- .line 257
- invoke-virtual {p0}, Ljava/io/File;->isDirectory()Z
- move-result v3
- if-nez v3, :cond_0
- .line 258
- new-instance v3, Ljava/io/IOException;
- new-instance v4, Ljava/lang/StringBuilder;
- const-string v5, "Failed to create dex directory "
- invoke-direct {v4, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {p0}, Ljava/io/File;->getPath()Ljava/lang/String;
- move-result-object v5
- invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v4
- invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v4
- invoke-direct {v3, v4}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
- throw v3
- .line 262
- :cond_0
- new-instance v1, Landroid/support/multidex/MultiDexExtractor$1;
- invoke-direct {v1, p1}, Landroid/support/multidex/MultiDexExtractor$1;-><init>(Ljava/lang/String;)V
- .line 269
- .local v1, "filter":Ljava/io/FileFilter;
- invoke-virtual {p0, v1}, Ljava/io/File;->listFiles(Ljava/io/FileFilter;)[Ljava/io/File;
- move-result-object v0
- .line 270
- .local v0, "files":[Ljava/io/File;
- if-nez v0, :cond_2
- .line 271
- const-string v3, "MultiDex"
- new-instance v4, Ljava/lang/StringBuilder;
- const-string v5, "Failed to list secondary dex dir content ("
- invoke-direct {v4, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {p0}, Ljava/io/File;->getPath()Ljava/lang/String;
- move-result-object v5
- invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v4
- const-string v5, ")."
- invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v4
- invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v4
- invoke-static {v3, v4}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
- .line 283
- :cond_1
- return-void
- .line 274
- :cond_2
- array-length v4, v0
- const/4 v3, 0x0
- :goto_0
- if-ge v3, v4, :cond_1
- aget-object v2, v0, v3
- .line 275
- .local v2, "oldFile":Ljava/io/File;
- const-string v5, "MultiDex"
- new-instance v6, Ljava/lang/StringBuilder;
- const-string v7, "Trying to delete old file "
- invoke-direct {v6, v7}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {v2}, Ljava/io/File;->getPath()Ljava/lang/String;
- move-result-object v7
- invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v6
- const-string v7, " of size "
- invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v6
- .line 276
- invoke-virtual {v2}, Ljava/io/File;->length()J
- move-result-wide v7
- invoke-virtual {v6, v7, v8}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
- move-result-object v6
- invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v6
- .line 275
- invoke-static {v5, v6}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
- .line 277
- invoke-virtual {v2}, Ljava/io/File;->delete()Z
- move-result v5
- if-nez v5, :cond_3
- .line 278
- const-string v5, "MultiDex"
- new-instance v6, Ljava/lang/StringBuilder;
- const-string v7, "Failed to delete old file "
- invoke-direct {v6, v7}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {v2}, Ljava/io/File;->getPath()Ljava/lang/String;
- move-result-object v7
- invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v6
- invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v6
- invoke-static {v5, v6}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
- .line 274
- :goto_1
- add-int/lit8 v3, v3, 0x1
- goto :goto_0
- .line 280
- :cond_3
- const-string v5, "MultiDex"
- new-instance v6, Ljava/lang/StringBuilder;
- const-string v7, "Deleted old file "
- invoke-direct {v6, v7}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {v2}, Ljava/io/File;->getPath()Ljava/lang/String;
- move-result-object v7
- invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v6
- invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v6
- invoke-static {v5, v6}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
- goto :goto_1
- .end method
- .method private static putStoredApkInfo(Landroid/content/Context;JJI)V
- .locals 3
- .param p0, "context" # Landroid/content/Context;
- .param p1, "timeStamp" # J
- .param p3, "crc" # J
- .param p5, "totalDexNumber" # I
- .prologue
- .line 232
- invoke-static {p0}, Landroid/support/multidex/MultiDexExtractor;->getMultiDexPreferences(Landroid/content/Context;)Landroid/content/SharedPreferences;
- move-result-object v1
- .line 233
- .local v1, "prefs":Landroid/content/SharedPreferences;
- invoke-interface {v1}, Landroid/content/SharedPreferences;->edit()Landroid/content/SharedPreferences$Editor;
- move-result-object v0
- .line 234
- .local v0, "edit":Landroid/content/SharedPreferences$Editor;
- const-string v2, "timestamp"
- invoke-interface {v0, v2, p1, p2}, Landroid/content/SharedPreferences$Editor;->putLong(Ljava/lang/String;J)Landroid/content/SharedPreferences$Editor;
- .line 235
- const-string v2, "crc"
- invoke-interface {v0, v2, p3, p4}, Landroid/content/SharedPreferences$Editor;->putLong(Ljava/lang/String;J)Landroid/content/SharedPreferences$Editor;
- .line 240
- const-string v2, "dex.number"
- invoke-interface {v0, v2, p5}, Landroid/content/SharedPreferences$Editor;->putInt(Ljava/lang/String;I)Landroid/content/SharedPreferences$Editor;
- .line 241
- invoke-static {v0}, Landroid/support/multidex/MultiDexExtractor;->apply(Landroid/content/SharedPreferences$Editor;)V
- .line 242
- return-void
- .end method
- .method static verifyZipFile(Ljava/io/File;)Z
- .locals 6
- .param p0, "file" # Ljava/io/File;
- .prologue
- .line 329
- :try_start_0
- new-instance v2, Ljava/util/zip/ZipFile;
- invoke-direct {v2, p0}, Ljava/util/zip/ZipFile;-><init>(Ljava/io/File;)V
- :try_end_0
- .catch Ljava/util/zip/ZipException; {:try_start_0 .. :try_end_0} :catch_1
- .catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_2
- .line 331
- .local v2, "zipFile":Ljava/util/zip/ZipFile;
- :try_start_1
- invoke-virtual {v2}, Ljava/util/zip/ZipFile;->close()V
- :try_end_1
- .catch Ljava/io/IOException; {:try_start_1 .. :try_end_1} :catch_0
- .catch Ljava/util/zip/ZipException; {:try_start_1 .. :try_end_1} :catch_1
- .line 332
- const/4 v3, 0x1
- .line 341
- .end local v2 # "zipFile":Ljava/util/zip/ZipFile;
- :goto_0
- return v3
- .line 333
- .restart local v2 # "zipFile":Ljava/util/zip/ZipFile;
- :catch_0
- move-exception v0
- .line 334
- .local v0, "e":Ljava/io/IOException;
- :try_start_2
- const-string v3, "MultiDex"
- new-instance v4, Ljava/lang/StringBuilder;
- const-string v5, "Failed to close zip file: "
- invoke-direct {v4, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {p0}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
- move-result-object v5
- invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v4
- invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v4
- invoke-static {v3, v4}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
- :try_end_2
- .catch Ljava/util/zip/ZipException; {:try_start_2 .. :try_end_2} :catch_1
- .catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_2
- .line 341
- .end local v0 # "e":Ljava/io/IOException;
- .end local v2 # "zipFile":Ljava/util/zip/ZipFile;
- :goto_1
- const/4 v3, 0x0
- goto :goto_0
- .line 336
- :catch_1
- move-exception v1
- .line 337
- .local v1, "ex":Ljava/util/zip/ZipException;
- const-string v3, "MultiDex"
- new-instance v4, Ljava/lang/StringBuilder;
- const-string v5, "File "
- invoke-direct {v4, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {p0}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
- move-result-object v5
- invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v4
- const-string v5, " is not a valid zip file."
- invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v4
- invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v4
- invoke-static {v3, v4, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
- goto :goto_1
- .line 338
- .end local v1 # "ex":Ljava/util/zip/ZipException;
- :catch_2
- move-exception v1
- .line 339
- .local v1, "ex":Ljava/io/IOException;
- const-string v3, "MultiDex"
- new-instance v4, Ljava/lang/StringBuilder;
- const-string v5, "Got an IOException trying to open zip file: "
- invoke-direct {v4, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
- invoke-virtual {p0}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
- move-result-object v5
- invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
- move-result-object v4
- invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
- move-result-object v4
- invoke-static {v3, v4, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
- goto :goto_1
- .end method
|