.class public Lorg/apache/http/impl/conn/SingleClientConnManager; .super Ljava/lang/Object; .source "SingleClientConnManager.java" # interfaces .implements Lorg/apache/http/conn/ClientConnectionManager; # annotations .annotation system Ldalvik/annotation/MemberClasses; value = { Lorg/apache/http/impl/conn/SingleClientConnManager$ConnAdapter;, Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry; } .end annotation .annotation build Lorg/apache/http/annotation/ThreadSafe; .end annotation # static fields .field public static final MISUSE_MESSAGE:Ljava/lang/String; = "Invalid use of SingleClientConnManager: connection still allocated.\nMake sure to release the connection before allocating another one." # instance fields .field public final alwaysShutDown:Z .field public final connOperator:Lorg/apache/http/conn/ClientConnectionOperator; .field public connectionExpiresTime:J .annotation build Lorg/apache/http/annotation/GuardedBy; value = "this" .end annotation .end field .field public volatile isShutDown:Z .field public lastReleaseTime:J .annotation build Lorg/apache/http/annotation/GuardedBy; value = "this" .end annotation .end field .field private final log:Lorg/apache/commons/logging/Log; .field public managedConn:Lorg/apache/http/impl/conn/SingleClientConnManager$ConnAdapter; .annotation build Lorg/apache/http/annotation/GuardedBy; value = "this" .end annotation .end field .field public final schemeRegistry:Lorg/apache/http/conn/scheme/SchemeRegistry; .field public uniquePoolEntry:Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry; .annotation build Lorg/apache/http/annotation/GuardedBy; value = "this" .end annotation .end field # direct methods .method public constructor (Lorg/apache/http/params/HttpParams;Lorg/apache/http/conn/scheme/SchemeRegistry;)V .locals 0 .line 1 invoke-direct {p0}, Ljava/lang/Object;->()V .line 2 invoke-virtual {p0}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object p1 invoke-static {p1}, Lorg/apache/commons/logging/LogFactory;->getLog(Ljava/lang/Class;)Lorg/apache/commons/logging/Log; move-result-object p1 iput-object p1, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->log:Lorg/apache/commons/logging/Log; if-eqz p2, :cond_0 .line 3 iput-object p2, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->schemeRegistry:Lorg/apache/http/conn/scheme/SchemeRegistry; .line 4 invoke-virtual {p0, p2}, Lorg/apache/http/impl/conn/SingleClientConnManager;->createConnectionOperator(Lorg/apache/http/conn/scheme/SchemeRegistry;)Lorg/apache/http/conn/ClientConnectionOperator; move-result-object p1 iput-object p1, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->connOperator:Lorg/apache/http/conn/ClientConnectionOperator; .line 5 new-instance p1, Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry; invoke-direct {p1, p0}, Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry;->(Lorg/apache/http/impl/conn/SingleClientConnManager;)V iput-object p1, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->uniquePoolEntry:Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry; const/4 p1, 0x0 .line 6 iput-object p1, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->managedConn:Lorg/apache/http/impl/conn/SingleClientConnManager$ConnAdapter; const-wide/16 p1, -0x1 .line 7 iput-wide p1, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->lastReleaseTime:J const/4 p1, 0x0 .line 8 iput-boolean p1, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->alwaysShutDown:Z .line 9 iput-boolean p1, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->isShutDown:Z return-void .line 10 :cond_0 new-instance p1, Ljava/lang/IllegalArgumentException; const-string p2, "Scheme registry must not be null." invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V throw p1 .end method # virtual methods .method public final assertStillUp()V .locals 2 .annotation system Ldalvik/annotation/Throws; value = { Ljava/lang/IllegalStateException; } .end annotation .line 1 iget-boolean v0, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->isShutDown:Z if-nez v0, :cond_0 return-void .line 2 :cond_0 new-instance v0, Ljava/lang/IllegalStateException; const-string v1, "Manager is shut down." invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;->(Ljava/lang/String;)V throw v0 .end method .method public declared-synchronized closeExpiredConnections()V .locals 4 monitor-enter p0 .line 1 :try_start_0 invoke-static {}, Ljava/lang/System;->currentTimeMillis()J move-result-wide v0 iget-wide v2, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->connectionExpiresTime:J cmp-long v0, v0, v2 if-ltz v0, :cond_0 const-wide/16 v0, 0x0 .line 2 sget-object v2, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit; invoke-virtual {p0, v0, v1, v2}, Lorg/apache/http/impl/conn/SingleClientConnManager;->closeIdleConnections(JLjava/util/concurrent/TimeUnit;)V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 .line 3 :cond_0 monitor-exit p0 return-void :catchall_0 move-exception v0 monitor-exit p0 throw v0 .end method .method public declared-synchronized closeIdleConnections(JLjava/util/concurrent/TimeUnit;)V .locals 2 monitor-enter p0 .line 1 :try_start_0 invoke-virtual {p0}, Lorg/apache/http/impl/conn/SingleClientConnManager;->assertStillUp()V if-eqz p3, :cond_1 .line 2 iget-object v0, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->managedConn:Lorg/apache/http/impl/conn/SingleClientConnManager$ConnAdapter; if-nez v0, :cond_0 iget-object v0, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->uniquePoolEntry:Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry; iget-object v0, v0, Lorg/apache/http/impl/conn/AbstractPoolEntry;->connection:Lorg/apache/http/conn/OperatedClientConnection; invoke-interface {v0}, Lorg/apache/http/HttpConnection;->isOpen()Z move-result v0 if-eqz v0, :cond_0 .line 3 invoke-static {}, Ljava/lang/System;->currentTimeMillis()J move-result-wide v0 invoke-virtual {p3, p1, p2}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J move-result-wide p1 sub-long/2addr v0, p1 .line 4 iget-wide p1, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->lastReleaseTime:J :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 cmp-long p1, p1, v0 if-gtz p1, :cond_0 .line 5 :try_start_1 iget-object p1, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->uniquePoolEntry:Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry; invoke-virtual {p1}, Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry;->close()V :try_end_1 .catch Ljava/io/IOException; {:try_start_1 .. :try_end_1} :catch_0 .catchall {:try_start_1 .. :try_end_1} :catchall_0 goto :goto_0 :catch_0 move-exception p1 .line 6 :try_start_2 iget-object p2, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->log:Lorg/apache/commons/logging/Log; const-string p3, "Problem closing idle connection." invoke-interface {p2, p3, p1}, Lorg/apache/commons/logging/Log;->debug(Ljava/lang/Object;Ljava/lang/Throwable;)V :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 .line 7 :cond_0 :goto_0 monitor-exit p0 return-void .line 8 :cond_1 :try_start_3 new-instance p1, Ljava/lang/IllegalArgumentException; const-string p2, "Time unit must not be null." invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V throw p1 :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_0 :catchall_0 move-exception p1 monitor-exit p0 throw p1 .end method .method public createConnectionOperator(Lorg/apache/http/conn/scheme/SchemeRegistry;)Lorg/apache/http/conn/ClientConnectionOperator; .locals 1 .line 1 new-instance v0, Lorg/apache/http/impl/conn/DefaultClientConnectionOperator; invoke-direct {v0, p1}, Lorg/apache/http/impl/conn/DefaultClientConnectionOperator;->(Lorg/apache/http/conn/scheme/SchemeRegistry;)V return-object v0 .end method .method public finalize()V .locals 1 .annotation system Ldalvik/annotation/Throws; value = { Ljava/lang/Throwable; } .end annotation .line 1 :try_start_0 invoke-virtual {p0}, Lorg/apache/http/impl/conn/SingleClientConnManager;->shutdown()V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 .line 2 invoke-super {p0}, Ljava/lang/Object;->finalize()V return-void :catchall_0 move-exception v0 invoke-super {p0}, Ljava/lang/Object;->finalize()V throw v0 .end method .method public declared-synchronized getConnection(Lorg/apache/http/conn/routing/HttpRoute;Ljava/lang/Object;)Lorg/apache/http/conn/ManagedClientConnection; .locals 4 monitor-enter p0 if-eqz p1, :cond_7 .line 1 :try_start_0 invoke-virtual {p0}, Lorg/apache/http/impl/conn/SingleClientConnManager;->assertStillUp()V .line 2 iget-object p2, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->log:Lorg/apache/commons/logging/Log; invoke-interface {p2}, Lorg/apache/commons/logging/Log;->isDebugEnabled()Z move-result p2 if-eqz p2, :cond_0 .line 3 iget-object p2, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->log:Lorg/apache/commons/logging/Log; new-instance v0, Ljava/lang/StringBuilder; invoke-direct {v0}, Ljava/lang/StringBuilder;->()V const-string v1, "Get connection for route " invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 invoke-interface {p2, v0}, Lorg/apache/commons/logging/Log;->debug(Ljava/lang/Object;)V .line 4 :cond_0 iget-object p2, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->managedConn:Lorg/apache/http/impl/conn/SingleClientConnManager$ConnAdapter; if-nez p2, :cond_6 .line 5 invoke-virtual {p0}, Lorg/apache/http/impl/conn/SingleClientConnManager;->closeExpiredConnections()V .line 6 iget-object p2, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->uniquePoolEntry:Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry; iget-object p2, p2, Lorg/apache/http/impl/conn/AbstractPoolEntry;->connection:Lorg/apache/http/conn/OperatedClientConnection; invoke-interface {p2}, Lorg/apache/http/HttpConnection;->isOpen()Z move-result p2 const/4 v0, 0x1 const/4 v1, 0x0 if-eqz p2, :cond_3 .line 7 iget-object p2, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->uniquePoolEntry:Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry; iget-object p2, p2, Lorg/apache/http/impl/conn/AbstractPoolEntry;->tracker:Lorg/apache/http/conn/routing/RouteTracker; if-eqz p2, :cond_2 .line 8 invoke-virtual {p2}, Lorg/apache/http/conn/routing/RouteTracker;->toRoute()Lorg/apache/http/conn/routing/HttpRoute; move-result-object p2 invoke-virtual {p2, p1}, Lorg/apache/http/conn/routing/HttpRoute;->equals(Ljava/lang/Object;)Z move-result p2 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 if-nez p2, :cond_1 goto :goto_0 :cond_1 move p2, v1 goto :goto_1 :cond_2 :goto_0 move p2, v0 :goto_1 move v3, v1 move v1, p2 move p2, v3 goto :goto_2 :cond_3 move p2, v0 :goto_2 if-eqz v1, :cond_4 .line 9 :try_start_1 iget-object p2, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->uniquePoolEntry:Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry; invoke-virtual {p2}, Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry;->shutdown()V :try_end_1 .catch Ljava/io/IOException; {:try_start_1 .. :try_end_1} :catch_0 .catchall {:try_start_1 .. :try_end_1} :catchall_0 goto :goto_3 :catch_0 move-exception p2 .line 10 :try_start_2 iget-object v1, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->log:Lorg/apache/commons/logging/Log; const-string v2, "Problem shutting down connection." invoke-interface {v1, v2, p2}, Lorg/apache/commons/logging/Log;->debug(Ljava/lang/Object;Ljava/lang/Throwable;)V goto :goto_3 :cond_4 move v0, p2 :goto_3 if-eqz v0, :cond_5 .line 11 new-instance p2, Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry; invoke-direct {p2, p0}, Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry;->(Lorg/apache/http/impl/conn/SingleClientConnManager;)V iput-object p2, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->uniquePoolEntry:Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry; .line 12 :cond_5 new-instance p2, Lorg/apache/http/impl/conn/SingleClientConnManager$ConnAdapter; iget-object v0, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->uniquePoolEntry:Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry; invoke-direct {p2, p0, v0, p1}, Lorg/apache/http/impl/conn/SingleClientConnManager$ConnAdapter;->(Lorg/apache/http/impl/conn/SingleClientConnManager;Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry;Lorg/apache/http/conn/routing/HttpRoute;)V iput-object p2, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->managedConn:Lorg/apache/http/impl/conn/SingleClientConnManager$ConnAdapter; :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 .line 13 monitor-exit p0 return-object p2 .line 14 :cond_6 :try_start_3 new-instance p1, Ljava/lang/IllegalStateException; const-string p2, "Invalid use of SingleClientConnManager: connection still allocated.\nMake sure to release the connection before allocating another one." invoke-direct {p1, p2}, Ljava/lang/IllegalStateException;->(Ljava/lang/String;)V throw p1 :catchall_0 move-exception p1 goto :goto_4 .line 15 :cond_7 new-instance p1, Ljava/lang/IllegalArgumentException; const-string p2, "Route may not be null." invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V throw p1 :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_0 :goto_4 monitor-exit p0 throw p1 .end method .method public getSchemeRegistry()Lorg/apache/http/conn/scheme/SchemeRegistry; .locals 1 .line 1 iget-object v0, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->schemeRegistry:Lorg/apache/http/conn/scheme/SchemeRegistry; return-object v0 .end method .method public declared-synchronized releaseConnection(Lorg/apache/http/conn/ManagedClientConnection;JLjava/util/concurrent/TimeUnit;)V .locals 8 monitor-enter p0 .line 1 :try_start_0 invoke-virtual {p0}, Lorg/apache/http/impl/conn/SingleClientConnManager;->assertStillUp()V .line 2 instance-of v0, p1, Lorg/apache/http/impl/conn/SingleClientConnManager$ConnAdapter; if-eqz v0, :cond_a .line 3 iget-object v0, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->log:Lorg/apache/commons/logging/Log; invoke-interface {v0}, Lorg/apache/commons/logging/Log;->isDebugEnabled()Z move-result v0 if-eqz v0, :cond_0 .line 4 iget-object v0, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->log:Lorg/apache/commons/logging/Log; new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "Releasing connection " invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-interface {v0, v1}, Lorg/apache/commons/logging/Log;->debug(Ljava/lang/Object;)V .line 5 :cond_0 check-cast p1, Lorg/apache/http/impl/conn/SingleClientConnManager$ConnAdapter; .line 6 iget-object v0, p1, Lorg/apache/http/impl/conn/AbstractPooledConnAdapter;->poolEntry:Lorg/apache/http/impl/conn/AbstractPoolEntry; :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_1 if-nez v0, :cond_1 .line 7 monitor-exit p0 return-void .line 8 :cond_1 :try_start_1 invoke-virtual {p1}, Lorg/apache/http/impl/conn/AbstractClientConnAdapter;->getManager()Lorg/apache/http/conn/ClientConnectionManager; move-result-object v0 if-eqz v0, :cond_3 if-ne v0, p0, :cond_2 goto :goto_0 .line 9 :cond_2 new-instance p1, Ljava/lang/IllegalArgumentException; const-string p2, "Connection not obtained from this manager." invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V throw p1 :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_1 :cond_3 :goto_0 const-wide v0, 0x7fffffffffffffffL const-wide/16 v2, 0x0 const/4 v4, 0x0 .line 10 :try_start_2 invoke-virtual {p1}, Lorg/apache/http/impl/conn/AbstractClientConnAdapter;->isOpen()Z move-result v5 if-eqz v5, :cond_6 iget-boolean v5, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->alwaysShutDown:Z if-nez v5, :cond_4 invoke-virtual {p1}, Lorg/apache/http/impl/conn/AbstractClientConnAdapter;->isMarkedReusable()Z move-result v5 if-nez v5, :cond_6 .line 11 :cond_4 iget-object v5, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->log:Lorg/apache/commons/logging/Log; invoke-interface {v5}, Lorg/apache/commons/logging/Log;->isDebugEnabled()Z move-result v5 if-eqz v5, :cond_5 .line 12 iget-object v5, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->log:Lorg/apache/commons/logging/Log; const-string v6, "Released connection open but not reusable." invoke-interface {v5, v6}, Lorg/apache/commons/logging/Log;->debug(Ljava/lang/Object;)V .line 13 :cond_5 invoke-virtual {p1}, Lorg/apache/http/impl/conn/AbstractPooledConnAdapter;->shutdown()V :try_end_2 .catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_0 .catchall {:try_start_2 .. :try_end_2} :catchall_0 .line 14 :cond_6 :try_start_3 invoke-virtual {p1}, Lorg/apache/http/impl/conn/AbstractPooledConnAdapter;->detach()V .line 15 iput-object v4, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->managedConn:Lorg/apache/http/impl/conn/SingleClientConnManager$ConnAdapter; .line 16 invoke-static {}, Ljava/lang/System;->currentTimeMillis()J move-result-wide v4 iput-wide v4, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->lastReleaseTime:J cmp-long p1, p2, v2 if-lez p1, :cond_7 .line 17 invoke-virtual {p4, p2, p3}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J move-result-wide p1 iget-wide p3, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->lastReleaseTime:J :goto_1 add-long/2addr p1, p3 iput-wide p1, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->connectionExpiresTime:J goto :goto_2 .line 18 :cond_7 iput-wide v0, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->connectionExpiresTime:J :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_1 goto :goto_2 :catchall_0 move-exception v5 goto :goto_3 :catch_0 move-exception v5 .line 19 :try_start_4 iget-object v6, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->log:Lorg/apache/commons/logging/Log; invoke-interface {v6}, Lorg/apache/commons/logging/Log;->isDebugEnabled()Z move-result v6 if-eqz v6, :cond_8 .line 20 iget-object v6, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->log:Lorg/apache/commons/logging/Log; const-string v7, "Exception shutting down released connection." invoke-interface {v6, v7, v5}, Lorg/apache/commons/logging/Log;->debug(Ljava/lang/Object;Ljava/lang/Throwable;)V :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_0 .line 21 :cond_8 :try_start_5 invoke-virtual {p1}, Lorg/apache/http/impl/conn/AbstractPooledConnAdapter;->detach()V .line 22 iput-object v4, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->managedConn:Lorg/apache/http/impl/conn/SingleClientConnManager$ConnAdapter; .line 23 invoke-static {}, Ljava/lang/System;->currentTimeMillis()J move-result-wide v4 iput-wide v4, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->lastReleaseTime:J cmp-long p1, p2, v2 if-lez p1, :cond_7 .line 24 invoke-virtual {p4, p2, p3}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J move-result-wide p1 iget-wide p3, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->lastReleaseTime:J :try_end_5 .catchall {:try_start_5 .. :try_end_5} :catchall_1 goto :goto_1 .line 25 :goto_2 monitor-exit p0 return-void .line 26 :goto_3 :try_start_6 invoke-virtual {p1}, Lorg/apache/http/impl/conn/AbstractPooledConnAdapter;->detach()V .line 27 iput-object v4, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->managedConn:Lorg/apache/http/impl/conn/SingleClientConnManager$ConnAdapter; .line 28 invoke-static {}, Ljava/lang/System;->currentTimeMillis()J move-result-wide v6 iput-wide v6, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->lastReleaseTime:J cmp-long p1, p2, v2 if-lez p1, :cond_9 .line 29 invoke-virtual {p4, p2, p3}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J move-result-wide p1 iget-wide p3, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->lastReleaseTime:J add-long/2addr p1, p3 iput-wide p1, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->connectionExpiresTime:J goto :goto_4 .line 30 :cond_9 iput-wide v0, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->connectionExpiresTime:J :goto_4 throw v5 .line 31 :cond_a new-instance p1, Ljava/lang/IllegalArgumentException; const-string p2, "Connection class mismatch, connection not obtained from this manager." invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V throw p1 :try_end_6 .catchall {:try_start_6 .. :try_end_6} :catchall_1 :catchall_1 move-exception p1 monitor-exit p0 throw p1 .end method .method public final requestConnection(Lorg/apache/http/conn/routing/HttpRoute;Ljava/lang/Object;)Lorg/apache/http/conn/ClientConnectionRequest; .locals 1 .line 1 new-instance v0, Lorg/apache/http/impl/conn/SingleClientConnManager$1; invoke-direct {v0, p0, p1, p2}, Lorg/apache/http/impl/conn/SingleClientConnManager$1;->(Lorg/apache/http/impl/conn/SingleClientConnManager;Lorg/apache/http/conn/routing/HttpRoute;Ljava/lang/Object;)V return-object v0 .end method .method public declared-synchronized revokeConnection()V .locals 3 .annotation runtime Ljava/lang/Deprecated; .end annotation monitor-enter p0 .line 1 :try_start_0 iget-object v0, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->managedConn:Lorg/apache/http/impl/conn/SingleClientConnManager$ConnAdapter; :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 if-nez v0, :cond_0 .line 2 monitor-exit p0 return-void .line 3 :cond_0 :try_start_1 invoke-virtual {v0}, Lorg/apache/http/impl/conn/AbstractPooledConnAdapter;->detach()V :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 .line 4 :try_start_2 iget-object v0, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->uniquePoolEntry:Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry; invoke-virtual {v0}, Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry;->shutdown()V :try_end_2 .catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_0 .catchall {:try_start_2 .. :try_end_2} :catchall_0 goto :goto_0 :catch_0 move-exception v0 .line 5 :try_start_3 iget-object v1, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->log:Lorg/apache/commons/logging/Log; const-string v2, "Problem while shutting down connection." invoke-interface {v1, v2, v0}, Lorg/apache/commons/logging/Log;->debug(Ljava/lang/Object;Ljava/lang/Throwable;)V :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_0 .line 6 :goto_0 monitor-exit p0 return-void :catchall_0 move-exception v0 monitor-exit p0 throw v0 .end method .method public declared-synchronized shutdown()V .locals 4 monitor-enter p0 const/4 v0, 0x1 .line 1 :try_start_0 iput-boolean v0, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->isShutDown:Z .line 2 iget-object v0, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->managedConn:Lorg/apache/http/impl/conn/SingleClientConnManager$ConnAdapter; if-eqz v0, :cond_0 .line 3 invoke-virtual {v0}, Lorg/apache/http/impl/conn/AbstractPooledConnAdapter;->detach()V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_1 :cond_0 const/4 v0, 0x0 .line 4 :try_start_1 iget-object v1, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->uniquePoolEntry:Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry; if-eqz v1, :cond_1 .line 5 invoke-virtual {v1}, Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry;->shutdown()V :try_end_1 .catch Ljava/io/IOException; {:try_start_1 .. :try_end_1} :catch_0 .catchall {:try_start_1 .. :try_end_1} :catchall_0 .line 6 :cond_1 :goto_0 :try_start_2 iput-object v0, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->uniquePoolEntry:Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry; :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_1 goto :goto_1 :catchall_0 move-exception v1 goto :goto_2 :catch_0 move-exception v1 .line 7 :try_start_3 iget-object v2, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->log:Lorg/apache/commons/logging/Log; const-string v3, "Problem while shutting down manager." invoke-interface {v2, v3, v1}, Lorg/apache/commons/logging/Log;->debug(Ljava/lang/Object;Ljava/lang/Throwable;)V :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_0 goto :goto_0 .line 8 :goto_1 monitor-exit p0 return-void .line 9 :goto_2 :try_start_4 iput-object v0, p0, Lorg/apache/http/impl/conn/SingleClientConnManager;->uniquePoolEntry:Lorg/apache/http/impl/conn/SingleClientConnManager$PoolEntry; throw v1 :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_1 :catchall_1 move-exception v0 monitor-exit p0 throw v0 .end method