.class public final Lokhttp3/internal/cache/DiskLruCache; .super Ljava/lang/Object; .source "SourceFile" # interfaces .implements Ljava/io/Closeable; .implements Ljava/io/Flushable; # annotations .annotation system Ldalvik/annotation/MemberClasses; value = { Lokhttp3/internal/cache/DiskLruCache$Entry;, Lokhttp3/internal/cache/DiskLruCache$Editor;, Lokhttp3/internal/cache/DiskLruCache$Snapshot; } .end annotation # static fields .field public static final LEGAL_KEY_PATTERN:Ljava/util/regex/Pattern; # instance fields .field public final appVersion:I .field public final cleanupRunnable:Ljava/lang/Runnable; .field public closed:Z .field public final directory:Ljava/io/File; .field public final executor:Ljava/util/concurrent/Executor; .field public final fileSystem:Lokhttp3/internal/io/FileSystem; .field public hasJournalErrors:Z .field public initialized:Z .field public final journalFile:Ljava/io/File; .field public final journalFileBackup:Ljava/io/File; .field public final journalFileTmp:Ljava/io/File; .field public journalWriter:Lokio/BufferedSink; .field public final lruEntries:Ljava/util/LinkedHashMap; .field public maxSize:J .field public mostRecentRebuildFailed:Z .field public mostRecentTrimFailed:Z .field public nextSequenceNumber:J .field public redundantOpCount:I .field public size:J .field public final valueCount:I # direct methods .method public static synthetic $closeResource(Ljava/lang/Throwable;Ljava/lang/AutoCloseable;)V .locals 0 if-eqz p0, :cond_0 .line 308 :try_start_0 invoke-interface {p1}, Ljava/lang/AutoCloseable;->close()V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 goto :goto_0 :catchall_0 move-exception p1 invoke-virtual {p0, p1}, Ljava/lang/Throwable;->addSuppressed(Ljava/lang/Throwable;)V goto :goto_0 :cond_0 invoke-interface {p1}, Ljava/lang/AutoCloseable;->close()V :goto_0 return-void .end method .method static constructor ()V .locals 1 const-string v0, "[a-z0-9_-]{1,120}" .line 94 invoke-static {v0}, Ljava/util/regex/Pattern;->compile(Ljava/lang/String;)Ljava/util/regex/Pattern; move-result-object v0 sput-object v0, Lokhttp3/internal/cache/DiskLruCache;->LEGAL_KEY_PATTERN:Ljava/util/regex/Pattern; return-void .end method .method public constructor (Lokhttp3/internal/io/FileSystem;Ljava/io/File;IIJLjava/util/concurrent/Executor;)V .locals 6 .line 196 invoke-direct {p0}, Ljava/lang/Object;->()V const-wide/16 v0, 0x0 iput-wide v0, p0, Lokhttp3/internal/cache/DiskLruCache;->size:J .line 150 new-instance v2, Ljava/util/LinkedHashMap; const/high16 v3, 0x3f400000 # 0.75f const/4 v4, 0x1 const/4 v5, 0x0 invoke-direct {v2, v5, v3, v4}, Ljava/util/LinkedHashMap;->(IFZ)V iput-object v2, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; iput-wide v0, p0, Lokhttp3/internal/cache/DiskLruCache;->nextSequenceNumber:J .line 169 new-instance v0, Lokhttp3/internal/cache/DiskLruCache$1; invoke-direct {v0, p0}, Lokhttp3/internal/cache/DiskLruCache$1;->(Lokhttp3/internal/cache/DiskLruCache;)V iput-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->cleanupRunnable:Ljava/lang/Runnable; iput-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; iput-object p2, p0, Lokhttp3/internal/cache/DiskLruCache;->directory:Ljava/io/File; iput p3, p0, Lokhttp3/internal/cache/DiskLruCache;->appVersion:I .line 200 new-instance p1, Ljava/io/File; const-string p3, "journal" invoke-direct {p1, p2, p3}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V iput-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFile:Ljava/io/File; .line 201 new-instance p1, Ljava/io/File; const-string p3, "journal.tmp" invoke-direct {p1, p2, p3}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V iput-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFileTmp:Ljava/io/File; .line 202 new-instance p1, Ljava/io/File; const-string p3, "journal.bkp" invoke-direct {p1, p2, p3}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V iput-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFileBackup:Ljava/io/File; iput p4, p0, Lokhttp3/internal/cache/DiskLruCache;->valueCount:I iput-wide p5, p0, Lokhttp3/internal/cache/DiskLruCache;->maxSize:J iput-object p7, p0, Lokhttp3/internal/cache/DiskLruCache;->executor:Ljava/util/concurrent/Executor; return-void .end method .method public static create(Lokhttp3/internal/io/FileSystem;Ljava/io/File;IIJ)Lokhttp3/internal/cache/DiskLruCache; .locals 10 const-wide/16 v0, 0x0 cmp-long v0, p4, v0 if-lez v0, :cond_1 if-lez p3, :cond_0 .line 269 new-instance v0, Ljava/util/concurrent/ThreadPoolExecutor; const/4 v2, 0x0 const/4 v3, 0x1 const-wide/16 v4, 0x3c sget-object v6, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit; new-instance v7, Ljava/util/concurrent/LinkedBlockingQueue; invoke-direct {v7}, Ljava/util/concurrent/LinkedBlockingQueue;->()V const-string v1, "OkHttp DiskLruCache" const/4 v8, 0x1 .line 270 invoke-static {v1, v8}, Lokhttp3/internal/Util;->threadFactory(Ljava/lang/String;Z)Ljava/util/concurrent/ThreadFactory; move-result-object v8 move-object v1, v0 invoke-direct/range {v1 .. v8}, Ljava/util/concurrent/ThreadPoolExecutor;->(IIJLjava/util/concurrent/TimeUnit;Ljava/util/concurrent/BlockingQueue;Ljava/util/concurrent/ThreadFactory;)V .line 272 new-instance v9, Lokhttp3/internal/cache/DiskLruCache; move-object v1, v9 move-object v2, p0 move-object v3, p1 move v4, p2 move v5, p3 move-wide v6, p4 move-object v8, v0 invoke-direct/range {v1 .. v8}, Lokhttp3/internal/cache/DiskLruCache;->(Lokhttp3/internal/io/FileSystem;Ljava/io/File;IIJLjava/util/concurrent/Executor;)V return-object v9 .line 265 :cond_0 new-instance p0, Ljava/lang/IllegalArgumentException; const-string p1, "valueCount <= 0" invoke-direct {p0, p1}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V throw p0 .line 262 :cond_1 new-instance p0, Ljava/lang/IllegalArgumentException; const-string p1, "maxSize <= 0" invoke-direct {p0, p1}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V throw p0 .end method # virtual methods .method public final declared-synchronized checkNotClosed()V .locals 2 monitor-enter p0 .line 644 :try_start_0 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->isClosed()Z move-result v0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 if-nez v0, :cond_0 .line 647 monitor-exit p0 return-void .line 645 :cond_0 :try_start_1 new-instance v0, Ljava/lang/IllegalStateException; const-string v1, "cache is closed" invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;->(Ljava/lang/String;)V throw v0 :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 :catchall_0 move-exception v0 .line 647 monitor-exit p0 throw v0 .end method .method public declared-synchronized close()V .locals 5 monitor-enter p0 :try_start_0 iget-boolean v0, p0, Lokhttp3/internal/cache/DiskLruCache;->initialized:Z const/4 v1, 0x1 if-eqz v0, :cond_3 iget-boolean v0, p0, Lokhttp3/internal/cache/DiskLruCache;->closed:Z if-eqz v0, :cond_0 goto :goto_2 :cond_0 iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; .line 665 invoke-virtual {v0}, Ljava/util/LinkedHashMap;->values()Ljava/util/Collection; move-result-object v0 iget-object v2, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; invoke-virtual {v2}, Ljava/util/AbstractMap;->size()I move-result v2 new-array v2, v2, [Lokhttp3/internal/cache/DiskLruCache$Entry; invoke-interface {v0, v2}, Ljava/util/Collection;->toArray([Ljava/lang/Object;)[Ljava/lang/Object; move-result-object v0 check-cast v0, [Lokhttp3/internal/cache/DiskLruCache$Entry; array-length v2, v0 const/4 v3, 0x0 :goto_0 if-ge v3, v2, :cond_2 aget-object v4, v0, v3 .line 666 iget-object v4, v4, Lokhttp3/internal/cache/DiskLruCache$Entry;->currentEditor:Lokhttp3/internal/cache/DiskLruCache$Editor; if-eqz v4, :cond_1 .line 667 invoke-virtual {v4}, Lokhttp3/internal/cache/DiskLruCache$Editor;->abort()V goto :goto_1 :catchall_0 move-exception v0 goto :goto_3 :cond_1 :goto_1 add-int/lit8 v3, v3, 0x1 goto :goto_0 .line 670 :cond_2 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->trimToSize()V iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; .line 671 invoke-interface {v0}, Lokio/Sink;->close()V const/4 v0, 0x0 iput-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; iput-boolean v1, p0, Lokhttp3/internal/cache/DiskLruCache;->closed:Z :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 .line 674 monitor-exit p0 return-void :cond_3 :goto_2 :try_start_1 iput-boolean v1, p0, Lokhttp3/internal/cache/DiskLruCache;->closed:Z :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 .line 662 monitor-exit p0 return-void :goto_3 monitor-exit p0 throw v0 .end method .method public declared-synchronized completeEdit(Lokhttp3/internal/cache/DiskLruCache$Editor;Z)V .locals 9 monitor-enter p0 .line 529 :try_start_0 iget-object v0, p1, Lokhttp3/internal/cache/DiskLruCache$Editor;->entry:Lokhttp3/internal/cache/DiskLruCache$Entry; .line 530 iget-object v1, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->currentEditor:Lokhttp3/internal/cache/DiskLruCache$Editor; if-ne v1, p1, :cond_a const/4 v1, 0x0 if-eqz p2, :cond_2 .line 535 iget-boolean v2, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->readable:Z if-nez v2, :cond_2 move v2, v1 :goto_0 iget v3, p0, Lokhttp3/internal/cache/DiskLruCache;->valueCount:I if-ge v2, v3, :cond_2 .line 537 iget-object v3, p1, Lokhttp3/internal/cache/DiskLruCache$Editor;->written:[Z aget-boolean v3, v3, v2 if-eqz v3, :cond_1 iget-object v3, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; .line 541 iget-object v4, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->dirtyFiles:[Ljava/io/File; aget-object v4, v4, v2 invoke-interface {v3, v4}, Lokhttp3/internal/io/FileSystem;->exists(Ljava/io/File;)Z move-result v3 if-nez v3, :cond_0 .line 542 invoke-virtual {p1}, Lokhttp3/internal/cache/DiskLruCache$Editor;->abort()V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 .line 543 monitor-exit p0 return-void :catchall_0 move-exception p1 goto/16 :goto_4 :cond_0 add-int/lit8 v2, v2, 0x1 goto :goto_0 .line 538 :cond_1 :try_start_1 invoke-virtual {p1}, Lokhttp3/internal/cache/DiskLruCache$Editor;->abort()V .line 539 new-instance p1, Ljava/lang/IllegalStateException; new-instance p2, Ljava/lang/StringBuilder; invoke-direct {p2}, Ljava/lang/StringBuilder;->()V const-string v0, "Newly created entry didn\'t create value for index " invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p2, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p2 invoke-direct {p1, p2}, Ljava/lang/IllegalStateException;->(Ljava/lang/String;)V throw p1 :cond_2 :goto_1 iget p1, p0, Lokhttp3/internal/cache/DiskLruCache;->valueCount:I if-ge v1, p1, :cond_5 .line 549 iget-object p1, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->dirtyFiles:[Ljava/io/File; aget-object p1, p1, v1 if-eqz p2, :cond_3 iget-object v2, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; .line 551 invoke-interface {v2, p1}, Lokhttp3/internal/io/FileSystem;->exists(Ljava/io/File;)Z move-result v2 if-eqz v2, :cond_4 .line 552 iget-object v2, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->cleanFiles:[Ljava/io/File; aget-object v2, v2, v1 iget-object v3, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; .line 553 invoke-interface {v3, p1, v2}, Lokhttp3/internal/io/FileSystem;->rename(Ljava/io/File;Ljava/io/File;)V .line 554 iget-object p1, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->lengths:[J aget-wide v3, p1, v1 iget-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; .line 555 invoke-interface {p1, v2}, Lokhttp3/internal/io/FileSystem;->size(Ljava/io/File;)J move-result-wide v5 .line 556 iget-object p1, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->lengths:[J aput-wide v5, p1, v1 iget-wide v7, p0, Lokhttp3/internal/cache/DiskLruCache;->size:J sub-long/2addr v7, v3 add-long/2addr v7, v5 iput-wide v7, p0, Lokhttp3/internal/cache/DiskLruCache;->size:J goto :goto_2 :cond_3 iget-object v2, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; .line 560 invoke-interface {v2, p1}, Lokhttp3/internal/io/FileSystem;->delete(Ljava/io/File;)V :cond_4 :goto_2 add-int/lit8 v1, v1, 0x1 goto :goto_1 :cond_5 iget p1, p0, Lokhttp3/internal/cache/DiskLruCache;->redundantOpCount:I const/4 v1, 0x1 add-int/2addr p1, v1 iput p1, p0, Lokhttp3/internal/cache/DiskLruCache;->redundantOpCount:I const/4 p1, 0x0 .line 565 iput-object p1, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->currentEditor:Lokhttp3/internal/cache/DiskLruCache$Editor; .line 566 iget-boolean p1, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->readable:Z or-int/2addr p1, p2 const/16 v2, 0xa const/16 v3, 0x20 if-eqz p1, :cond_6 .line 567 iput-boolean v1, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->readable:Z iget-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; const-string v1, "CLEAN" .line 568 invoke-interface {p1, v1}, Lokio/BufferedSink;->writeUtf8(Ljava/lang/String;)Lokio/BufferedSink; move-result-object p1 invoke-interface {p1, v3}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; iget-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; .line 569 iget-object v1, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->key:Ljava/lang/String; invoke-interface {p1, v1}, Lokio/BufferedSink;->writeUtf8(Ljava/lang/String;)Lokio/BufferedSink; iget-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; .line 570 invoke-virtual {v0, p1}, Lokhttp3/internal/cache/DiskLruCache$Entry;->writeLengths(Lokio/BufferedSink;)V iget-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; .line 571 invoke-interface {p1, v2}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; if-eqz p2, :cond_7 iget-wide p1, p0, Lokhttp3/internal/cache/DiskLruCache;->nextSequenceNumber:J const-wide/16 v1, 0x1 add-long/2addr v1, p1 iput-wide v1, p0, Lokhttp3/internal/cache/DiskLruCache;->nextSequenceNumber:J .line 573 iput-wide p1, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->sequenceNumber:J goto :goto_3 :cond_6 iget-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; .line 576 iget-object p2, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->key:Ljava/lang/String; invoke-virtual {p1, p2}, Ljava/util/AbstractMap;->remove(Ljava/lang/Object;)Ljava/lang/Object; iget-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; const-string p2, "REMOVE" .line 577 invoke-interface {p1, p2}, Lokio/BufferedSink;->writeUtf8(Ljava/lang/String;)Lokio/BufferedSink; move-result-object p1 invoke-interface {p1, v3}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; iget-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; .line 578 iget-object p2, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->key:Ljava/lang/String; invoke-interface {p1, p2}, Lokio/BufferedSink;->writeUtf8(Ljava/lang/String;)Lokio/BufferedSink; iget-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; .line 579 invoke-interface {p1, v2}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; :cond_7 :goto_3 iget-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; .line 581 invoke-interface {p1}, Lokio/BufferedSink;->flush()V iget-wide p1, p0, Lokhttp3/internal/cache/DiskLruCache;->size:J iget-wide v0, p0, Lokhttp3/internal/cache/DiskLruCache;->maxSize:J cmp-long p1, p1, v0 if-gtz p1, :cond_8 .line 583 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->journalRebuildRequired()Z move-result p1 if-eqz p1, :cond_9 :cond_8 iget-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->executor:Ljava/util/concurrent/Executor; iget-object p2, p0, Lokhttp3/internal/cache/DiskLruCache;->cleanupRunnable:Ljava/lang/Runnable; .line 584 invoke-interface {p1, p2}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 .line 586 :cond_9 monitor-exit p0 return-void .line 531 :cond_a :try_start_2 new-instance p1, Ljava/lang/IllegalStateException; invoke-direct {p1}, Ljava/lang/IllegalStateException;->()V throw p1 :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 .line 586 :goto_4 monitor-exit p0 throw p1 .end method .method public delete()V .locals 2 .line 689 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->close()V iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->directory:Ljava/io/File; .line 690 invoke-interface {v0, v1}, Lokhttp3/internal/io/FileSystem;->deleteContents(Ljava/io/File;)V return-void .end method .method public edit(Ljava/lang/String;)Lokhttp3/internal/cache/DiskLruCache$Editor; .locals 2 const-wide/16 v0, -0x1 .line 453 invoke-virtual {p0, p1, v0, v1}, Lokhttp3/internal/cache/DiskLruCache;->edit(Ljava/lang/String;J)Lokhttp3/internal/cache/DiskLruCache$Editor; move-result-object p1 return-object p1 .end method .method public declared-synchronized edit(Ljava/lang/String;J)Lokhttp3/internal/cache/DiskLruCache$Editor; .locals 5 monitor-enter p0 .line 457 :try_start_0 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->initialize()V .line 459 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->checkNotClosed()V .line 460 invoke-virtual {p0, p1}, Lokhttp3/internal/cache/DiskLruCache;->validateKey(Ljava/lang/String;)V iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; .line 461 invoke-virtual {v0, p1}, Ljava/util/LinkedHashMap;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v0 check-cast v0, Lokhttp3/internal/cache/DiskLruCache$Entry; const-wide/16 v1, -0x1 cmp-long v1, p2, v1 const/4 v2, 0x0 if-eqz v1, :cond_1 if-eqz v0, :cond_0 .line 462 iget-wide v3, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->sequenceNumber:J :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 cmp-long p2, v3, p2 if-eqz p2, :cond_1 goto :goto_0 :catchall_0 move-exception p1 goto :goto_2 .line 464 :cond_0 :goto_0 monitor-exit p0 return-object v2 :cond_1 if-eqz v0, :cond_2 .line 466 :try_start_1 iget-object p2, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->currentEditor:Lokhttp3/internal/cache/DiskLruCache$Editor; :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 if-eqz p2, :cond_2 .line 467 monitor-exit p0 return-object v2 :cond_2 :try_start_2 iget-boolean p2, p0, Lokhttp3/internal/cache/DiskLruCache;->mostRecentTrimFailed:Z if-nez p2, :cond_6 iget-boolean p2, p0, Lokhttp3/internal/cache/DiskLruCache;->mostRecentRebuildFailed:Z if-eqz p2, :cond_3 goto :goto_1 :cond_3 iget-object p2, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; const-string p3, "DIRTY" .line 480 invoke-interface {p2, p3}, Lokio/BufferedSink;->writeUtf8(Ljava/lang/String;)Lokio/BufferedSink; move-result-object p2 const/16 p3, 0x20 invoke-interface {p2, p3}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; move-result-object p2 invoke-interface {p2, p1}, Lokio/BufferedSink;->writeUtf8(Ljava/lang/String;)Lokio/BufferedSink; move-result-object p2 const/16 p3, 0xa invoke-interface {p2, p3}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; iget-object p2, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; .line 481 invoke-interface {p2}, Lokio/BufferedSink;->flush()V iget-boolean p2, p0, Lokhttp3/internal/cache/DiskLruCache;->hasJournalErrors:Z :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 if-eqz p2, :cond_4 .line 484 monitor-exit p0 return-object v2 :cond_4 if-nez v0, :cond_5 .line 488 :try_start_3 new-instance v0, Lokhttp3/internal/cache/DiskLruCache$Entry; invoke-direct {v0, p0, p1}, Lokhttp3/internal/cache/DiskLruCache$Entry;->(Lokhttp3/internal/cache/DiskLruCache;Ljava/lang/String;)V iget-object p2, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; .line 489 invoke-virtual {p2, p1, v0}, Ljava/util/AbstractMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 491 :cond_5 new-instance p1, Lokhttp3/internal/cache/DiskLruCache$Editor; invoke-direct {p1, p0, v0}, Lokhttp3/internal/cache/DiskLruCache$Editor;->(Lokhttp3/internal/cache/DiskLruCache;Lokhttp3/internal/cache/DiskLruCache$Entry;)V .line 492 iput-object p1, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->currentEditor:Lokhttp3/internal/cache/DiskLruCache$Editor; :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_0 .line 493 monitor-exit p0 return-object p1 :cond_6 :goto_1 :try_start_4 iget-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->executor:Ljava/util/concurrent/Executor; iget-object p2, p0, Lokhttp3/internal/cache/DiskLruCache;->cleanupRunnable:Ljava/lang/Runnable; .line 475 invoke-interface {p1, p2}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_0 .line 476 monitor-exit p0 return-object v2 :goto_2 monitor-exit p0 throw p1 .end method .method public declared-synchronized flush()V .locals 1 monitor-enter p0 :try_start_0 iget-boolean v0, p0, Lokhttp3/internal/cache/DiskLruCache;->initialized:Z :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 if-nez v0, :cond_0 .line 651 monitor-exit p0 return-void .line 653 :cond_0 :try_start_1 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->checkNotClosed()V .line 654 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->trimToSize()V iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; .line 655 invoke-interface {v0}, Lokio/BufferedSink;->flush()V :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 .line 656 monitor-exit p0 return-void :catchall_0 move-exception v0 monitor-exit p0 throw v0 .end method .method public declared-synchronized get(Ljava/lang/String;)Lokhttp3/internal/cache/DiskLruCache$Snapshot; .locals 3 monitor-enter p0 .line 430 :try_start_0 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->initialize()V .line 432 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->checkNotClosed()V .line 433 invoke-virtual {p0, p1}, Lokhttp3/internal/cache/DiskLruCache;->validateKey(Ljava/lang/String;)V iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; .line 434 invoke-virtual {v0, p1}, Ljava/util/LinkedHashMap;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v0 check-cast v0, Lokhttp3/internal/cache/DiskLruCache$Entry; const/4 v1, 0x0 if-eqz v0, :cond_3 .line 435 iget-boolean v2, v0, Lokhttp3/internal/cache/DiskLruCache$Entry;->readable:Z if-nez v2, :cond_0 goto :goto_1 .line 437 :cond_0 invoke-virtual {v0}, Lokhttp3/internal/cache/DiskLruCache$Entry;->snapshot()Lokhttp3/internal/cache/DiskLruCache$Snapshot; move-result-object v0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 if-nez v0, :cond_1 .line 438 monitor-exit p0 return-object v1 :cond_1 :try_start_1 iget v1, p0, Lokhttp3/internal/cache/DiskLruCache;->redundantOpCount:I add-int/lit8 v1, v1, 0x1 iput v1, p0, Lokhttp3/internal/cache/DiskLruCache;->redundantOpCount:I iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; const-string v2, "READ" .line 441 invoke-interface {v1, v2}, Lokio/BufferedSink;->writeUtf8(Ljava/lang/String;)Lokio/BufferedSink; move-result-object v1 const/16 v2, 0x20 invoke-interface {v1, v2}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; move-result-object v1 invoke-interface {v1, p1}, Lokio/BufferedSink;->writeUtf8(Ljava/lang/String;)Lokio/BufferedSink; move-result-object p1 const/16 v1, 0xa invoke-interface {p1, v1}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; .line 442 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->journalRebuildRequired()Z move-result p1 if-eqz p1, :cond_2 iget-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->executor:Ljava/util/concurrent/Executor; iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->cleanupRunnable:Ljava/lang/Runnable; .line 443 invoke-interface {p1, v1}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 goto :goto_0 :catchall_0 move-exception p1 goto :goto_2 .line 446 :cond_2 :goto_0 monitor-exit p0 return-object v0 .line 435 :cond_3 :goto_1 monitor-exit p0 return-object v1 :goto_2 monitor-exit p0 throw p1 .end method .method public declared-synchronized initialize()V .locals 5 monitor-enter p0 :try_start_0 iget-boolean v0, p0, Lokhttp3/internal/cache/DiskLruCache;->initialized:Z :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 if-eqz v0, :cond_0 .line 212 monitor-exit p0 return-void :cond_0 :try_start_1 iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFileBackup:Ljava/io/File; .line 216 invoke-interface {v0, v1}, Lokhttp3/internal/io/FileSystem;->exists(Ljava/io/File;)Z move-result v0 if-eqz v0, :cond_2 iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFile:Ljava/io/File; .line 218 invoke-interface {v0, v1}, Lokhttp3/internal/io/FileSystem;->exists(Ljava/io/File;)Z move-result v0 if-eqz v0, :cond_1 iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFileBackup:Ljava/io/File; .line 219 invoke-interface {v0, v1}, Lokhttp3/internal/io/FileSystem;->delete(Ljava/io/File;)V goto :goto_0 :catchall_0 move-exception v0 goto :goto_2 :cond_1 iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFileBackup:Ljava/io/File; iget-object v2, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFile:Ljava/io/File; .line 221 invoke-interface {v0, v1, v2}, Lokhttp3/internal/io/FileSystem;->rename(Ljava/io/File;Ljava/io/File;)V :cond_2 :goto_0 iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFile:Ljava/io/File; .line 226 invoke-interface {v0, v1}, Lokhttp3/internal/io/FileSystem;->exists(Ljava/io/File;)Z move-result v0 :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 const/4 v1, 0x1 if-eqz v0, :cond_3 .line 228 :try_start_2 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->readJournal()V .line 229 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->processJournal()V iput-boolean v1, p0, Lokhttp3/internal/cache/DiskLruCache;->initialized:Z :try_end_2 .catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_0 .catchall {:try_start_2 .. :try_end_2} :catchall_0 .line 231 monitor-exit p0 return-void :catch_0 move-exception v0 .line 233 :try_start_3 invoke-static {}, Lokhttp3/internal/platform/Platform;->get()Lokhttp3/internal/platform/Platform; move-result-object v2 new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v4, "DiskLruCache " invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; iget-object v4, p0, Lokhttp3/internal/cache/DiskLruCache;->directory:Ljava/io/File; invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; const-string v4, " is corrupt: " invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; .line 234 invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String; move-result-object v4 invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v4, ", removing" invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v3 const/4 v4, 0x5 .line 233 invoke-virtual {v2, v4, v3, v0}, Lokhttp3/internal/platform/Platform;->log(ILjava/lang/String;Ljava/lang/Throwable;)V :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_0 const/4 v0, 0x0 .line 240 :try_start_4 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->delete()V :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_1 :try_start_5 iput-boolean v0, p0, Lokhttp3/internal/cache/DiskLruCache;->closed:Z goto :goto_1 :catchall_1 move-exception v1 iput-boolean v0, p0, Lokhttp3/internal/cache/DiskLruCache;->closed:Z .line 242 throw v1 .line 246 :cond_3 :goto_1 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->rebuildJournal()V iput-boolean v1, p0, Lokhttp3/internal/cache/DiskLruCache;->initialized:Z :try_end_5 .catchall {:try_start_5 .. :try_end_5} :catchall_0 .line 249 monitor-exit p0 return-void :goto_2 monitor-exit p0 throw v0 .end method .method public declared-synchronized isClosed()Z .locals 1 monitor-enter p0 :try_start_0 iget-boolean v0, p0, Lokhttp3/internal/cache/DiskLruCache;->closed:Z :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 .line 640 monitor-exit p0 return v0 :catchall_0 move-exception v0 monitor-exit p0 throw v0 .end method .method public journalRebuildRequired()Z .locals 2 iget v0, p0, Lokhttp3/internal/cache/DiskLruCache;->redundantOpCount:I const/16 v1, 0x7d0 if-lt v0, v1, :cond_0 iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; .line 595 invoke-virtual {v1}, Ljava/util/AbstractMap;->size()I move-result v1 if-lt v0, v1, :cond_0 const/4 v0, 0x1 goto :goto_0 :cond_0 const/4 v0, 0x0 :goto_0 return v0 .end method .method public final newJournalWriter()Lokio/BufferedSink; .locals 2 iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFile:Ljava/io/File; .line 312 invoke-interface {v0, v1}, Lokhttp3/internal/io/FileSystem;->appendingSink(Ljava/io/File;)Lokio/Sink; move-result-object v0 .line 313 new-instance v1, Lokhttp3/internal/cache/DiskLruCache$2; invoke-direct {v1, p0, v0}, Lokhttp3/internal/cache/DiskLruCache$2;->(Lokhttp3/internal/cache/DiskLruCache;Lokio/Sink;)V .line 319 invoke-static {v1}, Lokio/Okio;->buffer(Lokio/Sink;)Lokio/BufferedSink; move-result-object v0 return-object v0 .end method .method public final processJournal()V .locals 8 iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFileTmp:Ljava/io/File; .line 366 invoke-interface {v0, v1}, Lokhttp3/internal/io/FileSystem;->delete(Ljava/io/File;)V iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; .line 367 invoke-virtual {v0}, Ljava/util/LinkedHashMap;->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_3 .line 368 invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v1 check-cast v1, Lokhttp3/internal/cache/DiskLruCache$Entry; .line 369 iget-object v2, v1, Lokhttp3/internal/cache/DiskLruCache$Entry;->currentEditor:Lokhttp3/internal/cache/DiskLruCache$Editor; const/4 v3, 0x0 if-nez v2, :cond_1 :goto_1 iget v2, p0, Lokhttp3/internal/cache/DiskLruCache;->valueCount:I if-ge v3, v2, :cond_0 iget-wide v4, p0, Lokhttp3/internal/cache/DiskLruCache;->size:J .line 371 iget-object v2, v1, Lokhttp3/internal/cache/DiskLruCache$Entry;->lengths:[J aget-wide v6, v2, v3 add-long/2addr v4, v6 iput-wide v4, p0, Lokhttp3/internal/cache/DiskLruCache;->size:J add-int/lit8 v3, v3, 0x1 goto :goto_1 :cond_1 const/4 v2, 0x0 .line 374 iput-object v2, v1, Lokhttp3/internal/cache/DiskLruCache$Entry;->currentEditor:Lokhttp3/internal/cache/DiskLruCache$Editor; :goto_2 iget v2, p0, Lokhttp3/internal/cache/DiskLruCache;->valueCount:I if-ge v3, v2, :cond_2 iget-object v2, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; .line 376 iget-object v4, v1, Lokhttp3/internal/cache/DiskLruCache$Entry;->cleanFiles:[Ljava/io/File; aget-object v4, v4, v3 invoke-interface {v2, v4}, Lokhttp3/internal/io/FileSystem;->delete(Ljava/io/File;)V iget-object v2, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; .line 377 iget-object v4, v1, Lokhttp3/internal/cache/DiskLruCache$Entry;->dirtyFiles:[Ljava/io/File; aget-object v4, v4, v3 invoke-interface {v2, v4}, Lokhttp3/internal/io/FileSystem;->delete(Ljava/io/File;)V add-int/lit8 v3, v3, 0x1 goto :goto_2 .line 379 :cond_2 invoke-interface {v0}, Ljava/util/Iterator;->remove()V goto :goto_0 :cond_3 return-void .end method .method public final readJournal()V .locals 9 const-string v0, ", " iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; iget-object v2, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFile:Ljava/io/File; .line 276 invoke-interface {v1, v2}, Lokhttp3/internal/io/FileSystem;->source(Ljava/io/File;)Lokio/Source; move-result-object v1 invoke-static {v1}, Lokio/Okio;->buffer(Lokio/Source;)Lokio/BufferedSource; move-result-object v1 .line 277 :try_start_0 invoke-interface {v1}, Lokio/BufferedSource;->readUtf8LineStrict()Ljava/lang/String; move-result-object v2 .line 278 invoke-interface {v1}, Lokio/BufferedSource;->readUtf8LineStrict()Ljava/lang/String; move-result-object v3 .line 279 invoke-interface {v1}, Lokio/BufferedSource;->readUtf8LineStrict()Ljava/lang/String; move-result-object v4 .line 280 invoke-interface {v1}, Lokio/BufferedSource;->readUtf8LineStrict()Ljava/lang/String; move-result-object v5 .line 281 invoke-interface {v1}, Lokio/BufferedSource;->readUtf8LineStrict()Ljava/lang/String; move-result-object v6 const-string v7, "libcore.io.DiskLruCache" .line 282 invoke-virtual {v7, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v7 if-eqz v7, :cond_1 const-string v7, "1" .line 283 invoke-virtual {v7, v3}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v7 if-eqz v7, :cond_1 iget v7, p0, Lokhttp3/internal/cache/DiskLruCache;->appVersion:I .line 284 invoke-static {v7}, Ljava/lang/Integer;->toString(I)Ljava/lang/String; move-result-object v7 invoke-virtual {v7, v4}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v4 if-eqz v4, :cond_1 iget v4, p0, Lokhttp3/internal/cache/DiskLruCache;->valueCount:I .line 285 invoke-static {v4}, Ljava/lang/Integer;->toString(I)Ljava/lang/String; move-result-object v4 invoke-virtual {v4, v5}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v4 if-eqz v4, :cond_1 const-string v4, "" .line 286 invoke-virtual {v4, v6}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v4 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 if-eqz v4, :cond_1 const/4 v0, 0x0 .line 294 :goto_0 :try_start_1 invoke-interface {v1}, Lokio/BufferedSource;->readUtf8LineStrict()Ljava/lang/String; move-result-object v2 invoke-virtual {p0, v2}, Lokhttp3/internal/cache/DiskLruCache;->readJournalLine(Ljava/lang/String;)V :try_end_1 .catch Ljava/io/EOFException; {:try_start_1 .. :try_end_1} :catch_0 .catchall {:try_start_1 .. :try_end_1} :catchall_0 add-int/lit8 v0, v0, 0x1 goto :goto_0 :catchall_0 move-exception v0 goto :goto_2 :catch_0 :try_start_2 iget-object v2, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; .line 300 invoke-virtual {v2}, Ljava/util/AbstractMap;->size()I move-result v2 sub-int/2addr v0, v2 iput v0, p0, Lokhttp3/internal/cache/DiskLruCache;->redundantOpCount:I .line 303 invoke-interface {v1}, Lokio/BufferedSource;->exhausted()Z move-result v0 if-nez v0, :cond_0 .line 304 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->rebuildJournal()V goto :goto_1 .line 306 :cond_0 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->newJournalWriter()Lokio/BufferedSink; move-result-object v0 iput-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 :goto_1 const/4 v0, 0x0 .line 308 invoke-static {v0, v1}, Lokhttp3/internal/cache/DiskLruCache;->$closeResource(Ljava/lang/Throwable;Ljava/lang/AutoCloseable;)V return-void .line 287 :cond_1 :try_start_3 new-instance v4, Ljava/io/IOException; new-instance v7, Ljava/lang/StringBuilder; invoke-direct {v7}, Ljava/lang/StringBuilder;->()V const-string v8, "unexpected journal header: [" invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v0, "]" invoke-virtual {v7, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 invoke-direct {v4, v0}, Ljava/io/IOException;->(Ljava/lang/String;)V throw v4 :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_0 .line 276 :goto_2 :try_start_4 throw v0 :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_1 :catchall_1 move-exception v2 if-eqz v1, :cond_2 .line 308 invoke-static {v0, v1}, Lokhttp3/internal/cache/DiskLruCache;->$closeResource(Ljava/lang/Throwable;Ljava/lang/AutoCloseable;)V :cond_2 throw v2 .end method .method public final readJournalLine(Ljava/lang/String;)V .locals 7 const/16 v0, 0x20 .line 323 invoke-virtual {p1, v0}, Ljava/lang/String;->indexOf(I)I move-result v1 const-string v2, "unexpected journal line: " const/4 v3, -0x1 if-eq v1, v3, :cond_6 add-int/lit8 v4, v1, 0x1 .line 329 invoke-virtual {p1, v0, v4}, Ljava/lang/String;->indexOf(II)I move-result v0 if-ne v0, v3, :cond_0 .line 332 invoke-virtual {p1, v4}, Ljava/lang/String;->substring(I)Ljava/lang/String; move-result-object v4 const/4 v5, 0x6 if-ne v1, v5, :cond_1 const-string v5, "REMOVE" .line 333 invoke-virtual {p1, v5}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z move-result v5 if-eqz v5, :cond_1 iget-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; .line 334 invoke-virtual {p1, v4}, Ljava/util/AbstractMap;->remove(Ljava/lang/Object;)Ljava/lang/Object; return-void .line 338 :cond_0 invoke-virtual {p1, v4, v0}, Ljava/lang/String;->substring(II)Ljava/lang/String; move-result-object v4 :cond_1 iget-object v5, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; .line 341 invoke-virtual {v5, v4}, Ljava/util/LinkedHashMap;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v5 check-cast v5, Lokhttp3/internal/cache/DiskLruCache$Entry; if-nez v5, :cond_2 .line 343 new-instance v5, Lokhttp3/internal/cache/DiskLruCache$Entry; invoke-direct {v5, p0, v4}, Lokhttp3/internal/cache/DiskLruCache$Entry;->(Lokhttp3/internal/cache/DiskLruCache;Ljava/lang/String;)V iget-object v6, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; .line 344 invoke-virtual {v6, v4, v5}, Ljava/util/AbstractMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; :cond_2 const/4 v4, 0x5 if-eq v0, v3, :cond_3 if-ne v1, v4, :cond_3 const-string v6, "CLEAN" .line 347 invoke-virtual {p1, v6}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z move-result v6 if-eqz v6, :cond_3 const/4 v1, 0x1 add-int/2addr v0, v1 .line 348 invoke-virtual {p1, v0}, Ljava/lang/String;->substring(I)Ljava/lang/String; move-result-object p1 const-string v0, " " invoke-virtual {p1, v0}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String; move-result-object p1 .line 349 iput-boolean v1, v5, Lokhttp3/internal/cache/DiskLruCache$Entry;->readable:Z const/4 v0, 0x0 .line 350 iput-object v0, v5, Lokhttp3/internal/cache/DiskLruCache$Entry;->currentEditor:Lokhttp3/internal/cache/DiskLruCache$Editor; .line 351 invoke-virtual {v5, p1}, Lokhttp3/internal/cache/DiskLruCache$Entry;->setLengths([Ljava/lang/String;)V goto :goto_0 :cond_3 if-ne v0, v3, :cond_4 if-ne v1, v4, :cond_4 const-string v4, "DIRTY" .line 352 invoke-virtual {p1, v4}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z move-result v4 if-eqz v4, :cond_4 .line 353 new-instance p1, Lokhttp3/internal/cache/DiskLruCache$Editor; invoke-direct {p1, p0, v5}, Lokhttp3/internal/cache/DiskLruCache$Editor;->(Lokhttp3/internal/cache/DiskLruCache;Lokhttp3/internal/cache/DiskLruCache$Entry;)V iput-object p1, v5, Lokhttp3/internal/cache/DiskLruCache$Entry;->currentEditor:Lokhttp3/internal/cache/DiskLruCache$Editor; goto :goto_0 :cond_4 if-ne v0, v3, :cond_5 const/4 v0, 0x4 if-ne v1, v0, :cond_5 const-string v0, "READ" .line 354 invoke-virtual {p1, v0}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z move-result v0 if-eqz v0, :cond_5 :goto_0 return-void .line 357 :cond_5 new-instance v0, Ljava/io/IOException; new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 invoke-direct {v0, p1}, Ljava/io/IOException;->(Ljava/lang/String;)V throw v0 .line 325 :cond_6 new-instance v0, Ljava/io/IOException; new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 invoke-direct {v0, p1}, Ljava/io/IOException;->(Ljava/lang/String;)V throw v0 .end method .method public declared-synchronized rebuildJournal()V .locals 6 monitor-enter p0 :try_start_0 iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; if-eqz v0, :cond_0 .line 390 invoke-interface {v0}, Lokio/Sink;->close()V goto :goto_0 :catchall_0 move-exception v0 goto/16 :goto_3 :cond_0 :goto_0 iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFileTmp:Ljava/io/File; .line 393 invoke-interface {v0, v1}, Lokhttp3/internal/io/FileSystem;->sink(Ljava/io/File;)Lokio/Sink; move-result-object v0 invoke-static {v0}, Lokio/Okio;->buffer(Lokio/Sink;)Lokio/BufferedSink; move-result-object v0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 :try_start_1 const-string v1, "libcore.io.DiskLruCache" .line 394 invoke-interface {v0, v1}, Lokio/BufferedSink;->writeUtf8(Ljava/lang/String;)Lokio/BufferedSink; move-result-object v1 const/16 v2, 0xa invoke-interface {v1, v2}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; const-string v1, "1" .line 395 invoke-interface {v0, v1}, Lokio/BufferedSink;->writeUtf8(Ljava/lang/String;)Lokio/BufferedSink; move-result-object v1 invoke-interface {v1, v2}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; iget v1, p0, Lokhttp3/internal/cache/DiskLruCache;->appVersion:I int-to-long v3, v1 .line 396 invoke-interface {v0, v3, v4}, Lokio/BufferedSink;->writeDecimalLong(J)Lokio/BufferedSink; move-result-object v1 invoke-interface {v1, v2}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; iget v1, p0, Lokhttp3/internal/cache/DiskLruCache;->valueCount:I int-to-long v3, v1 .line 397 invoke-interface {v0, v3, v4}, Lokio/BufferedSink;->writeDecimalLong(J)Lokio/BufferedSink; move-result-object v1 invoke-interface {v1, v2}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; .line 398 invoke-interface {v0, v2}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; .line 400 invoke-virtual {v1}, Ljava/util/LinkedHashMap;->values()Ljava/util/Collection; move-result-object v1 invoke-interface {v1}, Ljava/util/Collection;->iterator()Ljava/util/Iterator; move-result-object v1 :goto_1 invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z move-result v3 if-eqz v3, :cond_2 invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v3 check-cast v3, Lokhttp3/internal/cache/DiskLruCache$Entry; .line 401 iget-object v4, v3, Lokhttp3/internal/cache/DiskLruCache$Entry;->currentEditor:Lokhttp3/internal/cache/DiskLruCache$Editor; const/16 v5, 0x20 if-eqz v4, :cond_1 const-string v4, "DIRTY" .line 402 invoke-interface {v0, v4}, Lokio/BufferedSink;->writeUtf8(Ljava/lang/String;)Lokio/BufferedSink; move-result-object v4 invoke-interface {v4, v5}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; .line 403 iget-object v3, v3, Lokhttp3/internal/cache/DiskLruCache$Entry;->key:Ljava/lang/String; invoke-interface {v0, v3}, Lokio/BufferedSink;->writeUtf8(Ljava/lang/String;)Lokio/BufferedSink; .line 404 invoke-interface {v0, v2}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; goto :goto_1 :catchall_1 move-exception v1 goto :goto_2 :cond_1 const-string v4, "CLEAN" .line 406 invoke-interface {v0, v4}, Lokio/BufferedSink;->writeUtf8(Ljava/lang/String;)Lokio/BufferedSink; move-result-object v4 invoke-interface {v4, v5}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; .line 407 iget-object v4, v3, Lokhttp3/internal/cache/DiskLruCache$Entry;->key:Ljava/lang/String; invoke-interface {v0, v4}, Lokio/BufferedSink;->writeUtf8(Ljava/lang/String;)Lokio/BufferedSink; .line 408 invoke-virtual {v3, v0}, Lokhttp3/internal/cache/DiskLruCache$Entry;->writeLengths(Lokio/BufferedSink;)V .line 409 invoke-interface {v0, v2}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_1 goto :goto_1 :cond_2 const/4 v1, 0x0 .line 412 :try_start_2 invoke-static {v1, v0}, Lokhttp3/internal/cache/DiskLruCache;->$closeResource(Ljava/lang/Throwable;Ljava/lang/AutoCloseable;)V iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFile:Ljava/io/File; .line 414 invoke-interface {v0, v1}, Lokhttp3/internal/io/FileSystem;->exists(Ljava/io/File;)Z move-result v0 if-eqz v0, :cond_3 iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFile:Ljava/io/File; iget-object v2, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFileBackup:Ljava/io/File; .line 415 invoke-interface {v0, v1, v2}, Lokhttp3/internal/io/FileSystem;->rename(Ljava/io/File;Ljava/io/File;)V :cond_3 iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFileTmp:Ljava/io/File; iget-object v2, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFile:Ljava/io/File; .line 417 invoke-interface {v0, v1, v2}, Lokhttp3/internal/io/FileSystem;->rename(Ljava/io/File;Ljava/io/File;)V iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->journalFileBackup:Ljava/io/File; .line 418 invoke-interface {v0, v1}, Lokhttp3/internal/io/FileSystem;->delete(Ljava/io/File;)V .line 420 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->newJournalWriter()Lokio/BufferedSink; move-result-object v0 iput-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; const/4 v0, 0x0 iput-boolean v0, p0, Lokhttp3/internal/cache/DiskLruCache;->hasJournalErrors:Z iput-boolean v0, p0, Lokhttp3/internal/cache/DiskLruCache;->mostRecentRebuildFailed:Z :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 .line 423 monitor-exit p0 return-void .line 393 :goto_2 :try_start_3 throw v1 :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_2 :catchall_2 move-exception v2 if-eqz v0, :cond_4 .line 412 :try_start_4 invoke-static {v1, v0}, Lokhttp3/internal/cache/DiskLruCache;->$closeResource(Ljava/lang/Throwable;Ljava/lang/AutoCloseable;)V :cond_4 throw v2 :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_0 :goto_3 monitor-exit p0 throw v0 .end method .method public declared-synchronized remove(Ljava/lang/String;)Z .locals 5 monitor-enter p0 .line 605 :try_start_0 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->initialize()V .line 607 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->checkNotClosed()V .line 608 invoke-virtual {p0, p1}, Lokhttp3/internal/cache/DiskLruCache;->validateKey(Ljava/lang/String;)V iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; .line 609 invoke-virtual {v0, p1}, Ljava/util/LinkedHashMap;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object p1 check-cast p1, Lokhttp3/internal/cache/DiskLruCache$Entry; :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 const/4 v0, 0x0 if-nez p1, :cond_0 .line 610 monitor-exit p0 return v0 .line 611 :cond_0 :try_start_1 invoke-virtual {p0, p1}, Lokhttp3/internal/cache/DiskLruCache;->removeEntry(Lokhttp3/internal/cache/DiskLruCache$Entry;)Z move-result p1 if-eqz p1, :cond_1 iget-wide v1, p0, Lokhttp3/internal/cache/DiskLruCache;->size:J iget-wide v3, p0, Lokhttp3/internal/cache/DiskLruCache;->maxSize:J cmp-long v1, v1, v3 if-gtz v1, :cond_1 iput-boolean v0, p0, Lokhttp3/internal/cache/DiskLruCache;->mostRecentTrimFailed:Z :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 goto :goto_0 :catchall_0 move-exception p1 goto :goto_1 .line 613 :cond_1 :goto_0 monitor-exit p0 return p1 :goto_1 monitor-exit p0 throw p1 .end method .method public removeEntry(Lokhttp3/internal/cache/DiskLruCache$Entry;)Z .locals 6 .line 617 iget-object v0, p1, Lokhttp3/internal/cache/DiskLruCache$Entry;->currentEditor:Lokhttp3/internal/cache/DiskLruCache$Editor; if-eqz v0, :cond_0 .line 618 invoke-virtual {v0}, Lokhttp3/internal/cache/DiskLruCache$Editor;->detach()V :cond_0 const/4 v0, 0x0 :goto_0 iget v1, p0, Lokhttp3/internal/cache/DiskLruCache;->valueCount:I if-ge v0, v1, :cond_1 iget-object v1, p0, Lokhttp3/internal/cache/DiskLruCache;->fileSystem:Lokhttp3/internal/io/FileSystem; .line 622 iget-object v2, p1, Lokhttp3/internal/cache/DiskLruCache$Entry;->cleanFiles:[Ljava/io/File; aget-object v2, v2, v0 invoke-interface {v1, v2}, Lokhttp3/internal/io/FileSystem;->delete(Ljava/io/File;)V iget-wide v1, p0, Lokhttp3/internal/cache/DiskLruCache;->size:J .line 623 iget-object v3, p1, Lokhttp3/internal/cache/DiskLruCache$Entry;->lengths:[J aget-wide v4, v3, v0 sub-long/2addr v1, v4 iput-wide v1, p0, Lokhttp3/internal/cache/DiskLruCache;->size:J const-wide/16 v1, 0x0 .line 624 aput-wide v1, v3, v0 add-int/lit8 v0, v0, 0x1 goto :goto_0 :cond_1 iget v0, p0, Lokhttp3/internal/cache/DiskLruCache;->redundantOpCount:I const/4 v1, 0x1 add-int/2addr v0, v1 iput v0, p0, Lokhttp3/internal/cache/DiskLruCache;->redundantOpCount:I iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->journalWriter:Lokio/BufferedSink; const-string v2, "REMOVE" .line 628 invoke-interface {v0, v2}, Lokio/BufferedSink;->writeUtf8(Ljava/lang/String;)Lokio/BufferedSink; move-result-object v0 const/16 v2, 0x20 invoke-interface {v0, v2}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; move-result-object v0 iget-object v2, p1, Lokhttp3/internal/cache/DiskLruCache$Entry;->key:Ljava/lang/String; invoke-interface {v0, v2}, Lokio/BufferedSink;->writeUtf8(Ljava/lang/String;)Lokio/BufferedSink; move-result-object v0 const/16 v2, 0xa invoke-interface {v0, v2}, Lokio/BufferedSink;->writeByte(I)Lokio/BufferedSink; iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; .line 629 iget-object p1, p1, Lokhttp3/internal/cache/DiskLruCache$Entry;->key:Ljava/lang/String; invoke-virtual {v0, p1}, Ljava/util/AbstractMap;->remove(Ljava/lang/Object;)Ljava/lang/Object; .line 631 invoke-virtual {p0}, Lokhttp3/internal/cache/DiskLruCache;->journalRebuildRequired()Z move-result p1 if-eqz p1, :cond_2 iget-object p1, p0, Lokhttp3/internal/cache/DiskLruCache;->executor:Ljava/util/concurrent/Executor; iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->cleanupRunnable:Ljava/lang/Runnable; .line 632 invoke-interface {p1, v0}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V :cond_2 return v1 .end method .method public trimToSize()V .locals 4 :goto_0 iget-wide v0, p0, Lokhttp3/internal/cache/DiskLruCache;->size:J iget-wide v2, p0, Lokhttp3/internal/cache/DiskLruCache;->maxSize:J cmp-long v0, v0, v2 if-lez v0, :cond_0 iget-object v0, p0, Lokhttp3/internal/cache/DiskLruCache;->lruEntries:Ljava/util/LinkedHashMap; .line 678 invoke-virtual {v0}, Ljava/util/LinkedHashMap;->values()Ljava/util/Collection; move-result-object v0 invoke-interface {v0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator; move-result-object v0 invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v0 check-cast v0, Lokhttp3/internal/cache/DiskLruCache$Entry; .line 679 invoke-virtual {p0, v0}, Lokhttp3/internal/cache/DiskLruCache;->removeEntry(Lokhttp3/internal/cache/DiskLruCache$Entry;)Z goto :goto_0 :cond_0 const/4 v0, 0x0 iput-boolean v0, p0, Lokhttp3/internal/cache/DiskLruCache;->mostRecentTrimFailed:Z return-void .end method .method public final validateKey(Ljava/lang/String;)V .locals 3 sget-object v0, Lokhttp3/internal/cache/DiskLruCache;->LEGAL_KEY_PATTERN:Ljava/util/regex/Pattern; .line 707 invoke-virtual {v0, p1}, Ljava/util/regex/Pattern;->matcher(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher; move-result-object v0 .line 708 invoke-virtual {v0}, Ljava/util/regex/Matcher;->matches()Z move-result v0 if-eqz v0, :cond_0 return-void .line 709 :cond_0 new-instance v0, Ljava/lang/IllegalArgumentException; new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "keys must match regex [a-z0-9_-]{1,120}: \"" invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string p1, "\"" invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 invoke-direct {v0, p1}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V throw v0 .end method