TimedSemaphore.smali
.class public Lorg/apache/commons/lang3/concurrent/TimedSemaphore;
.super Ljava/lang/Object;
.source "TimedSemaphore.java"
# static fields
.field public static final NO_LIMIT:I = 0x0
.field private static final THREAD_POOL_SIZE:I = 0x1
# instance fields
.field private acquireCount:I
.field private final executorService:Ljava/util/concurrent/ScheduledExecutorService;
.field private lastCallsPerPeriod:I
.field private limit:I
.field private final ownExecutor:Z
.field private final period:J
.field private periodCount:J
.field private shutdown:Z
.field private task:Ljava/util/concurrent/ScheduledFuture;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/ScheduledFuture<",
"*>;"
}
.end annotation
.end field
.field private totalAcquireCount:J
.field private final unit:Ljava/util/concurrent/TimeUnit;
# direct methods
.method public constructor <init>(JLjava/util/concurrent/TimeUnit;I)V
.registers 11
const/4 v1, 0x0
move-object v0, p0
move-wide v2, p1
move-object v4, p3
move v5, p4
.line 189
invoke-direct/range {v0 .. v5}, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;-><init>(Ljava/util/concurrent/ScheduledExecutorService;JLjava/util/concurrent/TimeUnit;I)V
return-void
.end method
.method public constructor <init>(Ljava/util/concurrent/ScheduledExecutorService;JLjava/util/concurrent/TimeUnit;I)V
.registers 13
.line 205
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const-wide/16 v0, 0x1
const-wide v2, 0x7fffffffffffffffL
const-string v6, "Time period must be greater than 0!"
move-wide v4, p2
.line 206
invoke-static/range {v0 .. v6}, Lorg/apache/commons/lang3/Validate;->inclusiveBetween(JJJLjava/lang/String;)V
.line 208
iput-wide p2, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->period:J
.line 209
iput-object p4, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->unit:Ljava/util/concurrent/TimeUnit;
const/4 p2, 0x0
if-eqz p1, :cond_1c
.line 212
iput-object p1, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->executorService:Ljava/util/concurrent/ScheduledExecutorService;
.line 213
iput-boolean p2, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->ownExecutor:Z
goto :goto_2c
.line 215
:cond_1c
new-instance p1, Ljava/util/concurrent/ScheduledThreadPoolExecutor;
const/4 p3, 0x1
invoke-direct {p1, p3}, Ljava/util/concurrent/ScheduledThreadPoolExecutor;-><init>(I)V
.line 217
invoke-virtual {p1, p2}, Ljava/util/concurrent/ScheduledThreadPoolExecutor;->setContinueExistingPeriodicTasksAfterShutdownPolicy(Z)V
.line 218
invoke-virtual {p1, p2}, Ljava/util/concurrent/ScheduledThreadPoolExecutor;->setExecuteExistingDelayedTasksAfterShutdownPolicy(Z)V
.line 219
iput-object p1, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->executorService:Ljava/util/concurrent/ScheduledExecutorService;
.line 220
iput-boolean p3, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->ownExecutor:Z
.line 223
:goto_2c
invoke-virtual {p0, p5}, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->setLimit(I)V
return-void
.end method
# virtual methods
.method public declared-synchronized acquire()V
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/InterruptedException;
}
.end annotation
monitor-enter p0
.line 295
:try_start_1
invoke-virtual {p0}, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->isShutdown()Z
move-result v0
if-nez v0, :cond_33
.line 299
iget-object v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->task:Ljava/util/concurrent/ScheduledFuture;
if-nez v0, :cond_11
.line 300
invoke-virtual {p0}, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->startTimer()Ljava/util/concurrent/ScheduledFuture;
move-result-object v0
iput-object v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->task:Ljava/util/concurrent/ScheduledFuture;
.line 305
:cond_11
invoke-virtual {p0}, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->getLimit()I
move-result v0
const/4 v1, 0x1
if-lez v0, :cond_23
iget v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->acquireCount:I
invoke-virtual {p0}, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->getLimit()I
move-result v2
if-ge v0, v2, :cond_21
goto :goto_23
:cond_21
const/4 v0, 0x0
goto :goto_24
:cond_23
:goto_23
const/4 v0, 0x1
:goto_24
if-nez v0, :cond_2a
.line 307
invoke-virtual {p0}, Ljava/lang/Object;->wait()V
goto :goto_2f
.line 309
:cond_2a
iget v2, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->acquireCount:I
add-int/2addr v2, v1
iput v2, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->acquireCount:I
:try_end_2f
.catchall {:try_start_1 .. :try_end_2f} :catchall_3b
:goto_2f
if-eqz v0, :cond_11
.line 312
monitor-exit p0
return-void
.line 296
:cond_33
:try_start_33
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "TimedSemaphore is shut down!"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_3b
.catchall {:try_start_33 .. :try_end_3b} :catchall_3b
:catchall_3b
move-exception v0
monitor-exit p0
throw v0
.end method
.method declared-synchronized endOfPeriod()V
.registers 5
monitor-enter p0
.line 418
:try_start_1
iget v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->acquireCount:I
iput v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->lastCallsPerPeriod:I
.line 419
iget-wide v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->totalAcquireCount:J
iget v2, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->acquireCount:I
int-to-long v2, v2
add-long/2addr v0, v2
iput-wide v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->totalAcquireCount:J
.line 420
iget-wide v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->periodCount:J
const-wide/16 v2, 0x1
add-long/2addr v0, v2
iput-wide v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->periodCount:J
const/4 v0, 0x0
.line 421
iput v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->acquireCount:I
.line 422
invoke-virtual {p0}, Ljava/lang/Object;->notifyAll()V
:try_end_1a
.catchall {:try_start_1 .. :try_end_1a} :catchall_1c
.line 423
monitor-exit p0
return-void
:catchall_1c
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized getAcquireCount()I
.registers 2
monitor-enter p0
.line 335
:try_start_1
iget v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->acquireCount:I
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_5
monitor-exit p0
return v0
:catchall_5
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized getAvailablePermits()I
.registers 3
monitor-enter p0
.line 350
:try_start_1
invoke-virtual {p0}, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->getLimit()I
move-result v0
invoke-virtual {p0}, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->getAcquireCount()I
move-result v1
:try_end_9
.catchall {:try_start_1 .. :try_end_9} :catchall_c
sub-int/2addr v0, v1
monitor-exit p0
return v0
:catchall_c
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized getAverageCallsPerPeriod()D
.registers 6
monitor-enter p0
.line 363
:try_start_1
iget-wide v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->periodCount:J
const-wide/16 v2, 0x0
cmp-long v4, v0, v2
if-nez v4, :cond_c
const-wide/16 v0, 0x0
goto :goto_13
:cond_c
iget-wide v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->totalAcquireCount:J
long-to-double v0, v0
iget-wide v2, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->periodCount:J
:try_end_11
.catchall {:try_start_1 .. :try_end_11} :catchall_15
long-to-double v2, v2
div-double/2addr v0, v2
:goto_13
monitor-exit p0
return-wide v0
:catchall_15
move-exception v0
monitor-exit p0
throw v0
.end method
.method protected getExecutorService()Ljava/util/concurrent/ScheduledExecutorService;
.registers 2
.line 393
iget-object v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->executorService:Ljava/util/concurrent/ScheduledExecutorService;
return-object v0
.end method
.method public declared-synchronized getLastAcquiresPerPeriod()I
.registers 2
monitor-enter p0
.line 325
:try_start_1
iget v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->lastCallsPerPeriod:I
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_5
monitor-exit p0
return v0
:catchall_5
move-exception v0
monitor-exit p0
throw v0
.end method
.method public final declared-synchronized getLimit()I
.registers 2
monitor-enter p0
.line 234
:try_start_1
iget v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->limit:I
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_5
monitor-exit p0
return v0
:catchall_5
move-exception v0
monitor-exit p0
throw v0
.end method
.method public getPeriod()J
.registers 3
.line 375
iget-wide v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->period:J
return-wide v0
.end method
.method public getUnit()Ljava/util/concurrent/TimeUnit;
.registers 2
.line 384
iget-object v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->unit:Ljava/util/concurrent/TimeUnit;
return-object v0
.end method
.method public declared-synchronized isShutdown()Z
.registers 2
monitor-enter p0
.line 280
:try_start_1
iget-boolean v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->shutdown:Z
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_5
monitor-exit p0
return v0
:catchall_5
move-exception v0
monitor-exit p0
throw v0
.end method
.method public final declared-synchronized setLimit(I)V
.registers 2
monitor-enter p0
.line 248
:try_start_1
iput p1, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->limit:I
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_5
.line 249
monitor-exit p0
return-void
:catchall_5
move-exception p1
monitor-exit p0
throw p1
.end method
.method public declared-synchronized shutdown()V
.registers 3
monitor-enter p0
.line 257
:try_start_1
iget-boolean v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->shutdown:Z
if-nez v0, :cond_1d
.line 259
iget-boolean v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->ownExecutor:Z
if-eqz v0, :cond_10
.line 262
invoke-virtual {p0}, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->getExecutorService()Ljava/util/concurrent/ScheduledExecutorService;
move-result-object v0
invoke-interface {v0}, Ljava/util/concurrent/ScheduledExecutorService;->shutdownNow()Ljava/util/List;
.line 264
:cond_10
iget-object v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->task:Ljava/util/concurrent/ScheduledFuture;
if-eqz v0, :cond_1a
.line 265
iget-object v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->task:Ljava/util/concurrent/ScheduledFuture;
const/4 v1, 0x0
invoke-interface {v0, v1}, Ljava/util/concurrent/ScheduledFuture;->cancel(Z)Z
:cond_1a
const/4 v0, 0x1
.line 268
iput-boolean v0, p0, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->shutdown:Z
:try_end_1d
.catchall {:try_start_1 .. :try_end_1d} :catchall_1f
.line 270
:cond_1d
monitor-exit p0
return-void
:catchall_1f
move-exception v0
monitor-exit p0
throw v0
.end method
.method protected startTimer()Ljava/util/concurrent/ScheduledFuture;
.registers 8
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/concurrent/ScheduledFuture<",
"*>;"
}
.end annotation
.line 404
invoke-virtual {p0}, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->getExecutorService()Ljava/util/concurrent/ScheduledExecutorService;
move-result-object v0
new-instance v1, Lorg/apache/commons/lang3/concurrent/TimedSemaphore$1;
invoke-direct {v1, p0}, Lorg/apache/commons/lang3/concurrent/TimedSemaphore$1;-><init>(Lorg/apache/commons/lang3/concurrent/TimedSemaphore;)V
invoke-virtual {p0}, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->getPeriod()J
move-result-wide v2
invoke-virtual {p0}, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->getPeriod()J
move-result-wide v4
invoke-virtual {p0}, Lorg/apache/commons/lang3/concurrent/TimedSemaphore;->getUnit()Ljava/util/concurrent/TimeUnit;
move-result-object v6
invoke-interface/range {v0 .. v6}, Ljava/util/concurrent/ScheduledExecutorService;->scheduleAtFixedRate(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
move-result-object v0
return-object v0
.end method