Locker.smali
.class Lcom/bytedance/boost_multidex/Locker;
.super Ljava/lang/Object;
.source ""
# instance fields
.field private cacheLock:Ljava/nio/channels/FileLock;
.field private lockChannel:Ljava/nio/channels/FileChannel;
.field private lockFile:Ljava/io/File;
.field private lockRaf:Ljava/io/RandomAccessFile;
# direct methods
.method constructor <init>(Ljava/io/File;)V
.registers 2
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Lcom/bytedance/boost_multidex/Locker;->lockFile:Ljava/io/File;
return-void
.end method
# virtual methods
.method close()V
.registers 4
iget-object v0, p0, Lcom/bytedance/boost_multidex/Locker;->cacheLock:Ljava/nio/channels/FileLock;
if-eqz v0, :cond_7
:try_start_4
invoke-virtual {v0}, Ljava/nio/channels/FileLock;->release()V
:try_end_7
.catch Ljava/io/IOException; {:try_start_4 .. :try_end_7} :catch_7
:catch_7
:cond_7
invoke-static {}, Lcom/bytedance/boost_multidex/Monitor;->get()Lcom/bytedance/boost_multidex/Monitor;
move-result-object v0
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Released lock "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v2, p0, Lcom/bytedance/boost_multidex/Locker;->lockFile:Ljava/io/File;
invoke-virtual {v2}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Lcom/bytedance/boost_multidex/Monitor;->logInfo(Ljava/lang/String;)V
iget-object v0, p0, Lcom/bytedance/boost_multidex/Locker;->lockChannel:Ljava/nio/channels/FileChannel;
invoke-static {v0}, Lcom/bytedance/boost_multidex/Utility;->closeQuietly(Ljava/io/Closeable;)V
iget-object v0, p0, Lcom/bytedance/boost_multidex/Locker;->lockRaf:Ljava/io/RandomAccessFile;
invoke-static {v0}, Lcom/bytedance/boost_multidex/Utility;->closeQuietly(Ljava/io/Closeable;)V
return-void
.end method
.method lock()V
.registers 4
new-instance v0, Ljava/io/RandomAccessFile;
iget-object v1, p0, Lcom/bytedance/boost_multidex/Locker;->lockFile:Ljava/io/File;
const-string v2, "rw"
invoke-direct {v0, v1, v2}, Ljava/io/RandomAccessFile;-><init>(Ljava/io/File;Ljava/lang/String;)V
iput-object v0, p0, Lcom/bytedance/boost_multidex/Locker;->lockRaf:Ljava/io/RandomAccessFile;
:try_start_b
iget-object v0, p0, Lcom/bytedance/boost_multidex/Locker;->lockRaf:Ljava/io/RandomAccessFile;
invoke-virtual {v0}, Ljava/io/RandomAccessFile;->getChannel()Ljava/nio/channels/FileChannel;
move-result-object v0
iput-object v0, p0, Lcom/bytedance/boost_multidex/Locker;->lockChannel:Ljava/nio/channels/FileChannel;
:try_end_13
.catch Ljava/io/IOException; {:try_start_b .. :try_end_13} :catch_5f
:try_start_13
invoke-static {}, Lcom/bytedance/boost_multidex/Monitor;->get()Lcom/bytedance/boost_multidex/Monitor;
move-result-object v0
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Blocking on lock "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v2, p0, Lcom/bytedance/boost_multidex/Locker;->lockFile:Ljava/io/File;
invoke-virtual {v2}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Lcom/bytedance/boost_multidex/Monitor;->logInfo(Ljava/lang/String;)V
iget-object v0, p0, Lcom/bytedance/boost_multidex/Locker;->lockChannel:Ljava/nio/channels/FileChannel;
invoke-virtual {v0}, Ljava/nio/channels/FileChannel;->lock()Ljava/nio/channels/FileLock;
move-result-object v0
iput-object v0, p0, Lcom/bytedance/boost_multidex/Locker;->cacheLock:Ljava/nio/channels/FileLock;
:try_end_39
.catch Ljava/io/IOException; {:try_start_13 .. :try_end_39} :catch_58
:try_start_39
invoke-static {}, Lcom/bytedance/boost_multidex/Monitor;->get()Lcom/bytedance/boost_multidex/Monitor;
move-result-object v0
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Acquired on lock "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v2, p0, Lcom/bytedance/boost_multidex/Locker;->lockFile:Ljava/io/File;
invoke-virtual {v2}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Lcom/bytedance/boost_multidex/Monitor;->logInfo(Ljava/lang/String;)V
return-void
:catch_58
move-exception v0
iget-object v1, p0, Lcom/bytedance/boost_multidex/Locker;->lockChannel:Ljava/nio/channels/FileChannel;
invoke-static {v1}, Lcom/bytedance/boost_multidex/Utility;->closeQuietly(Ljava/io/Closeable;)V
throw v0
:try_end_5f
.catch Ljava/io/IOException; {:try_start_39 .. :try_end_5f} :catch_5f
:catch_5f
move-exception v0
iget-object v1, p0, Lcom/bytedance/boost_multidex/Locker;->lockRaf:Ljava/io/RandomAccessFile;
invoke-static {v1}, Lcom/bytedance/boost_multidex/Utility;->closeQuietly(Ljava/io/Closeable;)V
throw v0
.end method
.method test()Z
.registers 6
const-string v0, "Acquired on lock "
new-instance v1, Ljava/io/RandomAccessFile;
iget-object v2, p0, Lcom/bytedance/boost_multidex/Locker;->lockFile:Ljava/io/File;
const-string v3, "rw"
invoke-direct {v1, v2, v3}, Ljava/io/RandomAccessFile;-><init>(Ljava/io/File;Ljava/lang/String;)V
iput-object v1, p0, Lcom/bytedance/boost_multidex/Locker;->lockRaf:Ljava/io/RandomAccessFile;
iget-object v1, p0, Lcom/bytedance/boost_multidex/Locker;->lockRaf:Ljava/io/RandomAccessFile;
invoke-virtual {v1}, Ljava/io/RandomAccessFile;->getChannel()Ljava/nio/channels/FileChannel;
move-result-object v1
iput-object v1, p0, Lcom/bytedance/boost_multidex/Locker;->lockChannel:Ljava/nio/channels/FileChannel;
const/4 v1, 0x0
:try_start_16
invoke-static {}, Lcom/bytedance/boost_multidex/Monitor;->get()Lcom/bytedance/boost_multidex/Monitor;
move-result-object v2
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Blocking on lock "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v4, p0, Lcom/bytedance/boost_multidex/Locker;->lockFile:Ljava/io/File;
invoke-virtual {v4}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v4
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
invoke-virtual {v2, v3}, Lcom/bytedance/boost_multidex/Monitor;->logInfo(Ljava/lang/String;)V
iget-object v2, p0, Lcom/bytedance/boost_multidex/Locker;->lockChannel:Ljava/nio/channels/FileChannel;
invoke-virtual {v2}, Ljava/nio/channels/FileChannel;->tryLock()Ljava/nio/channels/FileLock;
move-result-object v2
iput-object v2, p0, Lcom/bytedance/boost_multidex/Locker;->cacheLock:Ljava/nio/channels/FileLock;
iget-object v2, p0, Lcom/bytedance/boost_multidex/Locker;->cacheLock:Ljava/nio/channels/FileLock;
:try_end_3e
.catch Ljava/io/IOException; {:try_start_16 .. :try_end_3e} :catch_60
.catchall {:try_start_16 .. :try_end_3e} :catchall_5e
if-eqz v2, :cond_41
const/4 v1, 0x1
:cond_41
invoke-static {}, Lcom/bytedance/boost_multidex/Monitor;->get()Lcom/bytedance/boost_multidex/Monitor;
move-result-object v2
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
:goto_4a
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v0, p0, Lcom/bytedance/boost_multidex/Locker;->lockFile:Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v0
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v2, v0}, Lcom/bytedance/boost_multidex/Monitor;->logInfo(Ljava/lang/String;)V
return v1
:catchall_5e
move-exception v1
goto :goto_88
:catch_60
:try_start_60
invoke-static {}, Lcom/bytedance/boost_multidex/Monitor;->get()Lcom/bytedance/boost_multidex/Monitor;
move-result-object v2
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Aborting on lock "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v4, p0, Lcom/bytedance/boost_multidex/Locker;->lockFile:Ljava/io/File;
invoke-virtual {v4}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v4
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
invoke-virtual {v2, v3}, Lcom/bytedance/boost_multidex/Monitor;->logInfo(Ljava/lang/String;)V
:try_end_7e
.catchall {:try_start_60 .. :try_end_7e} :catchall_5e
invoke-static {}, Lcom/bytedance/boost_multidex/Monitor;->get()Lcom/bytedance/boost_multidex/Monitor;
move-result-object v2
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
goto :goto_4a
:goto_88
invoke-static {}, Lcom/bytedance/boost_multidex/Monitor;->get()Lcom/bytedance/boost_multidex/Monitor;
move-result-object v2
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v0, p0, Lcom/bytedance/boost_multidex/Locker;->lockFile:Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v0
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v2, v0}, Lcom/bytedance/boost_multidex/Monitor;->logInfo(Ljava/lang/String;)V
goto :goto_a6
:goto_a5
throw v1
:goto_a6
goto :goto_a5
.end method