.class public Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager; .super Ljava/lang/Object; .source "BasicHttpClientConnectionManager.java" # interfaces .implements Lorg/apache/http/conn/HttpClientConnectionManager; .implements Ljava/io/Closeable; # instance fields .field private conn:Lorg/apache/http/conn/ManagedHttpClientConnection; .field private connConfig:Lorg/apache/http/config/ConnectionConfig; .field private final connFactory:Lorg/apache/http/conn/HttpConnectionFactory; .annotation system Ldalvik/annotation/Signature; value = { "Lorg/apache/http/conn/HttpConnectionFactory<", "Lorg/apache/http/conn/routing/HttpRoute;", "Lorg/apache/http/conn/ManagedHttpClientConnection;", ">;" } .end annotation .end field .field private final connectionOperator:Lorg/apache/http/conn/HttpClientConnectionOperator; .field private expiry:J .field private final isShutdown:Ljava/util/concurrent/atomic/AtomicBoolean; .field private leased:Z .field private final log:Lorg/apache/commons/logging/Log; .field private route:Lorg/apache/http/conn/routing/HttpRoute; .field private socketConfig:Lorg/apache/http/config/SocketConfig; .field private state:Ljava/lang/Object; .field private updated:J # direct methods .method public constructor ()V .registers 3 .line 146 invoke-static {}, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->getDefaultRegistry()Lorg/apache/http/config/Registry; move-result-object v0 const/4 v1, 0x0 invoke-direct {p0, v0, v1, v1, v1}, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->(Lorg/apache/http/config/Lookup;Lorg/apache/http/conn/HttpConnectionFactory;Lorg/apache/http/conn/SchemePortResolver;Lorg/apache/http/conn/DnsResolver;)V return-void .end method .method public constructor (Lorg/apache/http/config/Lookup;)V .registers 3 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lorg/apache/http/config/Lookup<", "Lorg/apache/http/conn/socket/ConnectionSocketFactory;", ">;)V" } .end annotation const/4 v0, 0x0 .line 142 invoke-direct {p0, p1, v0, v0, v0}, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->(Lorg/apache/http/config/Lookup;Lorg/apache/http/conn/HttpConnectionFactory;Lorg/apache/http/conn/SchemePortResolver;Lorg/apache/http/conn/DnsResolver;)V return-void .end method .method public constructor (Lorg/apache/http/config/Lookup;Lorg/apache/http/conn/HttpConnectionFactory;)V .registers 4 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lorg/apache/http/config/Lookup<", "Lorg/apache/http/conn/socket/ConnectionSocketFactory;", ">;", "Lorg/apache/http/conn/HttpConnectionFactory<", "Lorg/apache/http/conn/routing/HttpRoute;", "Lorg/apache/http/conn/ManagedHttpClientConnection;", ">;)V" } .end annotation const/4 v0, 0x0 .line 137 invoke-direct {p0, p1, p2, v0, v0}, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->(Lorg/apache/http/config/Lookup;Lorg/apache/http/conn/HttpConnectionFactory;Lorg/apache/http/conn/SchemePortResolver;Lorg/apache/http/conn/DnsResolver;)V return-void .end method .method public constructor (Lorg/apache/http/config/Lookup;Lorg/apache/http/conn/HttpConnectionFactory;Lorg/apache/http/conn/SchemePortResolver;Lorg/apache/http/conn/DnsResolver;)V .registers 6 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lorg/apache/http/config/Lookup<", "Lorg/apache/http/conn/socket/ConnectionSocketFactory;", ">;", "Lorg/apache/http/conn/HttpConnectionFactory<", "Lorg/apache/http/conn/routing/HttpRoute;", "Lorg/apache/http/conn/ManagedHttpClientConnection;", ">;", "Lorg/apache/http/conn/SchemePortResolver;", "Lorg/apache/http/conn/DnsResolver;", ")V" } .end annotation .line 113 new-instance v0, Lorg/apache/http/impl/conn/DefaultHttpClientConnectionOperator; invoke-direct {v0, p1, p3, p4}, Lorg/apache/http/impl/conn/DefaultHttpClientConnectionOperator;->(Lorg/apache/http/config/Lookup;Lorg/apache/http/conn/SchemePortResolver;Lorg/apache/http/conn/DnsResolver;)V invoke-direct {p0, v0, p2}, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->(Lorg/apache/http/conn/HttpClientConnectionOperator;Lorg/apache/http/conn/HttpConnectionFactory;)V return-void .end method .method public constructor (Lorg/apache/http/conn/HttpClientConnectionOperator;Lorg/apache/http/conn/HttpConnectionFactory;)V .registers 4 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lorg/apache/http/conn/HttpClientConnectionOperator;", "Lorg/apache/http/conn/HttpConnectionFactory<", "Lorg/apache/http/conn/routing/HttpRoute;", "Lorg/apache/http/conn/ManagedHttpClientConnection;", ">;)V" } .end annotation .line 125 invoke-direct {p0}, Ljava/lang/Object;->()V .line 85 invoke-virtual {p0}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object v0 invoke-static {v0}, Lorg/apache/commons/logging/LogFactory;->getLog(Ljava/lang/Class;)Lorg/apache/commons/logging/Log; move-result-object v0 iput-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->log:Lorg/apache/commons/logging/Log; .line 126 const-string v0, "Connection operator" invoke-static {p1, v0}, Lorg/apache/http/util/Args;->notNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object; move-result-object p1 check-cast p1, Lorg/apache/http/conn/HttpClientConnectionOperator; iput-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->connectionOperator:Lorg/apache/http/conn/HttpClientConnectionOperator; if-eqz p2, :cond_1a goto :goto_1c .line 127 :cond_1a sget-object p2, Lorg/apache/http/impl/conn/ManagedHttpClientConnectionFactory;->INSTANCE:Lorg/apache/http/impl/conn/ManagedHttpClientConnectionFactory; :goto_1c iput-object p2, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->connFactory:Lorg/apache/http/conn/HttpConnectionFactory; const-wide p1, 0x7fffffffffffffffL .line 128 iput-wide p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->expiry:J .line 129 sget-object p1, Lorg/apache/http/config/SocketConfig;->DEFAULT:Lorg/apache/http/config/SocketConfig; iput-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->socketConfig:Lorg/apache/http/config/SocketConfig; .line 130 sget-object p1, Lorg/apache/http/config/ConnectionConfig;->DEFAULT:Lorg/apache/http/config/ConnectionConfig; iput-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->connConfig:Lorg/apache/http/config/ConnectionConfig; .line 131 new-instance p1, Ljava/util/concurrent/atomic/AtomicBoolean; const/4 p2, 0x0 invoke-direct {p1, p2}, Ljava/util/concurrent/atomic/AtomicBoolean;->(Z)V iput-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->isShutdown:Ljava/util/concurrent/atomic/AtomicBoolean; return-void .end method .method private checkExpiry()V .registers 6 .line 226 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->conn:Lorg/apache/http/conn/ManagedHttpClientConnection; if-eqz v0, :cond_34 invoke-static {}, Ljava/lang/System;->currentTimeMillis()J move-result-wide v0 iget-wide v2, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->expiry:J cmp-long v0, v0, v2 if-ltz v0, :cond_34 .line 227 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->log:Lorg/apache/commons/logging/Log; invoke-interface {v0}, Lorg/apache/commons/logging/Log;->isDebugEnabled()Z move-result v0 if-eqz v0, :cond_31 .line 228 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->log:Lorg/apache/commons/logging/Log; new-instance v1, Ljava/lang/StringBuilder; const-string v2, "Connection expired @ " invoke-direct {v1, v2}, Ljava/lang/StringBuilder;->(Ljava/lang/String;)V new-instance v2, Ljava/util/Date; iget-wide v3, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->expiry:J invoke-direct {v2, v3, v4}, Ljava/util/Date;->(J)V invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; move-result-object v1 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 230 :cond_31 invoke-direct {p0}, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->closeConnection()V :cond_34 return-void .end method .method private declared-synchronized closeConnection()V .registers 4 monitor-enter p0 .line 212 :try_start_1 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->conn:Lorg/apache/http/conn/ManagedHttpClientConnection; if-eqz v0, :cond_25 .line 213 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->log:Lorg/apache/commons/logging/Log; const-string v1, "Closing connection" invoke-interface {v0, v1}, Lorg/apache/commons/logging/Log;->debug(Ljava/lang/Object;)V :try_end_c .catchall {:try_start_1 .. :try_end_c} :catchall_27 .line 215 :try_start_c iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->conn:Lorg/apache/http/conn/ManagedHttpClientConnection; invoke-interface {v0}, Lorg/apache/http/conn/ManagedHttpClientConnection;->close()V :try_end_11 .catch Ljava/io/IOException; {:try_start_c .. :try_end_11} :catch_12 .catchall {:try_start_c .. :try_end_11} :catchall_27 goto :goto_22 :catch_12 move-exception v0 .line 217 :try_start_13 iget-object v1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->log:Lorg/apache/commons/logging/Log; invoke-interface {v1}, Lorg/apache/commons/logging/Log;->isDebugEnabled()Z move-result v1 if-eqz v1, :cond_22 .line 218 iget-object v1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->log:Lorg/apache/commons/logging/Log; const-string v2, "I/O exception closing connection" invoke-interface {v1, v2, v0}, Lorg/apache/commons/logging/Log;->debug(Ljava/lang/Object;Ljava/lang/Throwable;)V :cond_22 :goto_22 const/4 v0, 0x0 .line 221 iput-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->conn:Lorg/apache/http/conn/ManagedHttpClientConnection; :try_end_25 .catchall {:try_start_13 .. :try_end_25} :catchall_27 .line 223 :cond_25 monitor-exit p0 return-void :catchall_27 move-exception v0 :try_start_28 monitor-exit p0 :try_end_29 .catchall {:try_start_28 .. :try_end_29} :catchall_27 throw v0 .end method .method private static getDefaultRegistry()Lorg/apache/http/config/Registry; .registers 3 .annotation system Ldalvik/annotation/Signature; value = { "()", "Lorg/apache/http/config/Registry<", "Lorg/apache/http/conn/socket/ConnectionSocketFactory;", ">;" } .end annotation .line 102 invoke-static {}, Lorg/apache/http/config/RegistryBuilder;->create()Lorg/apache/http/config/RegistryBuilder; move-result-object v0 const-string v1, "http" invoke-static {}, Lorg/apache/http/conn/socket/PlainConnectionSocketFactory;->getSocketFactory()Lorg/apache/http/conn/socket/PlainConnectionSocketFactory; move-result-object v2 invoke-virtual {v0, v1, v2}, Lorg/apache/http/config/RegistryBuilder;->register(Ljava/lang/String;Ljava/lang/Object;)Lorg/apache/http/config/RegistryBuilder; move-result-object v0 const-string v1, "https" invoke-static {}, Lorg/apache/http/conn/ssl/SSLConnectionSocketFactory;->getSocketFactory()Lorg/apache/http/conn/ssl/SSLConnectionSocketFactory; move-result-object v2 invoke-virtual {v0, v1, v2}, Lorg/apache/http/config/RegistryBuilder;->register(Ljava/lang/String;Ljava/lang/Object;)Lorg/apache/http/config/RegistryBuilder; move-result-object v0 invoke-virtual {v0}, Lorg/apache/http/config/RegistryBuilder;->build()Lorg/apache/http/config/Registry; move-result-object v0 return-object v0 .end method # virtual methods .method public close()V .registers 4 .line 160 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->isShutdown:Ljava/util/concurrent/atomic/AtomicBoolean; const/4 v1, 0x0 const/4 v2, 0x1 invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/atomic/AtomicBoolean;->compareAndSet(ZZ)Z move-result v0 if-eqz v0, :cond_d .line 161 invoke-direct {p0}, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->closeConnection()V :cond_d return-void .end method .method public declared-synchronized closeExpiredConnections()V .registers 2 monitor-enter p0 .line 337 :try_start_1 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->isShutdown:Ljava/util/concurrent/atomic/AtomicBoolean; invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicBoolean;->get()Z move-result v0 :try_end_7 .catchall {:try_start_1 .. :try_end_7} :catchall_14 if-eqz v0, :cond_b .line 338 monitor-exit p0 return-void .line 340 :cond_b :try_start_b iget-boolean v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->leased:Z if-nez v0, :cond_12 .line 341 invoke-direct {p0}, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->checkExpiry()V :try_end_12 .catchall {:try_start_b .. :try_end_12} :catchall_14 .line 343 :cond_12 monitor-exit p0 return-void :catchall_14 move-exception v0 :try_start_15 monitor-exit p0 :try_end_16 .catchall {:try_start_15 .. :try_end_16} :catchall_14 throw v0 .end method .method public declared-synchronized closeIdleConnections(JLjava/util/concurrent/TimeUnit;)V .registers 6 monitor-enter p0 .line 347 :try_start_1 const-string v0, "Time unit" invoke-static {p3, v0}, Lorg/apache/http/util/Args;->notNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object; .line 348 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->isShutdown:Ljava/util/concurrent/atomic/AtomicBoolean; invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicBoolean;->get()Z move-result v0 :try_end_c .catchall {:try_start_1 .. :try_end_c} :catchall_2f if-eqz v0, :cond_10 .line 349 monitor-exit p0 return-void .line 351 :cond_10 :try_start_10 iget-boolean v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->leased:Z if-nez v0, :cond_2d .line 352 invoke-virtual {p3, p1, p2}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J move-result-wide p1 const-wide/16 v0, 0x0 cmp-long p3, p1, v0 if-gez p3, :cond_1f move-wide p1, v0 .line 356 :cond_1f invoke-static {}, Ljava/lang/System;->currentTimeMillis()J move-result-wide v0 sub-long/2addr v0, p1 .line 357 iget-wide p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->updated:J cmp-long p1, p1, v0 if-gtz p1, :cond_2d .line 358 invoke-direct {p0}, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->closeConnection()V :try_end_2d .catchall {:try_start_10 .. :try_end_2d} :catchall_2f .line 361 :cond_2d monitor-exit p0 return-void :catchall_2f move-exception p1 :try_start_30 monitor-exit p0 :try_end_31 .catchall {:try_start_30 .. :try_end_31} :catchall_2f throw p1 .end method .method public connect(Lorg/apache/http/HttpClientConnection;Lorg/apache/http/conn/routing/HttpRoute;ILorg/apache/http/protocol/HttpContext;)V .registers 12 .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation .line 303 const-string v0, "Connection" invoke-static {p1, v0}, Lorg/apache/http/util/Args;->notNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object; .line 304 const-string v0, "HTTP route" invoke-static {p2, v0}, Lorg/apache/http/util/Args;->notNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object; .line 305 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->conn:Lorg/apache/http/conn/ManagedHttpClientConnection; if-ne p1, v0, :cond_10 const/4 p1, 0x1 goto :goto_11 :cond_10 const/4 p1, 0x0 :goto_11 const-string v0, "Connection not obtained from this manager" invoke-static {p1, v0}, Lorg/apache/http/util/Asserts;->check(ZLjava/lang/String;)V .line 307 invoke-virtual {p2}, Lorg/apache/http/conn/routing/HttpRoute;->getProxyHost()Lorg/apache/http/HttpHost; move-result-object p1 if-eqz p1, :cond_21 .line 308 invoke-virtual {p2}, Lorg/apache/http/conn/routing/HttpRoute;->getProxyHost()Lorg/apache/http/HttpHost; move-result-object p1 goto :goto_25 .line 310 :cond_21 invoke-virtual {p2}, Lorg/apache/http/conn/routing/HttpRoute;->getTargetHost()Lorg/apache/http/HttpHost; move-result-object p1 :goto_25 move-object v2, p1 .line 312 invoke-virtual {p2}, Lorg/apache/http/conn/routing/HttpRoute;->getLocalSocketAddress()Ljava/net/InetSocketAddress; move-result-object v3 .line 313 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->connectionOperator:Lorg/apache/http/conn/HttpClientConnectionOperator; iget-object v1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->conn:Lorg/apache/http/conn/ManagedHttpClientConnection; iget-object v5, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->socketConfig:Lorg/apache/http/config/SocketConfig; move v4, p3 move-object v6, p4 invoke-interface/range {v0 .. v6}, Lorg/apache/http/conn/HttpClientConnectionOperator;->connect(Lorg/apache/http/conn/ManagedHttpClientConnection;Lorg/apache/http/HttpHost;Ljava/net/InetSocketAddress;ILorg/apache/http/config/SocketConfig;Lorg/apache/http/protocol/HttpContext;)V return-void .end method .method protected finalize()V .registers 2 .annotation system Ldalvik/annotation/Throws; value = { Ljava/lang/Throwable; } .end annotation .line 152 :try_start_0 invoke-virtual {p0}, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->shutdown()V :try_end_3 .catchall {:try_start_0 .. :try_end_3} :catchall_7 .line 154 invoke-super {p0}, Ljava/lang/Object;->finalize()V return-void :catchall_7 move-exception v0 invoke-super {p0}, Ljava/lang/Object;->finalize()V throw v0 .end method .method declared-synchronized getConnection(Lorg/apache/http/conn/routing/HttpRoute;Ljava/lang/Object;)Lorg/apache/http/HttpClientConnection; .registers 7 const-string v0, "Get connection for route " monitor-enter p0 .line 235 :try_start_3 iget-object v1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->isShutdown:Ljava/util/concurrent/atomic/AtomicBoolean; invoke-virtual {v1}, Ljava/util/concurrent/atomic/AtomicBoolean;->get()Z move-result v1 const/4 v2, 0x1 xor-int/2addr v1, v2 const-string v3, "Connection manager has been shut down" invoke-static {v1, v3}, Lorg/apache/http/util/Asserts;->check(ZLjava/lang/String;)V .line 236 iget-object v1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->log:Lorg/apache/commons/logging/Log; invoke-interface {v1}, Lorg/apache/commons/logging/Log;->isDebugEnabled()Z move-result v1 if-eqz v1, :cond_2a .line 237 iget-object v1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->log:Lorg/apache/commons/logging/Log; new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3, v0}, Ljava/lang/StringBuilder;->(Ljava/lang/String;)V invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; move-result-object v0 invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 invoke-interface {v1, v0}, Lorg/apache/commons/logging/Log;->debug(Ljava/lang/Object;)V .line 239 :cond_2a iget-boolean v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->leased:Z xor-int/2addr v0, v2 const-string v1, "Connection is still allocated" invoke-static {v0, v1}, Lorg/apache/http/util/Asserts;->check(ZLjava/lang/String;)V .line 240 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->route:Lorg/apache/http/conn/routing/HttpRoute; invoke-static {v0, p1}, Lorg/apache/http/util/LangUtils;->equals(Ljava/lang/Object;Ljava/lang/Object;)Z move-result v0 if-eqz v0, :cond_42 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->state:Ljava/lang/Object; invoke-static {v0, p2}, Lorg/apache/http/util/LangUtils;->equals(Ljava/lang/Object;Ljava/lang/Object;)Z move-result v0 if-nez v0, :cond_45 .line 241 :cond_42 invoke-direct {p0}, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->closeConnection()V .line 243 :cond_45 iput-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->route:Lorg/apache/http/conn/routing/HttpRoute; .line 244 iput-object p2, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->state:Ljava/lang/Object; .line 245 invoke-direct {p0}, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->checkExpiry()V .line 246 iget-object p2, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->conn:Lorg/apache/http/conn/ManagedHttpClientConnection; if-nez p2, :cond_5c .line 247 iget-object p2, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->connFactory:Lorg/apache/http/conn/HttpConnectionFactory; iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->connConfig:Lorg/apache/http/config/ConnectionConfig; invoke-interface {p2, p1, v0}, Lorg/apache/http/conn/HttpConnectionFactory;->create(Ljava/lang/Object;Lorg/apache/http/config/ConnectionConfig;)Lorg/apache/http/HttpConnection; move-result-object p1 check-cast p1, Lorg/apache/http/conn/ManagedHttpClientConnection; iput-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->conn:Lorg/apache/http/conn/ManagedHttpClientConnection; .line 249 :cond_5c iget-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->conn:Lorg/apache/http/conn/ManagedHttpClientConnection; iget-object p2, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->socketConfig:Lorg/apache/http/config/SocketConfig; invoke-virtual {p2}, Lorg/apache/http/config/SocketConfig;->getSoTimeout()I move-result p2 invoke-interface {p1, p2}, Lorg/apache/http/conn/ManagedHttpClientConnection;->setSocketTimeout(I)V .line 250 iput-boolean v2, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->leased:Z .line 251 iget-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->conn:Lorg/apache/http/conn/ManagedHttpClientConnection; :try_end_6b .catchall {:try_start_3 .. :try_end_6b} :catchall_6d monitor-exit p0 return-object p1 :catchall_6d move-exception p1 :try_start_6e monitor-exit p0 :try_end_6f .catchall {:try_start_6e .. :try_end_6f} :catchall_6d throw p1 .end method .method public declared-synchronized getConnectionConfig()Lorg/apache/http/config/ConnectionConfig; .registers 2 monitor-enter p0 .line 182 :try_start_1 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->connConfig:Lorg/apache/http/config/ConnectionConfig; :try_end_3 .catchall {:try_start_1 .. :try_end_3} :catchall_5 monitor-exit p0 return-object v0 :catchall_5 move-exception v0 :try_start_6 monitor-exit p0 :try_end_7 .catchall {:try_start_6 .. :try_end_7} :catchall_5 throw v0 .end method .method getRoute()Lorg/apache/http/conn/routing/HttpRoute; .registers 2 .line 166 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->route:Lorg/apache/http/conn/routing/HttpRoute; return-object v0 .end method .method public declared-synchronized getSocketConfig()Lorg/apache/http/config/SocketConfig; .registers 2 monitor-enter p0 .line 174 :try_start_1 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->socketConfig:Lorg/apache/http/config/SocketConfig; :try_end_3 .catchall {:try_start_1 .. :try_end_3} :catchall_5 monitor-exit p0 return-object v0 :catchall_5 move-exception v0 :try_start_6 monitor-exit p0 :try_end_7 .catchall {:try_start_6 .. :try_end_7} :catchall_5 throw v0 .end method .method getState()Ljava/lang/Object; .registers 2 .line 170 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->state:Ljava/lang/Object; return-object v0 .end method .method public declared-synchronized releaseConnection(Lorg/apache/http/HttpClientConnection;Ljava/lang/Object;JLjava/util/concurrent/TimeUnit;)V .registers 13 const-string v0, "Connection can be kept alive " const-string v1, "for " const-string v2, "Releasing connection " monitor-enter p0 .line 259 :try_start_7 const-string v3, "Connection" invoke-static {p1, v3}, Lorg/apache/http/util/Args;->notNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object; .line 260 iget-object v3, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->conn:Lorg/apache/http/conn/ManagedHttpClientConnection; const/4 v4, 0x0 if-ne p1, v3, :cond_13 const/4 v3, 0x1 goto :goto_14 :cond_13 move v3, v4 :goto_14 const-string v5, "Connection not obtained from this manager" invoke-static {v3, v5}, Lorg/apache/http/util/Asserts;->check(ZLjava/lang/String;)V .line 261 iget-object v3, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->log:Lorg/apache/commons/logging/Log; invoke-interface {v3}, Lorg/apache/commons/logging/Log;->isDebugEnabled()Z move-result v3 if-eqz v3, :cond_33 .line 262 iget-object v3, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->log:Lorg/apache/commons/logging/Log; new-instance v5, Ljava/lang/StringBuilder; invoke-direct {v5, v2}, Ljava/lang/StringBuilder;->(Ljava/lang/String;)V invoke-virtual {v5, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; move-result-object p1 invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 invoke-interface {v3, p1}, Lorg/apache/commons/logging/Log;->debug(Ljava/lang/Object;)V .line 264 :cond_33 iget-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->isShutdown:Ljava/util/concurrent/atomic/AtomicBoolean; invoke-virtual {p1}, Ljava/util/concurrent/atomic/AtomicBoolean;->get()Z move-result p1 :try_end_39 .catchall {:try_start_7 .. :try_end_39} :catchall_b1 if-eqz p1, :cond_3d .line 265 monitor-exit p0 return-void .line 268 :cond_3d :try_start_3d invoke-static {}, Ljava/lang/System;->currentTimeMillis()J move-result-wide v2 iput-wide v2, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->updated:J .line 269 iget-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->conn:Lorg/apache/http/conn/ManagedHttpClientConnection; invoke-interface {p1}, Lorg/apache/http/conn/ManagedHttpClientConnection;->isOpen()Z move-result p1 const-wide v2, 0x7fffffffffffffffL if-nez p1, :cond_58 const/4 p1, 0x0 .line 271 iput-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->route:Lorg/apache/http/conn/routing/HttpRoute; .line 272 iput-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->conn:Lorg/apache/http/conn/ManagedHttpClientConnection; .line 273 iput-wide v2, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->expiry:J goto :goto_a9 .line 275 :cond_58 iput-object p2, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->state:Ljava/lang/Object; .line 276 iget-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->conn:Lorg/apache/http/conn/ManagedHttpClientConnection; invoke-interface {p1, v4}, Lorg/apache/http/conn/ManagedHttpClientConnection;->setSocketTimeout(I)V .line 277 iget-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->log:Lorg/apache/commons/logging/Log; invoke-interface {p1}, Lorg/apache/commons/logging/Log;->isDebugEnabled()Z move-result p1 const-wide/16 v5, 0x0 if-eqz p1, :cond_99 cmp-long p1, p3, v5 if-lez p1, :cond_85 .line 280 new-instance p1, Ljava/lang/StringBuilder; invoke-direct {p1, v1}, Ljava/lang/StringBuilder;->(Ljava/lang/String;)V invoke-virtual {p1, p3, p4}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder; move-result-object p1 const-string p2, " " invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object p1 invoke-virtual {p1, p5}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; move-result-object p1 invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 goto :goto_87 .line 282 :cond_85 const-string p1, "indefinitely" .line 284 :goto_87 iget-object p2, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->log:Lorg/apache/commons/logging/Log; new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1, v0}, Ljava/lang/StringBuilder;->(Ljava/lang/String;)V invoke-virtual {v1, p1}, 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 invoke-interface {p2, p1}, Lorg/apache/commons/logging/Log;->debug(Ljava/lang/Object;)V :cond_99 cmp-long p1, p3, v5 if-lez p1, :cond_a7 .line 287 iget-wide p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->updated:J invoke-virtual {p5, p3, p4}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J move-result-wide p3 add-long/2addr p1, p3 iput-wide p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->expiry:J goto :goto_a9 .line 289 :cond_a7 iput-wide v2, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->expiry:J :try_end_a9 .catchall {:try_start_3d .. :try_end_a9} :catchall_ad .line 293 :goto_a9 :try_start_a9 iput-boolean v4, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->leased:Z :try_end_ab .catchall {:try_start_a9 .. :try_end_ab} :catchall_b1 .line 295 monitor-exit p0 return-void :catchall_ad move-exception p1 .line 293 :try_start_ae iput-boolean v4, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->leased:Z throw p1 :catchall_b1 move-exception p1 monitor-exit p0 :try_end_b3 .catchall {:try_start_ae .. :try_end_b3} :catchall_b1 throw p1 .end method .method public final requestConnection(Lorg/apache/http/conn/routing/HttpRoute;Ljava/lang/Object;)Lorg/apache/http/conn/ConnectionRequest; .registers 4 .line 193 const-string v0, "Route" invoke-static {p1, v0}, Lorg/apache/http/util/Args;->notNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object; .line 194 new-instance v0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager$1; invoke-direct {v0, p0, p1, p2}, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager$1;->(Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;Lorg/apache/http/conn/routing/HttpRoute;Ljava/lang/Object;)V return-object v0 .end method .method public routeComplete(Lorg/apache/http/HttpClientConnection;Lorg/apache/http/conn/routing/HttpRoute;Lorg/apache/http/protocol/HttpContext;)V .registers 4 .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation return-void .end method .method public declared-synchronized setConnectionConfig(Lorg/apache/http/config/ConnectionConfig;)V .registers 2 monitor-enter p0 if-eqz p1, :cond_4 goto :goto_6 .line 186 :cond_4 :try_start_4 sget-object p1, Lorg/apache/http/config/ConnectionConfig;->DEFAULT:Lorg/apache/http/config/ConnectionConfig; :goto_6 iput-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->connConfig:Lorg/apache/http/config/ConnectionConfig; :try_end_8 .catchall {:try_start_4 .. :try_end_8} :catchall_a .line 187 monitor-exit p0 return-void :catchall_a move-exception p1 :try_start_b monitor-exit p0 :try_end_c .catchall {:try_start_b .. :try_end_c} :catchall_a throw p1 .end method .method public declared-synchronized setSocketConfig(Lorg/apache/http/config/SocketConfig;)V .registers 2 monitor-enter p0 if-eqz p1, :cond_4 goto :goto_6 .line 178 :cond_4 :try_start_4 sget-object p1, Lorg/apache/http/config/SocketConfig;->DEFAULT:Lorg/apache/http/config/SocketConfig; :goto_6 iput-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->socketConfig:Lorg/apache/http/config/SocketConfig; :try_end_8 .catchall {:try_start_4 .. :try_end_8} :catchall_a .line 179 monitor-exit p0 return-void :catchall_a move-exception p1 :try_start_b monitor-exit p0 :try_end_c .catchall {:try_start_b .. :try_end_c} :catchall_a throw p1 .end method .method public shutdown()V .registers 1 .line 365 invoke-virtual {p0}, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->close()V return-void .end method .method public upgrade(Lorg/apache/http/HttpClientConnection;Lorg/apache/http/conn/routing/HttpRoute;Lorg/apache/http/protocol/HttpContext;)V .registers 5 .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation .line 322 const-string v0, "Connection" invoke-static {p1, v0}, Lorg/apache/http/util/Args;->notNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object; .line 323 const-string v0, "HTTP route" invoke-static {p2, v0}, Lorg/apache/http/util/Args;->notNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object; .line 324 iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->conn:Lorg/apache/http/conn/ManagedHttpClientConnection; if-ne p1, v0, :cond_10 const/4 p1, 0x1 goto :goto_11 :cond_10 const/4 p1, 0x0 :goto_11 const-string v0, "Connection not obtained from this manager" invoke-static {p1, v0}, Lorg/apache/http/util/Asserts;->check(ZLjava/lang/String;)V .line 325 iget-object p1, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->connectionOperator:Lorg/apache/http/conn/HttpClientConnectionOperator; iget-object v0, p0, Lorg/apache/http/impl/conn/BasicHttpClientConnectionManager;->conn:Lorg/apache/http/conn/ManagedHttpClientConnection; invoke-virtual {p2}, Lorg/apache/http/conn/routing/HttpRoute;->getTargetHost()Lorg/apache/http/HttpHost; move-result-object p2 invoke-interface {p1, v0, p2, p3}, Lorg/apache/http/conn/HttpClientConnectionOperator;->upgrade(Lorg/apache/http/conn/ManagedHttpClientConnection;Lorg/apache/http/HttpHost;Lorg/apache/http/protocol/HttpContext;)V return-void .end method