Dispatcher.smali
.class Lcom/squareup/picasso/Dispatcher;
.super Ljava/lang/Object;
.source "Dispatcher.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/squareup/picasso/Dispatcher$NetworkBroadcastReceiver;,
Lcom/squareup/picasso/Dispatcher$DispatcherThread;,
Lcom/squareup/picasso/Dispatcher$DispatcherHandler;
}
.end annotation
# static fields
.field static final AIRPLANE_MODE_CHANGE:I = 0xa
.field private static final AIRPLANE_MODE_OFF:I = 0x0
.field private static final AIRPLANE_MODE_ON:I = 0x1
.field private static final BATCH_DELAY:I = 0xc8
.field private static final DISPATCHER_THREAD_NAME:Ljava/lang/String; = "Dispatcher"
.field static final HUNTER_BATCH_COMPLETE:I = 0x8
.field static final HUNTER_COMPLETE:I = 0x4
.field static final HUNTER_DECODE_FAILED:I = 0x6
.field static final HUNTER_DELAY_NEXT_BATCH:I = 0x7
.field static final HUNTER_RETRY:I = 0x5
.field static final NETWORK_STATE_CHANGE:I = 0x9
.field static final REQUEST_BATCH_RESUME:I = 0xd
.field static final REQUEST_CANCEL:I = 0x2
.field static final REQUEST_GCED:I = 0x3
.field static final REQUEST_SUBMIT:I = 0x1
.field private static final RETRY_DELAY:I = 0x1f4
.field static final TAG_PAUSE:I = 0xb
.field static final TAG_RESUME:I = 0xc
# instance fields
.field airplaneMode:Z
.field final batch:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Lcom/squareup/picasso/BitmapHunter;",
">;"
}
.end annotation
.end field
.field final cache:Lcom/squareup/picasso/Cache;
.field final context:Landroid/content/Context;
.field final dispatcherThread:Lcom/squareup/picasso/Dispatcher$DispatcherThread;
.field final downloader:Lcom/squareup/picasso/Downloader;
.field final failedActions:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/Object;",
"Lcom/squareup/picasso/Action;",
">;"
}
.end annotation
.end field
.field final handler:Landroid/os/Handler;
.field final hunterMap:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/String;",
"Lcom/squareup/picasso/BitmapHunter;",
">;"
}
.end annotation
.end field
.field final mainThreadHandler:Landroid/os/Handler;
.field final pausedActions:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/Object;",
"Lcom/squareup/picasso/Action;",
">;"
}
.end annotation
.end field
.field final pausedTags:Ljava/util/Set;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Set<",
"Ljava/lang/Object;",
">;"
}
.end annotation
.end field
.field final receiver:Lcom/squareup/picasso/Dispatcher$NetworkBroadcastReceiver;
.field final scansNetworkChanges:Z
.field final service:Ljava/util/concurrent/ExecutorService;
.field final stats:Lcom/squareup/picasso/Stats;
# direct methods
.method constructor <init>(Landroid/content/Context;Ljava/util/concurrent/ExecutorService;Landroid/os/Handler;Lcom/squareup/picasso/Downloader;Lcom/squareup/picasso/Cache;Lcom/squareup/picasso/Stats;)V
.registers 8
.line 100
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 101
new-instance v0, Lcom/squareup/picasso/Dispatcher$DispatcherThread;
invoke-direct {v0}, Lcom/squareup/picasso/Dispatcher$DispatcherThread;-><init>()V
iput-object v0, p0, Lcom/squareup/picasso/Dispatcher;->dispatcherThread:Lcom/squareup/picasso/Dispatcher$DispatcherThread;
.line 102
invoke-virtual {v0}, Lcom/squareup/picasso/Dispatcher$DispatcherThread;->start()V
.line 103
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->dispatcherThread:Lcom/squareup/picasso/Dispatcher$DispatcherThread;
invoke-virtual {v0}, Lcom/squareup/picasso/Dispatcher$DispatcherThread;->getLooper()Landroid/os/Looper;
move-result-object v0
invoke-static {v0}, Lcom/squareup/picasso/Utils;->flushStackLocalLeaks(Landroid/os/Looper;)V
.line 104
iput-object p1, p0, Lcom/squareup/picasso/Dispatcher;->context:Landroid/content/Context;
.line 105
iput-object p2, p0, Lcom/squareup/picasso/Dispatcher;->service:Ljava/util/concurrent/ExecutorService;
.line 106
new-instance p2, Ljava/util/LinkedHashMap;
invoke-direct {p2}, Ljava/util/LinkedHashMap;-><init>()V
iput-object p2, p0, Lcom/squareup/picasso/Dispatcher;->hunterMap:Ljava/util/Map;
.line 107
new-instance p2, Ljava/util/WeakHashMap;
invoke-direct {p2}, Ljava/util/WeakHashMap;-><init>()V
iput-object p2, p0, Lcom/squareup/picasso/Dispatcher;->failedActions:Ljava/util/Map;
.line 108
new-instance p2, Ljava/util/WeakHashMap;
invoke-direct {p2}, Ljava/util/WeakHashMap;-><init>()V
iput-object p2, p0, Lcom/squareup/picasso/Dispatcher;->pausedActions:Ljava/util/Map;
.line 109
new-instance p2, Ljava/util/HashSet;
invoke-direct {p2}, Ljava/util/HashSet;-><init>()V
iput-object p2, p0, Lcom/squareup/picasso/Dispatcher;->pausedTags:Ljava/util/Set;
.line 110
new-instance p2, Lcom/squareup/picasso/Dispatcher$DispatcherHandler;
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->dispatcherThread:Lcom/squareup/picasso/Dispatcher$DispatcherThread;
invoke-virtual {v0}, Lcom/squareup/picasso/Dispatcher$DispatcherThread;->getLooper()Landroid/os/Looper;
move-result-object v0
invoke-direct {p2, v0, p0}, Lcom/squareup/picasso/Dispatcher$DispatcherHandler;-><init>(Landroid/os/Looper;Lcom/squareup/picasso/Dispatcher;)V
iput-object p2, p0, Lcom/squareup/picasso/Dispatcher;->handler:Landroid/os/Handler;
.line 111
iput-object p4, p0, Lcom/squareup/picasso/Dispatcher;->downloader:Lcom/squareup/picasso/Downloader;
.line 112
iput-object p3, p0, Lcom/squareup/picasso/Dispatcher;->mainThreadHandler:Landroid/os/Handler;
.line 113
iput-object p5, p0, Lcom/squareup/picasso/Dispatcher;->cache:Lcom/squareup/picasso/Cache;
.line 114
iput-object p6, p0, Lcom/squareup/picasso/Dispatcher;->stats:Lcom/squareup/picasso/Stats;
.line 115
new-instance p2, Ljava/util/ArrayList;
const/4 p3, 0x4
invoke-direct {p2, p3}, Ljava/util/ArrayList;-><init>(I)V
iput-object p2, p0, Lcom/squareup/picasso/Dispatcher;->batch:Ljava/util/List;
.line 116
iget-object p2, p0, Lcom/squareup/picasso/Dispatcher;->context:Landroid/content/Context;
invoke-static {p2}, Lcom/squareup/picasso/Utils;->isAirplaneModeOn(Landroid/content/Context;)Z
move-result p2
iput-boolean p2, p0, Lcom/squareup/picasso/Dispatcher;->airplaneMode:Z
const-string p2, "android.permission.ACCESS_NETWORK_STATE"
.line 117
invoke-static {p1, p2}, Lcom/squareup/picasso/Utils;->hasPermission(Landroid/content/Context;Ljava/lang/String;)Z
move-result p1
iput-boolean p1, p0, Lcom/squareup/picasso/Dispatcher;->scansNetworkChanges:Z
.line 118
new-instance p1, Lcom/squareup/picasso/Dispatcher$NetworkBroadcastReceiver;
invoke-direct {p1, p0}, Lcom/squareup/picasso/Dispatcher$NetworkBroadcastReceiver;-><init>(Lcom/squareup/picasso/Dispatcher;)V
iput-object p1, p0, Lcom/squareup/picasso/Dispatcher;->receiver:Lcom/squareup/picasso/Dispatcher$NetworkBroadcastReceiver;
.line 119
invoke-virtual {p1}, Lcom/squareup/picasso/Dispatcher$NetworkBroadcastReceiver;->register()V
return-void
.end method
.method private batch(Lcom/squareup/picasso/BitmapHunter;)V
.registers 5
.line 447
invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->isCancelled()Z
move-result v0
if-eqz v0, :cond_7
return-void
.line 450
:cond_7
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->batch:Ljava/util/List;
invoke-interface {v0, p1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 451
iget-object p1, p0, Lcom/squareup/picasso/Dispatcher;->handler:Landroid/os/Handler;
const/4 v0, 0x7
invoke-virtual {p1, v0}, Landroid/os/Handler;->hasMessages(I)Z
move-result p1
if-nez p1, :cond_1c
.line 452
iget-object p1, p0, Lcom/squareup/picasso/Dispatcher;->handler:Landroid/os/Handler;
const-wide/16 v1, 0xc8
invoke-virtual {p1, v0, v1, v2}, Landroid/os/Handler;->sendEmptyMessageDelayed(IJ)Z
:cond_1c
return-void
.end method
.method private flushFailedActions()V
.registers 6
.line 410
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->failedActions:Ljava/util/Map;
invoke-interface {v0}, Ljava/util/Map;->isEmpty()Z
move-result v0
if-nez v0, :cond_3d
.line 411
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->failedActions:Ljava/util/Map;
invoke-interface {v0}, Ljava/util/Map;->values()Ljava/util/Collection;
move-result-object v0
invoke-interface {v0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v0
.line 412
:goto_12
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_3d
.line 413
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/squareup/picasso/Action;
.line 414
invoke-interface {v0}, Ljava/util/Iterator;->remove()V
.line 415
invoke-virtual {v1}, Lcom/squareup/picasso/Action;->getPicasso()Lcom/squareup/picasso/Picasso;
move-result-object v2
iget-boolean v2, v2, Lcom/squareup/picasso/Picasso;->loggingEnabled:Z
if-eqz v2, :cond_38
.line 416
invoke-virtual {v1}, Lcom/squareup/picasso/Action;->getRequest()Lcom/squareup/picasso/Request;
move-result-object v2
invoke-virtual {v2}, Lcom/squareup/picasso/Request;->logId()Ljava/lang/String;
move-result-object v2
const-string v3, "Dispatcher"
const-string v4, "replaying"
invoke-static {v3, v4, v2}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
:cond_38
const/4 v2, 0x0
.line 418
invoke-virtual {p0, v1, v2}, Lcom/squareup/picasso/Dispatcher;->performSubmit(Lcom/squareup/picasso/Action;Z)V
goto :goto_12
:cond_3d
return-void
.end method
.method private logBatch(Ljava/util/List;)V
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List<",
"Lcom/squareup/picasso/BitmapHunter;",
">;)V"
}
.end annotation
if-eqz p1, :cond_4b
.line 457
invoke-interface {p1}, Ljava/util/List;->isEmpty()Z
move-result v0
if-eqz v0, :cond_9
goto :goto_4b
:cond_9
const/4 v0, 0x0
.line 458
invoke-interface {p1, v0}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/squareup/picasso/BitmapHunter;
.line 459
invoke-virtual {v0}, Lcom/squareup/picasso/BitmapHunter;->getPicasso()Lcom/squareup/picasso/Picasso;
move-result-object v0
.line 460
iget-boolean v0, v0, Lcom/squareup/picasso/Picasso;->loggingEnabled:Z
if-eqz v0, :cond_4b
.line 461
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
.line 462
invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object p1
:goto_21
invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_40
invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/squareup/picasso/BitmapHunter;
.line 463
invoke-virtual {v0}, Ljava/lang/StringBuilder;->length()I
move-result v2
if-lez v2, :cond_38
const-string v2, ", "
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 464
:cond_38
invoke-static {v1}, Lcom/squareup/picasso/Utils;->getLogIdsForHunter(Lcom/squareup/picasso/BitmapHunter;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
goto :goto_21
.line 466
:cond_40
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
const-string v0, "Dispatcher"
const-string v1, "delivered"
invoke-static {v0, v1, p1}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
:cond_4b
:goto_4b
return-void
.end method
.method private markForReplay(Lcom/squareup/picasso/Action;)V
.registers 4
.line 439
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getTarget()Ljava/lang/Object;
move-result-object v0
if-eqz v0, :cond_e
const/4 v1, 0x1
.line 441
iput-boolean v1, p1, Lcom/squareup/picasso/Action;->willReplay:Z
.line 442
iget-object v1, p0, Lcom/squareup/picasso/Dispatcher;->failedActions:Ljava/util/Map;
invoke-interface {v1, v0, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:cond_e
return-void
.end method
.method private markForReplay(Lcom/squareup/picasso/BitmapHunter;)V
.registers 5
.line 424
invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->getAction()Lcom/squareup/picasso/Action;
move-result-object v0
if-eqz v0, :cond_9
.line 426
invoke-direct {p0, v0}, Lcom/squareup/picasso/Dispatcher;->markForReplay(Lcom/squareup/picasso/Action;)V
.line 428
:cond_9
invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->getActions()Ljava/util/List;
move-result-object p1
if-eqz p1, :cond_22
const/4 v0, 0x0
.line 431
invoke-interface {p1}, Ljava/util/List;->size()I
move-result v1
:goto_14
if-ge v0, v1, :cond_22
.line 432
invoke-interface {p1, v0}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/squareup/picasso/Action;
.line 433
invoke-direct {p0, v2}, Lcom/squareup/picasso/Dispatcher;->markForReplay(Lcom/squareup/picasso/Action;)V
add-int/lit8 v0, v0, 0x1
goto :goto_14
:cond_22
return-void
.end method
# virtual methods
.method dispatchAirplaneModeChange(Z)V
.registers 5
.line 170
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->handler:Landroid/os/Handler;
const/4 v1, 0x0
const/16 v2, 0xa
invoke-virtual {v0, v2, p1, v1}, Landroid/os/Handler;->obtainMessage(III)Landroid/os/Message;
move-result-object p1
invoke-virtual {v0, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z
return-void
.end method
.method dispatchCancel(Lcom/squareup/picasso/Action;)V
.registers 4
.line 142
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->handler:Landroid/os/Handler;
const/4 v1, 0x2
invoke-virtual {v0, v1, p1}, Landroid/os/Handler;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object p1
invoke-virtual {v0, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z
return-void
.end method
.method dispatchComplete(Lcom/squareup/picasso/BitmapHunter;)V
.registers 4
.line 154
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->handler:Landroid/os/Handler;
const/4 v1, 0x4
invoke-virtual {v0, v1, p1}, Landroid/os/Handler;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object p1
invoke-virtual {v0, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z
return-void
.end method
.method dispatchFailed(Lcom/squareup/picasso/BitmapHunter;)V
.registers 4
.line 162
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->handler:Landroid/os/Handler;
const/4 v1, 0x6
invoke-virtual {v0, v1, p1}, Landroid/os/Handler;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object p1
invoke-virtual {v0, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z
return-void
.end method
.method dispatchNetworkStateChange(Landroid/net/NetworkInfo;)V
.registers 4
.line 166
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->handler:Landroid/os/Handler;
const/16 v1, 0x9
invoke-virtual {v0, v1, p1}, Landroid/os/Handler;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object p1
invoke-virtual {v0, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z
return-void
.end method
.method dispatchPauseTag(Ljava/lang/Object;)V
.registers 4
.line 146
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->handler:Landroid/os/Handler;
const/16 v1, 0xb
invoke-virtual {v0, v1, p1}, Landroid/os/Handler;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object p1
invoke-virtual {v0, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z
return-void
.end method
.method dispatchResumeTag(Ljava/lang/Object;)V
.registers 4
.line 150
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->handler:Landroid/os/Handler;
const/16 v1, 0xc
invoke-virtual {v0, v1, p1}, Landroid/os/Handler;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object p1
invoke-virtual {v0, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z
return-void
.end method
.method dispatchRetry(Lcom/squareup/picasso/BitmapHunter;)V
.registers 5
.line 158
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->handler:Landroid/os/Handler;
const/4 v1, 0x5
invoke-virtual {v0, v1, p1}, Landroid/os/Handler;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object p1
const-wide/16 v1, 0x1f4
invoke-virtual {v0, p1, v1, v2}, Landroid/os/Handler;->sendMessageDelayed(Landroid/os/Message;J)Z
return-void
.end method
.method dispatchSubmit(Lcom/squareup/picasso/Action;)V
.registers 4
.line 138
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->handler:Landroid/os/Handler;
const/4 v1, 0x1
invoke-virtual {v0, v1, p1}, Landroid/os/Handler;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object p1
invoke-virtual {v0, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z
return-void
.end method
.method performAirplaneModeChange(Z)V
.registers 2
.line 396
iput-boolean p1, p0, Lcom/squareup/picasso/Dispatcher;->airplaneMode:Z
return-void
.end method
.method performBatchComplete()V
.registers 4
.line 380
new-instance v0, Ljava/util/ArrayList;
iget-object v1, p0, Lcom/squareup/picasso/Dispatcher;->batch:Ljava/util/List;
invoke-direct {v0, v1}, Ljava/util/ArrayList;-><init>(Ljava/util/Collection;)V
.line 381
iget-object v1, p0, Lcom/squareup/picasso/Dispatcher;->batch:Ljava/util/List;
invoke-interface {v1}, Ljava/util/List;->clear()V
.line 382
iget-object v1, p0, Lcom/squareup/picasso/Dispatcher;->mainThreadHandler:Landroid/os/Handler;
const/16 v2, 0x8
invoke-virtual {v1, v2, v0}, Landroid/os/Handler;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object v2
invoke-virtual {v1, v2}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z
.line 383
invoke-direct {p0, v0}, Lcom/squareup/picasso/Dispatcher;->logBatch(Ljava/util/List;)V
return-void
.end method
.method performCancel(Lcom/squareup/picasso/Action;)V
.registers 6
.line 214
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getKey()Ljava/lang/String;
move-result-object v0
.line 215
iget-object v1, p0, Lcom/squareup/picasso/Dispatcher;->hunterMap:Ljava/util/Map;
invoke-interface {v1, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/squareup/picasso/BitmapHunter;
const-string v2, "canceled"
const-string v3, "Dispatcher"
if-eqz v1, :cond_33
.line 217
invoke-virtual {v1, p1}, Lcom/squareup/picasso/BitmapHunter;->detach(Lcom/squareup/picasso/Action;)V
.line 218
invoke-virtual {v1}, Lcom/squareup/picasso/BitmapHunter;->cancel()Z
move-result v1
if-eqz v1, :cond_33
.line 219
iget-object v1, p0, Lcom/squareup/picasso/Dispatcher;->hunterMap:Ljava/util/Map;
invoke-interface {v1, v0}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
.line 220
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getPicasso()Lcom/squareup/picasso/Picasso;
move-result-object v0
iget-boolean v0, v0, Lcom/squareup/picasso/Picasso;->loggingEnabled:Z
if-eqz v0, :cond_33
.line 221
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getRequest()Lcom/squareup/picasso/Request;
move-result-object v0
invoke-virtual {v0}, Lcom/squareup/picasso/Request;->logId()Ljava/lang/String;
move-result-object v0
invoke-static {v3, v2, v0}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.line 226
:cond_33
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->pausedTags:Ljava/util/Set;
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getTag()Ljava/lang/Object;
move-result-object v1
invoke-interface {v0, v1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_5d
.line 227
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->pausedActions:Ljava/util/Map;
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getTarget()Ljava/lang/Object;
move-result-object v1
invoke-interface {v0, v1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
.line 228
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getPicasso()Lcom/squareup/picasso/Picasso;
move-result-object v0
iget-boolean v0, v0, Lcom/squareup/picasso/Picasso;->loggingEnabled:Z
if-eqz v0, :cond_5d
.line 229
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getRequest()Lcom/squareup/picasso/Request;
move-result-object v0
invoke-virtual {v0}, Lcom/squareup/picasso/Request;->logId()Ljava/lang/String;
move-result-object v0
const-string v1, "because paused request got canceled"
invoke-static {v3, v2, v0, v1}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.line 234
:cond_5d
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->failedActions:Ljava/util/Map;
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getTarget()Ljava/lang/Object;
move-result-object p1
invoke-interface {v0, p1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
check-cast p1, Lcom/squareup/picasso/Action;
if-eqz p1, :cond_80
.line 235
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getPicasso()Lcom/squareup/picasso/Picasso;
move-result-object v0
iget-boolean v0, v0, Lcom/squareup/picasso/Picasso;->loggingEnabled:Z
if-eqz v0, :cond_80
.line 236
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getRequest()Lcom/squareup/picasso/Request;
move-result-object p1
invoke-virtual {p1}, Lcom/squareup/picasso/Request;->logId()Ljava/lang/String;
move-result-object p1
const-string v0, "from replaying"
invoke-static {v3, v2, p1, v0}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
:cond_80
return-void
.end method
.method performComplete(Lcom/squareup/picasso/BitmapHunter;)V
.registers 5
.line 369
invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->getMemoryPolicy()I
move-result v0
invoke-static {v0}, Lcom/squareup/picasso/MemoryPolicy;->shouldWriteToMemoryCache(I)Z
move-result v0
if-eqz v0, :cond_17
.line 370
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->cache:Lcom/squareup/picasso/Cache;
invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->getKey()Ljava/lang/String;
move-result-object v1
invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->getResult()Landroid/graphics/Bitmap;
move-result-object v2
invoke-interface {v0, v1, v2}, Lcom/squareup/picasso/Cache;->set(Ljava/lang/String;Landroid/graphics/Bitmap;)V
.line 372
:cond_17
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->hunterMap:Ljava/util/Map;
invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->getKey()Ljava/lang/String;
move-result-object v1
invoke-interface {v0, v1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
.line 373
invoke-direct {p0, p1}, Lcom/squareup/picasso/Dispatcher;->batch(Lcom/squareup/picasso/BitmapHunter;)V
.line 374
invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->getPicasso()Lcom/squareup/picasso/Picasso;
move-result-object v0
iget-boolean v0, v0, Lcom/squareup/picasso/Picasso;->loggingEnabled:Z
if-eqz v0, :cond_38
.line 375
invoke-static {p1}, Lcom/squareup/picasso/Utils;->getLogIdsForHunter(Lcom/squareup/picasso/BitmapHunter;)Ljava/lang/String;
move-result-object p1
const-string v0, "Dispatcher"
const-string v1, "batched"
const-string v2, "for completion"
invoke-static {v0, v1, p1, v2}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
:cond_38
return-void
.end method
.method performError(Lcom/squareup/picasso/BitmapHunter;Z)V
.registers 6
.line 387
invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->getPicasso()Lcom/squareup/picasso/Picasso;
move-result-object v0
iget-boolean v0, v0, Lcom/squareup/picasso/Picasso;->loggingEnabled:Z
if-eqz v0, :cond_2b
.line 388
invoke-static {p1}, Lcom/squareup/picasso/Utils;->getLogIdsForHunter(Lcom/squareup/picasso/BitmapHunter;)Ljava/lang/String;
move-result-object v0
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "for error"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
if-eqz p2, :cond_1b
const-string p2, " (will replay)"
goto :goto_1d
:cond_1b
const-string p2, ""
:goto_1d
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
const-string v1, "Dispatcher"
const-string v2, "batched"
invoke-static {v1, v2, v0, p2}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.line 391
:cond_2b
iget-object p2, p0, Lcom/squareup/picasso/Dispatcher;->hunterMap:Ljava/util/Map;
invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->getKey()Ljava/lang/String;
move-result-object v0
invoke-interface {p2, v0}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
.line 392
invoke-direct {p0, p1}, Lcom/squareup/picasso/Dispatcher;->batch(Lcom/squareup/picasso/BitmapHunter;)V
return-void
.end method
.method performNetworkStateChange(Landroid/net/NetworkInfo;)V
.registers 4
.line 400
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->service:Ljava/util/concurrent/ExecutorService;
instance-of v1, v0, Lcom/squareup/picasso/PicassoExecutorService;
if-eqz v1, :cond_b
.line 401
check-cast v0, Lcom/squareup/picasso/PicassoExecutorService;
invoke-virtual {v0, p1}, Lcom/squareup/picasso/PicassoExecutorService;->adjustThreadCount(Landroid/net/NetworkInfo;)V
:cond_b
if-eqz p1, :cond_16
.line 404
invoke-virtual {p1}, Landroid/net/NetworkInfo;->isConnected()Z
move-result p1
if-eqz p1, :cond_16
.line 405
invoke-direct {p0}, Lcom/squareup/picasso/Dispatcher;->flushFailedActions()V
:cond_16
return-void
.end method
.method performPauseTag(Ljava/lang/Object;)V
.registers 15
.line 242
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->pausedTags:Ljava/util/Set;
invoke-interface {v0, p1}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_9
return-void
.line 248
:cond_9
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->hunterMap:Ljava/util/Map;
invoke-interface {v0}, Ljava/util/Map;->values()Ljava/util/Collection;
move-result-object v0
invoke-interface {v0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v0
:cond_13
:goto_13
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_d9
.line 249
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/squareup/picasso/BitmapHunter;
.line 250
invoke-virtual {v1}, Lcom/squareup/picasso/BitmapHunter;->getPicasso()Lcom/squareup/picasso/Picasso;
move-result-object v2
iget-boolean v2, v2, Lcom/squareup/picasso/Picasso;->loggingEnabled:Z
.line 252
invoke-virtual {v1}, Lcom/squareup/picasso/BitmapHunter;->getAction()Lcom/squareup/picasso/Action;
move-result-object v3
.line 253
invoke-virtual {v1}, Lcom/squareup/picasso/BitmapHunter;->getActions()Ljava/util/List;
move-result-object v4
const/4 v5, 0x1
if-eqz v4, :cond_38
.line 254
invoke-interface {v4}, Ljava/util/List;->isEmpty()Z
move-result v6
if-nez v6, :cond_38
const/4 v6, 0x1
goto :goto_39
:cond_38
const/4 v6, 0x0
:goto_39
if-nez v3, :cond_3e
if-nez v6, :cond_3e
goto :goto_13
:cond_3e
const-string v7, "\' was paused"
const-string v8, "because tag \'"
const-string v9, "paused"
const-string v10, "Dispatcher"
if-eqz v3, :cond_7b
.line 261
invoke-virtual {v3}, Lcom/squareup/picasso/Action;->getTag()Ljava/lang/Object;
move-result-object v11
invoke-virtual {v11, p1}, Ljava/lang/Object;->equals(Ljava/lang/Object;)Z
move-result v11
if-eqz v11, :cond_7b
.line 262
invoke-virtual {v1, v3}, Lcom/squareup/picasso/BitmapHunter;->detach(Lcom/squareup/picasso/Action;)V
.line 263
iget-object v11, p0, Lcom/squareup/picasso/Dispatcher;->pausedActions:Ljava/util/Map;
invoke-virtual {v3}, Lcom/squareup/picasso/Action;->getTarget()Ljava/lang/Object;
move-result-object v12
invoke-interface {v11, v12, v3}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
if-eqz v2, :cond_7b
.line 265
iget-object v3, v3, Lcom/squareup/picasso/Action;->request:Lcom/squareup/picasso/Request;
invoke-virtual {v3}, Lcom/squareup/picasso/Request;->logId()Ljava/lang/String;
move-result-object v3
new-instance v11, Ljava/lang/StringBuilder;
invoke-direct {v11}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v11, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v11, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v11, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v11}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v11
invoke-static {v10, v9, v3, v11}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
:cond_7b
if-eqz v6, :cond_c1
.line 271
invoke-interface {v4}, Ljava/util/List;->size()I
move-result v3
sub-int/2addr v3, v5
:goto_82
if-ltz v3, :cond_c1
.line 272
invoke-interface {v4, v3}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v5
check-cast v5, Lcom/squareup/picasso/Action;
.line 273
invoke-virtual {v5}, Lcom/squareup/picasso/Action;->getTag()Ljava/lang/Object;
move-result-object v6
invoke-virtual {v6, p1}, Ljava/lang/Object;->equals(Ljava/lang/Object;)Z
move-result v6
if-nez v6, :cond_95
goto :goto_be
.line 277
:cond_95
invoke-virtual {v1, v5}, Lcom/squareup/picasso/BitmapHunter;->detach(Lcom/squareup/picasso/Action;)V
.line 278
iget-object v6, p0, Lcom/squareup/picasso/Dispatcher;->pausedActions:Ljava/util/Map;
invoke-virtual {v5}, Lcom/squareup/picasso/Action;->getTarget()Ljava/lang/Object;
move-result-object v11
invoke-interface {v6, v11, v5}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
if-eqz v2, :cond_be
.line 280
iget-object v5, v5, Lcom/squareup/picasso/Action;->request:Lcom/squareup/picasso/Request;
invoke-virtual {v5}, Lcom/squareup/picasso/Request;->logId()Ljava/lang/String;
move-result-object v5
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v6, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-static {v10, v9, v5, v6}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
:cond_be
:goto_be
add-int/lit8 v3, v3, -0x1
goto :goto_82
.line 288
:cond_c1
invoke-virtual {v1}, Lcom/squareup/picasso/BitmapHunter;->cancel()Z
move-result v3
if-eqz v3, :cond_13
.line 289
invoke-interface {v0}, Ljava/util/Iterator;->remove()V
if-eqz v2, :cond_13
.line 291
invoke-static {v1}, Lcom/squareup/picasso/Utils;->getLogIdsForHunter(Lcom/squareup/picasso/BitmapHunter;)Ljava/lang/String;
move-result-object v1
const-string v2, "canceled"
const-string v3, "all actions paused"
invoke-static {v10, v2, v1, v3}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
goto/16 :goto_13
:cond_d9
return-void
.end method
.method performResumeTag(Ljava/lang/Object;)V
.registers 6
.line 299
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->pausedTags:Ljava/util/Set;
invoke-interface {v0, p1}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_9
return-void
:cond_9
const/4 v0, 0x0
.line 304
iget-object v1, p0, Lcom/squareup/picasso/Dispatcher;->pausedActions:Ljava/util/Map;
invoke-interface {v1}, Ljava/util/Map;->values()Ljava/util/Collection;
move-result-object v1
invoke-interface {v1}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v1
:cond_14
:goto_14
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_38
.line 305
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/squareup/picasso/Action;
.line 306
invoke-virtual {v2}, Lcom/squareup/picasso/Action;->getTag()Ljava/lang/Object;
move-result-object v3
invoke-virtual {v3, p1}, Ljava/lang/Object;->equals(Ljava/lang/Object;)Z
move-result v3
if-eqz v3, :cond_14
if-nez v0, :cond_31
.line 308
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
.line 310
:cond_31
invoke-interface {v0, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 311
invoke-interface {v1}, Ljava/util/Iterator;->remove()V
goto :goto_14
:cond_38
if-eqz v0, :cond_45
.line 316
iget-object p1, p0, Lcom/squareup/picasso/Dispatcher;->mainThreadHandler:Landroid/os/Handler;
const/16 v1, 0xd
invoke-virtual {p1, v1, v0}, Landroid/os/Handler;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object v0
invoke-virtual {p1, v0}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z
:cond_45
return-void
.end method
.method performRetry(Lcom/squareup/picasso/BitmapHunter;)V
.registers 7
.line 321
invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->isCancelled()Z
move-result v0
if-eqz v0, :cond_7
return-void
.line 323
:cond_7
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->service:Ljava/util/concurrent/ExecutorService;
invoke-interface {v0}, Ljava/util/concurrent/ExecutorService;->isShutdown()Z
move-result v0
const/4 v1, 0x0
if-eqz v0, :cond_14
.line 324
invoke-virtual {p0, p1, v1}, Lcom/squareup/picasso/Dispatcher;->performError(Lcom/squareup/picasso/BitmapHunter;Z)V
return-void
:cond_14
const/4 v0, 0x0
.line 329
iget-boolean v2, p0, Lcom/squareup/picasso/Dispatcher;->scansNetworkChanges:Z
if-eqz v2, :cond_27
.line 330
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->context:Landroid/content/Context;
const-string v2, "connectivity"
invoke-static {v0, v2}, Lcom/squareup/picasso/Utils;->getService(Landroid/content/Context;Ljava/lang/String;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Landroid/net/ConnectivityManager;
.line 331
invoke-virtual {v0}, Landroid/net/ConnectivityManager;->getActiveNetworkInfo()Landroid/net/NetworkInfo;
move-result-object v0
:cond_27
const/4 v2, 0x1
if-eqz v0, :cond_32
.line 334
invoke-virtual {v0}, Landroid/net/NetworkInfo;->isConnected()Z
move-result v3
if-eqz v3, :cond_32
const/4 v3, 0x1
goto :goto_33
:cond_32
const/4 v3, 0x0
.line 335
:goto_33
iget-boolean v4, p0, Lcom/squareup/picasso/Dispatcher;->airplaneMode:Z
invoke-virtual {p1, v4, v0}, Lcom/squareup/picasso/BitmapHunter;->shouldRetry(ZLandroid/net/NetworkInfo;)Z
move-result v0
.line 336
invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->supportsReplay()Z
move-result v4
if-nez v0, :cond_4f
.line 340
iget-boolean v0, p0, Lcom/squareup/picasso/Dispatcher;->scansNetworkChanges:Z
if-eqz v0, :cond_46
if-eqz v4, :cond_46
const/4 v1, 0x1
.line 341
:cond_46
invoke-virtual {p0, p1, v1}, Lcom/squareup/picasso/Dispatcher;->performError(Lcom/squareup/picasso/BitmapHunter;Z)V
if-eqz v1, :cond_4e
.line 343
invoke-direct {p0, p1}, Lcom/squareup/picasso/Dispatcher;->markForReplay(Lcom/squareup/picasso/BitmapHunter;)V
:cond_4e
return-void
.line 349
:cond_4f
iget-boolean v0, p0, Lcom/squareup/picasso/Dispatcher;->scansNetworkChanges:Z
if-eqz v0, :cond_5f
if-eqz v3, :cond_56
goto :goto_5f
.line 361
:cond_56
invoke-virtual {p0, p1, v4}, Lcom/squareup/picasso/Dispatcher;->performError(Lcom/squareup/picasso/BitmapHunter;Z)V
if-eqz v4, :cond_5e
.line 364
invoke-direct {p0, p1}, Lcom/squareup/picasso/Dispatcher;->markForReplay(Lcom/squareup/picasso/BitmapHunter;)V
:cond_5e
return-void
.line 350
:cond_5f
:goto_5f
invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->getPicasso()Lcom/squareup/picasso/Picasso;
move-result-object v0
iget-boolean v0, v0, Lcom/squareup/picasso/Picasso;->loggingEnabled:Z
if-eqz v0, :cond_72
.line 351
invoke-static {p1}, Lcom/squareup/picasso/Utils;->getLogIdsForHunter(Lcom/squareup/picasso/BitmapHunter;)Ljava/lang/String;
move-result-object v0
const-string v1, "Dispatcher"
const-string v2, "retrying"
invoke-static {v1, v2, v0}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.line 354
:cond_72
invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->getException()Ljava/lang/Exception;
move-result-object v0
instance-of v0, v0, Lcom/squareup/picasso/NetworkRequestHandler$ContentLengthException;
if-eqz v0, :cond_83
.line 355
iget v0, p1, Lcom/squareup/picasso/BitmapHunter;->networkPolicy:I
sget-object v1, Lcom/squareup/picasso/NetworkPolicy;->NO_CACHE:Lcom/squareup/picasso/NetworkPolicy;
iget v1, v1, Lcom/squareup/picasso/NetworkPolicy;->index:I
or-int/2addr v0, v1
iput v0, p1, Lcom/squareup/picasso/BitmapHunter;->networkPolicy:I
.line 357
:cond_83
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->service:Ljava/util/concurrent/ExecutorService;
invoke-interface {v0, p1}, Ljava/util/concurrent/ExecutorService;->submit(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
move-result-object v0
iput-object v0, p1, Lcom/squareup/picasso/BitmapHunter;->future:Ljava/util/concurrent/Future;
return-void
.end method
.method performSubmit(Lcom/squareup/picasso/Action;)V
.registers 3
const/4 v0, 0x1
.line 175
invoke-virtual {p0, p1, v0}, Lcom/squareup/picasso/Dispatcher;->performSubmit(Lcom/squareup/picasso/Action;Z)V
return-void
.end method
.method performSubmit(Lcom/squareup/picasso/Action;Z)V
.registers 7
.line 179
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->pausedTags:Ljava/util/Set;
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getTag()Ljava/lang/Object;
move-result-object v1
invoke-interface {v0, v1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v0
const-string v1, "Dispatcher"
if-eqz v0, :cond_45
.line 180
iget-object p2, p0, Lcom/squareup/picasso/Dispatcher;->pausedActions:Ljava/util/Map;
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getTarget()Ljava/lang/Object;
move-result-object v0
invoke-interface {p2, v0, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 181
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getPicasso()Lcom/squareup/picasso/Picasso;
move-result-object p2
iget-boolean p2, p2, Lcom/squareup/picasso/Picasso;->loggingEnabled:Z
if-eqz p2, :cond_44
.line 182
iget-object p2, p1, Lcom/squareup/picasso/Action;->request:Lcom/squareup/picasso/Request;
invoke-virtual {p2}, Lcom/squareup/picasso/Request;->logId()Ljava/lang/String;
move-result-object p2
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "because tag \'"
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 183
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getTag()Ljava/lang/Object;
move-result-object p1
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string p1, "\' is paused"
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
const-string v0, "paused"
.line 182
invoke-static {v1, v0, p2, p1}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
:cond_44
return-void
.line 188
:cond_45
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->hunterMap:Ljava/util/Map;
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getKey()Ljava/lang/String;
move-result-object v2
invoke-interface {v0, v2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/squareup/picasso/BitmapHunter;
if-eqz v0, :cond_57
.line 190
invoke-virtual {v0, p1}, Lcom/squareup/picasso/BitmapHunter;->attach(Lcom/squareup/picasso/Action;)V
return-void
.line 194
:cond_57
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->service:Ljava/util/concurrent/ExecutorService;
invoke-interface {v0}, Ljava/util/concurrent/ExecutorService;->isShutdown()Z
move-result v0
if-eqz v0, :cond_75
.line 195
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getPicasso()Lcom/squareup/picasso/Picasso;
move-result-object p2
iget-boolean p2, p2, Lcom/squareup/picasso/Picasso;->loggingEnabled:Z
if-eqz p2, :cond_74
.line 196
iget-object p1, p1, Lcom/squareup/picasso/Action;->request:Lcom/squareup/picasso/Request;
invoke-virtual {p1}, Lcom/squareup/picasso/Request;->logId()Ljava/lang/String;
move-result-object p1
const-string p2, "ignored"
const-string v0, "because shut down"
invoke-static {v1, p2, p1, v0}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
:cond_74
return-void
.line 201
:cond_75
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getPicasso()Lcom/squareup/picasso/Picasso;
move-result-object v0
iget-object v2, p0, Lcom/squareup/picasso/Dispatcher;->cache:Lcom/squareup/picasso/Cache;
iget-object v3, p0, Lcom/squareup/picasso/Dispatcher;->stats:Lcom/squareup/picasso/Stats;
invoke-static {v0, p0, v2, v3, p1}, Lcom/squareup/picasso/BitmapHunter;->forRequest(Lcom/squareup/picasso/Picasso;Lcom/squareup/picasso/Dispatcher;Lcom/squareup/picasso/Cache;Lcom/squareup/picasso/Stats;Lcom/squareup/picasso/Action;)Lcom/squareup/picasso/BitmapHunter;
move-result-object v0
.line 202
iget-object v2, p0, Lcom/squareup/picasso/Dispatcher;->service:Ljava/util/concurrent/ExecutorService;
invoke-interface {v2, v0}, Ljava/util/concurrent/ExecutorService;->submit(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
move-result-object v2
iput-object v2, v0, Lcom/squareup/picasso/BitmapHunter;->future:Ljava/util/concurrent/Future;
.line 203
iget-object v2, p0, Lcom/squareup/picasso/Dispatcher;->hunterMap:Ljava/util/Map;
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getKey()Ljava/lang/String;
move-result-object v3
invoke-interface {v2, v3, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
if-eqz p2, :cond_9d
.line 205
iget-object p2, p0, Lcom/squareup/picasso/Dispatcher;->failedActions:Ljava/util/Map;
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getTarget()Ljava/lang/Object;
move-result-object v0
invoke-interface {p2, v0}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
.line 208
:cond_9d
invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getPicasso()Lcom/squareup/picasso/Picasso;
move-result-object p2
iget-boolean p2, p2, Lcom/squareup/picasso/Picasso;->loggingEnabled:Z
if-eqz p2, :cond_b0
.line 209
iget-object p1, p1, Lcom/squareup/picasso/Action;->request:Lcom/squareup/picasso/Request;
invoke-virtual {p1}, Lcom/squareup/picasso/Request;->logId()Ljava/lang/String;
move-result-object p1
const-string p2, "enqueued"
invoke-static {v1, p2, p1}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
:cond_b0
return-void
.end method
.method shutdown()V
.registers 3
.line 124
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->service:Ljava/util/concurrent/ExecutorService;
instance-of v1, v0, Lcom/squareup/picasso/PicassoExecutorService;
if-eqz v1, :cond_9
.line 125
invoke-interface {v0}, Ljava/util/concurrent/ExecutorService;->shutdown()V
.line 127
:cond_9
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->downloader:Lcom/squareup/picasso/Downloader;
invoke-interface {v0}, Lcom/squareup/picasso/Downloader;->shutdown()V
.line 128
iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->dispatcherThread:Lcom/squareup/picasso/Dispatcher$DispatcherThread;
invoke-virtual {v0}, Lcom/squareup/picasso/Dispatcher$DispatcherThread;->quit()Z
.line 130
sget-object v0, Lcom/squareup/picasso/Picasso;->HANDLER:Landroid/os/Handler;
new-instance v1, Lcom/squareup/picasso/Dispatcher$1;
invoke-direct {v1, p0}, Lcom/squareup/picasso/Dispatcher$1;-><init>(Lcom/squareup/picasso/Dispatcher;)V
invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
return-void
.end method