.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 (Landroid/content/Context;Ljava/util/concurrent/ExecutorService;Landroid/os/Handler;Lcom/squareup/picasso/Downloader;Lcom/squareup/picasso/Cache;Lcom/squareup/picasso/Stats;)V .registers 9 .line 101 invoke-direct {p0}, Ljava/lang/Object;->()V .line 102 new-instance v0, Lcom/squareup/picasso/Dispatcher$DispatcherThread; invoke-direct {v0}, Lcom/squareup/picasso/Dispatcher$DispatcherThread;->()V iput-object v0, p0, Lcom/squareup/picasso/Dispatcher;->dispatcherThread:Lcom/squareup/picasso/Dispatcher$DispatcherThread; .line 103 invoke-virtual {v0}, Lcom/squareup/picasso/Dispatcher$DispatcherThread;->start()V .line 104 invoke-virtual {v0}, Lcom/squareup/picasso/Dispatcher$DispatcherThread;->getLooper()Landroid/os/Looper; move-result-object v1 invoke-static {v1}, Lcom/squareup/picasso/Utils;->flushStackLocalLeaks(Landroid/os/Looper;)V .line 105 iput-object p1, p0, Lcom/squareup/picasso/Dispatcher;->context:Landroid/content/Context; .line 106 iput-object p2, p0, Lcom/squareup/picasso/Dispatcher;->service:Ljava/util/concurrent/ExecutorService; .line 107 new-instance p2, Ljava/util/LinkedHashMap; invoke-direct {p2}, Ljava/util/LinkedHashMap;->()V iput-object p2, p0, Lcom/squareup/picasso/Dispatcher;->hunterMap:Ljava/util/Map; .line 108 new-instance p2, Ljava/util/WeakHashMap; invoke-direct {p2}, Ljava/util/WeakHashMap;->()V iput-object p2, p0, Lcom/squareup/picasso/Dispatcher;->failedActions:Ljava/util/Map; .line 109 new-instance p2, Ljava/util/WeakHashMap; invoke-direct {p2}, Ljava/util/WeakHashMap;->()V iput-object p2, p0, Lcom/squareup/picasso/Dispatcher;->pausedActions:Ljava/util/Map; .line 110 new-instance p2, Ljava/util/LinkedHashSet; invoke-direct {p2}, Ljava/util/LinkedHashSet;->()V iput-object p2, p0, Lcom/squareup/picasso/Dispatcher;->pausedTags:Ljava/util/Set; .line 111 new-instance p2, Lcom/squareup/picasso/Dispatcher$DispatcherHandler; 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;->(Landroid/os/Looper;Lcom/squareup/picasso/Dispatcher;)V iput-object p2, p0, Lcom/squareup/picasso/Dispatcher;->handler:Landroid/os/Handler; .line 112 iput-object p4, p0, Lcom/squareup/picasso/Dispatcher;->downloader:Lcom/squareup/picasso/Downloader; .line 113 iput-object p3, p0, Lcom/squareup/picasso/Dispatcher;->mainThreadHandler:Landroid/os/Handler; .line 114 iput-object p5, p0, Lcom/squareup/picasso/Dispatcher;->cache:Lcom/squareup/picasso/Cache; .line 115 iput-object p6, p0, Lcom/squareup/picasso/Dispatcher;->stats:Lcom/squareup/picasso/Stats; .line 116 new-instance p2, Ljava/util/ArrayList; const/4 p3, 0x4 invoke-direct {p2, p3}, Ljava/util/ArrayList;->(I)V iput-object p2, p0, Lcom/squareup/picasso/Dispatcher;->batch:Ljava/util/List; .line 117 invoke-static {p1}, Lcom/squareup/picasso/Utils;->isAirplaneModeOn(Landroid/content/Context;)Z move-result p2 iput-boolean p2, p0, Lcom/squareup/picasso/Dispatcher;->airplaneMode:Z .line 118 const-string p2, "android.permission.ACCESS_NETWORK_STATE" 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 119 new-instance p1, Lcom/squareup/picasso/Dispatcher$NetworkBroadcastReceiver; invoke-direct {p1, p0}, Lcom/squareup/picasso/Dispatcher$NetworkBroadcastReceiver;->(Lcom/squareup/picasso/Dispatcher;)V iput-object p1, p0, Lcom/squareup/picasso/Dispatcher;->receiver:Lcom/squareup/picasso/Dispatcher$NetworkBroadcastReceiver; .line 120 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 433 invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->isCancelled()Z move-result v0 if-eqz v0, :cond_7 return-void .line 436 :cond_7 iget-object v0, p1, Lcom/squareup/picasso/BitmapHunter;->result:Landroid/graphics/Bitmap; if-eqz v0, :cond_10 .line 437 iget-object v0, p1, Lcom/squareup/picasso/BitmapHunter;->result:Landroid/graphics/Bitmap; invoke-virtual {v0}, Landroid/graphics/Bitmap;->prepareToDraw()V .line 439 :cond_10 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 440 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_25 .line 441 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_25 return-void .end method .method private flushFailedActions()V .registers 6 .line 396 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 397 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 398 :goto_12 invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z move-result v1 if-eqz v1, :cond_3d .line 399 invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v1 check-cast v1, Lcom/squareup/picasso/Action; .line 400 invoke-interface {v0}, Ljava/util/Iterator;->remove()V .line 401 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 402 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 404 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 446 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 447 invoke-interface {p1, v0}, Ljava/util/List;->get(I)Ljava/lang/Object; move-result-object v0 check-cast v0, Lcom/squareup/picasso/BitmapHunter; .line 448 invoke-virtual {v0}, Lcom/squareup/picasso/BitmapHunter;->getPicasso()Lcom/squareup/picasso/Picasso; move-result-object v0 .line 449 iget-boolean v0, v0, Lcom/squareup/picasso/Picasso;->loggingEnabled:Z if-eqz v0, :cond_4b .line 450 new-instance v0, Ljava/lang/StringBuilder; invoke-direct {v0}, Ljava/lang/StringBuilder;->()V .line 451 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 452 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 453 :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 455 :cond_40 const-string p1, "delivered" invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 const-string v1, "Dispatcher" invoke-static {v1, p1, v0}, 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 425 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 427 iput-boolean v1, p1, Lcom/squareup/picasso/Action;->willReplay:Z .line 428 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 410 invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->getAction()Lcom/squareup/picasso/Action; move-result-object v0 if-eqz v0, :cond_9 .line 412 invoke-direct {p0, v0}, Lcom/squareup/picasso/Dispatcher;->markForReplay(Lcom/squareup/picasso/Action;)V .line 414 :cond_9 invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->getActions()Ljava/util/List; move-result-object p1 if-eqz p1, :cond_22 .line 417 invoke-interface {p1}, Ljava/util/List;->size()I move-result v0 const/4 v1, 0x0 :goto_14 if-ge v1, v0, :cond_22 .line 418 invoke-interface {p1, v1}, Ljava/util/List;->get(I)Ljava/lang/Object; move-result-object v2 check-cast v2, Lcom/squareup/picasso/Action; .line 419 invoke-direct {p0, v2}, Lcom/squareup/picasso/Dispatcher;->markForReplay(Lcom/squareup/picasso/Action;)V add-int/lit8 v1, v1, 0x1 goto :goto_14 :cond_22 return-void .end method # virtual methods .method dispatchAirplaneModeChange(Z)V .registers 5 .line 171 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 143 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 155 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 163 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 167 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 147 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 151 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 159 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 139 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 382 iput-boolean p1, p0, Lcom/squareup/picasso/Dispatcher;->airplaneMode:Z return-void .end method .method performBatchComplete()V .registers 4 .line 366 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;->(Ljava/util/Collection;)V .line 367 iget-object v1, p0, Lcom/squareup/picasso/Dispatcher;->batch:Ljava/util/List; invoke-interface {v1}, Ljava/util/List;->clear()V .line 368 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 369 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 215 invoke-virtual {p1}, Lcom/squareup/picasso/Action;->getKey()Ljava/lang/String; move-result-object v0 .line 216 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; .line 217 const-string v2, "canceled" const-string v3, "Dispatcher" if-eqz v1, :cond_33 .line 218 invoke-virtual {v1, p1}, Lcom/squareup/picasso/BitmapHunter;->detach(Lcom/squareup/picasso/Action;)V .line 219 invoke-virtual {v1}, Lcom/squareup/picasso/BitmapHunter;->cancel()Z move-result v1 if-eqz v1, :cond_33 .line 220 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 221 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 222 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 227 :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 228 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 229 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 230 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 235 :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 236 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 237 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 355 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 356 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 358 :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 359 invoke-direct {p0, p1}, Lcom/squareup/picasso/Dispatcher;->batch(Lcom/squareup/picasso/BitmapHunter;)V .line 360 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 361 invoke-static {p1}, Lcom/squareup/picasso/Utils;->getLogIdsForHunter(Lcom/squareup/picasso/BitmapHunter;)Ljava/lang/String; move-result-object p1 const-string v0, "for completion" const-string v1, "Dispatcher" const-string v2, "batched" invoke-static {v1, v2, p1, v0}, 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 373 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_20 .line 374 invoke-static {p1}, Lcom/squareup/picasso/Utils;->getLogIdsForHunter(Lcom/squareup/picasso/BitmapHunter;)Ljava/lang/String; move-result-object v0 if-eqz p2, :cond_11 const-string p2, " (will replay)" goto :goto_13 :cond_11 const-string p2, "" :goto_13 const-string v1, "for error" invoke-virtual {v1, p2}, Ljava/lang/String;->concat(Ljava/lang/String;)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 377 :cond_20 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 378 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 386 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 387 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 390 invoke-virtual {p1}, Landroid/net/NetworkInfo;->isConnected()Z move-result p1 if-eqz p1, :cond_16 .line 391 invoke-direct {p0}, Lcom/squareup/picasso/Dispatcher;->flushFailedActions()V :cond_16 return-void .end method .method performPauseTag(Ljava/lang/Object;)V .registers 15 .line 243 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 249 :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_d7 .line 250 invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v1 check-cast v1, Lcom/squareup/picasso/BitmapHunter; .line 251 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 253 invoke-virtual {v1}, Lcom/squareup/picasso/BitmapHunter;->getAction()Lcom/squareup/picasso/Action; move-result-object v3 .line 254 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 255 invoke-interface {v4}, Ljava/util/List;->isEmpty()Z move-result v6 if-nez v6, :cond_38 move v6, v5 goto :goto_39 :cond_38 const/4 v6, 0x0 :goto_39 if-nez v3, :cond_3e if-nez v6, :cond_3e goto :goto_13 .line 262 :cond_3e const-string v7, "\' was paused" const-string v8, "because tag \'" const-string v9, "paused" const-string v10, "Dispatcher" if-eqz v3, :cond_7a 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_7a .line 263 invoke-virtual {v1, v3}, Lcom/squareup/picasso/BitmapHunter;->detach(Lcom/squareup/picasso/Action;)V .line 264 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_7a .line 266 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, v8}, Ljava/lang/StringBuilder;->(Ljava/lang/String;)V invoke-virtual {v11, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; move-result-object v11 invoke-virtual {v11, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v11 invoke-virtual {v11}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v11 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_7a if-eqz v6, :cond_bf .line 272 invoke-interface {v4}, Ljava/util/List;->size()I move-result v3 sub-int/2addr v3, v5 :goto_81 if-ltz v3, :cond_bf .line 273 invoke-interface {v4, v3}, Ljava/util/List;->get(I)Ljava/lang/Object; move-result-object v5 check-cast v5, Lcom/squareup/picasso/Action; .line 274 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_94 goto :goto_bc .line 278 :cond_94 invoke-virtual {v1, v5}, Lcom/squareup/picasso/BitmapHunter;->detach(Lcom/squareup/picasso/Action;)V .line 279 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_bc .line 281 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, v8}, Ljava/lang/StringBuilder;->(Ljava/lang/String;)V invoke-virtual {v6, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; move-result-object v6 invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v6 invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v6 invoke-static {v10, v9, v5, v6}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V :cond_bc :goto_bc add-int/lit8 v3, v3, -0x1 goto :goto_81 .line 289 :cond_bf invoke-virtual {v1}, Lcom/squareup/picasso/BitmapHunter;->cancel()Z move-result v3 if-eqz v3, :cond_13 .line 290 invoke-interface {v0}, Ljava/util/Iterator;->remove()V if-eqz v2, :cond_13 .line 292 invoke-static {v1}, Lcom/squareup/picasso/Utils;->getLogIdsForHunter(Lcom/squareup/picasso/BitmapHunter;)Ljava/lang/String; move-result-object v1 const-string v2, "all actions paused" const-string v3, "canceled" invoke-static {v10, v3, v1, v2}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V goto/16 :goto_13 :cond_d7 return-void .end method .method performResumeTag(Ljava/lang/Object;)V .registers 6 .line 300 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 .line 305 :cond_9 iget-object v0, p0, Lcom/squareup/picasso/Dispatcher;->pausedActions: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 const/4 v1, 0x0 :cond_14 :goto_14 invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z move-result v2 if-eqz v2, :cond_38 .line 306 invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v2 check-cast v2, Lcom/squareup/picasso/Action; .line 307 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 v1, :cond_31 .line 309 new-instance v1, Ljava/util/ArrayList; invoke-direct {v1}, Ljava/util/ArrayList;->()V .line 311 :cond_31 invoke-interface {v1, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z .line 312 invoke-interface {v0}, Ljava/util/Iterator;->remove()V goto :goto_14 :cond_38 if-eqz v1, :cond_45 .line 317 iget-object p1, p0, Lcom/squareup/picasso/Dispatcher;->mainThreadHandler:Landroid/os/Handler; const/16 v0, 0xd invoke-virtual {p1, v0, v1}, 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 5 .line 323 invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->isCancelled()Z move-result v0 if-eqz v0, :cond_7 return-void .line 325 :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 326 invoke-virtual {p0, p1, v1}, Lcom/squareup/picasso/Dispatcher;->performError(Lcom/squareup/picasso/BitmapHunter;Z)V return-void .line 331 :cond_14 iget-boolean v0, p0, Lcom/squareup/picasso/Dispatcher;->scansNetworkChanges:Z if-eqz v0, :cond_27 .line 332 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 333 invoke-virtual {v0}, Landroid/net/ConnectivityManager;->getActiveNetworkInfo()Landroid/net/NetworkInfo; move-result-object v0 goto :goto_28 :cond_27 const/4 v0, 0x0 .line 336 :goto_28 iget-boolean v2, p0, Lcom/squareup/picasso/Dispatcher;->airplaneMode:Z invoke-virtual {p1, v2, v0}, Lcom/squareup/picasso/BitmapHunter;->shouldRetry(ZLandroid/net/NetworkInfo;)Z move-result v0 if-eqz v0, :cond_5d .line 337 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_43 .line 338 const-string v0, "retrying" invoke-static {p1}, Lcom/squareup/picasso/Utils;->getLogIdsForHunter(Lcom/squareup/picasso/BitmapHunter;)Ljava/lang/String; move-result-object v1 const-string v2, "Dispatcher" invoke-static {v2, v0, v1}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V .line 340 :cond_43 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_54 .line 341 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 343 :cond_54 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; goto :goto_70 .line 346 :cond_5d iget-boolean v0, p0, Lcom/squareup/picasso/Dispatcher;->scansNetworkChanges:Z if-eqz v0, :cond_68 invoke-virtual {p1}, Lcom/squareup/picasso/BitmapHunter;->supportsReplay()Z move-result v0 if-eqz v0, :cond_68 const/4 v1, 0x1 .line 347 :cond_68 invoke-virtual {p0, p1, v1}, Lcom/squareup/picasso/Dispatcher;->performError(Lcom/squareup/picasso/BitmapHunter;Z)V if-eqz v1, :cond_70 .line 349 invoke-direct {p0, p1}, Lcom/squareup/picasso/Dispatcher;->markForReplay(Lcom/squareup/picasso/BitmapHunter;)V :cond_70 :goto_70 return-void .end method .method performSubmit(Lcom/squareup/picasso/Action;)V .registers 3 const/4 v0, 0x1 .line 176 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 180 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_44 .line 181 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 182 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_43 .line 183 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; const-string v2, "because tag \'" invoke-direct {v0, v2}, Ljava/lang/StringBuilder;->(Ljava/lang/String;)V .line 184 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; move-result-object p1 const-string v0, "\' is paused" invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object p1 invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 .line 183 const-string v0, "paused" 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_43 return-void .line 189 :cond_44 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_56 .line 191 invoke-virtual {v0, p1}, Lcom/squareup/picasso/BitmapHunter;->attach(Lcom/squareup/picasso/Action;)V return-void .line 195 :cond_56 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_74 .line 196 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_73 .line 197 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, "because shut down" const-string v0, "ignored" invoke-static {v1, v0, p1, p2}, Lcom/squareup/picasso/Utils;->log(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V :cond_73 return-void .line 202 :cond_74 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 203 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 204 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_9c .line 206 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 209 :cond_9c 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_af .line 210 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_af return-void .end method .method shutdown()V .registers 3 .line 125 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 126 invoke-interface {v0}, Ljava/util/concurrent/ExecutorService;->shutdown()V .line 128 :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 129 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 131 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;->(Lcom/squareup/picasso/Dispatcher;)V invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z return-void .end method