RestAdapter$RestHandler.smali

.class Lretrofit/RestAdapter$RestHandler;
.super Ljava/lang/Object;
.source "RestAdapter.java"

# interfaces
.implements Ljava/lang/reflect/InvocationHandler;


# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
    value = Lretrofit/RestAdapter;
.end annotation

.annotation system Ldalvik/annotation/InnerClass;
    accessFlags = 0x2
    name = "RestHandler"
.end annotation


# instance fields
.field private final methodDetailsCache:Ljava/util/Map;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Map<",
            "Ljava/lang/reflect/Method;",
            "Lretrofit/RestMethodInfo;",
            ">;"
        }
    .end annotation
.end field

.field final synthetic this$0:Lretrofit/RestAdapter;


# direct methods
.method constructor <init>(Lretrofit/RestAdapter;Ljava/util/Map;)V
    .registers 3
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/util/Map<",
            "Ljava/lang/reflect/Method;",
            "Lretrofit/RestMethodInfo;",
            ">;)V"
        }
    .end annotation

    .line 223
    iput-object p1, p0, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 224
    iput-object p2, p0, Lretrofit/RestAdapter$RestHandler;->methodDetailsCache:Ljava/util/Map;

    return-void
.end method

.method static synthetic access$100(Lretrofit/RestAdapter$RestHandler;Lretrofit/RequestInterceptor;Lretrofit/RestMethodInfo;[Ljava/lang/Object;)Ljava/lang/Object;
    .registers 4

    .line 220
    invoke-direct {p0, p1, p2, p3}, Lretrofit/RestAdapter$RestHandler;->invokeRequest(Lretrofit/RequestInterceptor;Lretrofit/RestMethodInfo;[Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object p0

    return-object p0
.end method

.method private invokeRequest(Lretrofit/RequestInterceptor;Lretrofit/RestMethodInfo;[Ljava/lang/Object;)Ljava/lang/Object;
    .registers 20

    move-object/from16 v1, p0

    move-object/from16 v2, p2

    move-object/from16 v0, p3

    const-string v3, "Retrofit-Idle"

    const/4 v4, 0x0

    .line 294
    :try_start_9
    invoke-virtual/range {p2 .. p2}, Lretrofit/RestMethodInfo;->init()V

    .line 296
    iget-object v5, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object v5, v5, Lretrofit/RestAdapter;->server:Lretrofit/Endpoint;

    invoke-interface {v5}, Lretrofit/Endpoint;->getUrl()Ljava/lang/String;

    move-result-object v5

    .line 297
    new-instance v6, Lretrofit/RequestBuilder;

    iget-object v7, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object v7, v7, Lretrofit/RestAdapter;->converter:Lretrofit/converter/Converter;

    invoke-direct {v6, v5, v2, v7}, Lretrofit/RequestBuilder;-><init>(Ljava/lang/String;Lretrofit/RestMethodInfo;Lretrofit/converter/Converter;)V

    .line 298
    invoke-virtual {v6, v0}, Lretrofit/RequestBuilder;->setArguments([Ljava/lang/Object;)V

    move-object/from16 v7, p1

    .line 300
    invoke-interface {v7, v6}, Lretrofit/RequestInterceptor;->intercept(Lretrofit/RequestInterceptor$RequestFacade;)V

    .line 302
    invoke-virtual {v6}, Lretrofit/RequestBuilder;->build()Lretrofit/client/Request;

    move-result-object v6

    .line 303
    invoke-virtual {v6}, Lretrofit/client/Request;->getUrl()Ljava/lang/String;

    move-result-object v7
    :try_end_2d
    .catch Lretrofit/RetrofitError; {:try_start_9 .. :try_end_2d} :catch_1ae
    .catch Ljava/io/IOException; {:try_start_9 .. :try_end_2d} :catch_199
    .catchall {:try_start_9 .. :try_end_2d} :catchall_184

    .line 305
    :try_start_2d
    iget-boolean v8, v2, Lretrofit/RestMethodInfo;->isSynchronous:Z

    if-nez v8, :cond_51

    .line 307
    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object v8

    new-instance v9, Ljava/lang/StringBuilder;

    invoke-direct {v9}, Ljava/lang/StringBuilder;-><init>()V

    const-string v10, "Retrofit-"

    invoke-virtual {v9, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v5}, Ljava/lang/String;->length()I

    move-result v10

    invoke-virtual {v7, v10}, Ljava/lang/String;->substring(I)Ljava/lang/String;

    move-result-object v10

    invoke-virtual {v9, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v9}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v9

    invoke-virtual {v8, v9}, Ljava/lang/Thread;->setName(Ljava/lang/String;)V

    .line 310
    :cond_51
    iget-object v8, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object v8, v8, Lretrofit/RestAdapter;->logLevel:Lretrofit/RestAdapter$LogLevel;

    invoke-virtual {v8}, Lretrofit/RestAdapter$LogLevel;->log()Z

    move-result v8

    if-eqz v8, :cond_63

    .line 312
    iget-object v8, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    const-string v9, "HTTP"

    invoke-virtual {v8, v9, v6, v0}, Lretrofit/RestAdapter;->logAndReplaceRequest(Ljava/lang/String;Lretrofit/client/Request;[Ljava/lang/Object;)Lretrofit/client/Request;

    move-result-object v6

    .line 316
    :cond_63
    iget-object v0, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    # getter for: Lretrofit/RestAdapter;->profiler:Lretrofit/Profiler;
    invoke-static {v0}, Lretrofit/RestAdapter;->access$200(Lretrofit/RestAdapter;)Lretrofit/Profiler;

    move-result-object v0

    if-eqz v0, :cond_77

    .line 317
    iget-object v0, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    # getter for: Lretrofit/RestAdapter;->profiler:Lretrofit/Profiler;
    invoke-static {v0}, Lretrofit/RestAdapter;->access$200(Lretrofit/RestAdapter;)Lretrofit/Profiler;

    move-result-object v0

    invoke-interface {v0}, Lretrofit/Profiler;->beforeCall()Ljava/lang/Object;

    move-result-object v0

    move-object v13, v0

    goto :goto_78

    :cond_77
    move-object v13, v4

    .line 320
    :goto_78
    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v8

    .line 321
    iget-object v0, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    # getter for: Lretrofit/RestAdapter;->clientProvider:Lretrofit/client/Client$Provider;
    invoke-static {v0}, Lretrofit/RestAdapter;->access$300(Lretrofit/RestAdapter;)Lretrofit/client/Client$Provider;

    move-result-object v0

    invoke-interface {v0}, Lretrofit/client/Client$Provider;->get()Lretrofit/client/Client;

    move-result-object v0

    invoke-interface {v0, v6}, Lretrofit/client/Client;->execute(Lretrofit/client/Request;)Lretrofit/client/Response;

    move-result-object v0

    .line 322
    sget-object v10, Ljava/util/concurrent/TimeUnit;->NANOSECONDS:Ljava/util/concurrent/TimeUnit;

    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v11

    sub-long/2addr v11, v8

    invoke-virtual {v10, v11, v12}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J

    move-result-wide v14

    .line 324
    invoke-virtual {v0}, Lretrofit/client/Response;->getStatus()I

    move-result v12

    .line 325
    iget-object v8, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    # getter for: Lretrofit/RestAdapter;->profiler:Lretrofit/Profiler;
    invoke-static {v8}, Lretrofit/RestAdapter;->access$200(Lretrofit/RestAdapter;)Lretrofit/Profiler;

    move-result-object v8

    if-eqz v8, :cond_b1

    .line 326
    # invokes: Lretrofit/RestAdapter;->getRequestInfo(Ljava/lang/String;Lretrofit/RestMethodInfo;Lretrofit/client/Request;)Lretrofit/Profiler$RequestInformation;
    invoke-static {v5, v2, v6}, Lretrofit/RestAdapter;->access$400(Ljava/lang/String;Lretrofit/RestMethodInfo;Lretrofit/client/Request;)Lretrofit/Profiler$RequestInformation;

    move-result-object v9

    .line 328
    iget-object v5, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    # getter for: Lretrofit/RestAdapter;->profiler:Lretrofit/Profiler;
    invoke-static {v5}, Lretrofit/RestAdapter;->access$200(Lretrofit/RestAdapter;)Lretrofit/Profiler;

    move-result-object v8

    move-wide v10, v14

    move v5, v12

    invoke-interface/range {v8 .. v13}, Lretrofit/Profiler;->afterCall(Lretrofit/Profiler$RequestInformation;JILjava/lang/Object;)V

    goto :goto_b2

    :cond_b1
    move v5, v12

    .line 331
    :goto_b2
    iget-object v6, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object v6, v6, Lretrofit/RestAdapter;->logLevel:Lretrofit/RestAdapter$LogLevel;

    invoke-virtual {v6}, Lretrofit/RestAdapter$LogLevel;->log()Z

    move-result v6

    if-eqz v6, :cond_c2

    .line 333
    iget-object v6, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    # invokes: Lretrofit/RestAdapter;->logAndReplaceResponse(Ljava/lang/String;Lretrofit/client/Response;J)Lretrofit/client/Response;
    invoke-static {v6, v7, v0, v14, v15}, Lretrofit/RestAdapter;->access$500(Lretrofit/RestAdapter;Ljava/lang/String;Lretrofit/client/Response;J)Lretrofit/client/Response;

    move-result-object v0

    :cond_c2
    move-object v6, v0

    .line 336
    iget-object v8, v2, Lretrofit/RestMethodInfo;->responseObjectType:Ljava/lang/reflect/Type;

    const/16 v0, 0xc8

    if-lt v5, v0, :cond_171

    const/16 v0, 0x12c

    if-ge v5, v0, :cond_171

    .line 340
    const-class v0, Lretrofit/client/Response;

    invoke-virtual {v8, v0}, Ljava/lang/Object;->equals(Ljava/lang/Object;)Z

    move-result v0

    if-eqz v0, :cond_fe

    .line 341
    iget-boolean v0, v2, Lretrofit/RestMethodInfo;->isStreaming:Z

    if-nez v0, :cond_dd

    .line 343
    invoke-static {v6}, Lretrofit/Utils;->readBodyToBytesIfNecessary(Lretrofit/client/Response;)Lretrofit/client/Response;

    move-result-object v6

    .line 346
    :cond_dd
    iget-boolean v0, v2, Lretrofit/RestMethodInfo;->isSynchronous:Z
    :try_end_df
    .catch Lretrofit/RetrofitError; {:try_start_2d .. :try_end_df} :catch_1ae
    .catch Ljava/io/IOException; {:try_start_2d .. :try_end_df} :catch_181
    .catchall {:try_start_2d .. :try_end_df} :catchall_17e

    if-eqz v0, :cond_ed

    .line 397
    iget-boolean v0, v2, Lretrofit/RestMethodInfo;->isSynchronous:Z

    if-nez v0, :cond_ec

    .line 398
    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object v0

    invoke-virtual {v0, v3}, Ljava/lang/Thread;->setName(Ljava/lang/String;)V

    :cond_ec
    return-object v6

    .line 349
    :cond_ed
    :try_start_ed
    new-instance v0, Lretrofit/ResponseWrapper;

    invoke-direct {v0, v6, v6}, Lretrofit/ResponseWrapper;-><init>(Lretrofit/client/Response;Ljava/lang/Object;)V
    :try_end_f2
    .catch Lretrofit/RetrofitError; {:try_start_ed .. :try_end_f2} :catch_1ae
    .catch Ljava/io/IOException; {:try_start_ed .. :try_end_f2} :catch_181
    .catchall {:try_start_ed .. :try_end_f2} :catchall_17e

    .line 397
    iget-boolean v2, v2, Lretrofit/RestMethodInfo;->isSynchronous:Z

    if-nez v2, :cond_fd

    .line 398
    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object v2

    invoke-virtual {v2, v3}, Ljava/lang/Thread;->setName(Ljava/lang/String;)V

    :cond_fd
    return-object v0

    .line 352
    :cond_fe
    :try_start_fe
    invoke-virtual {v6}, Lretrofit/client/Response;->getBody()Lretrofit/mime/TypedInput;

    move-result-object v0

    if-nez v0, :cond_125

    .line 354
    iget-boolean v0, v2, Lretrofit/RestMethodInfo;->isSynchronous:Z
    :try_end_106
    .catch Lretrofit/RetrofitError; {:try_start_fe .. :try_end_106} :catch_1ae
    .catch Ljava/io/IOException; {:try_start_fe .. :try_end_106} :catch_181
    .catchall {:try_start_fe .. :try_end_106} :catchall_17e

    if-eqz v0, :cond_114

    .line 397
    iget-boolean v0, v2, Lretrofit/RestMethodInfo;->isSynchronous:Z

    if-nez v0, :cond_113

    .line 398
    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object v0

    invoke-virtual {v0, v3}, Ljava/lang/Thread;->setName(Ljava/lang/String;)V

    :cond_113
    return-object v4

    .line 357
    :cond_114
    :try_start_114
    new-instance v0, Lretrofit/ResponseWrapper;

    invoke-direct {v0, v6, v4}, Lretrofit/ResponseWrapper;-><init>(Lretrofit/client/Response;Ljava/lang/Object;)V
    :try_end_119
    .catch Lretrofit/RetrofitError; {:try_start_114 .. :try_end_119} :catch_1ae
    .catch Ljava/io/IOException; {:try_start_114 .. :try_end_119} :catch_181
    .catchall {:try_start_114 .. :try_end_119} :catchall_17e

    .line 397
    iget-boolean v2, v2, Lretrofit/RestMethodInfo;->isSynchronous:Z

    if-nez v2, :cond_124

    .line 398
    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object v2

    invoke-virtual {v2, v3}, Ljava/lang/Thread;->setName(Ljava/lang/String;)V

    :cond_124
    return-object v0

    .line 360
    :cond_125
    :try_start_125
    new-instance v5, Lretrofit/ExceptionCatchingTypedInput;

    invoke-direct {v5, v0}, Lretrofit/ExceptionCatchingTypedInput;-><init>(Lretrofit/mime/TypedInput;)V
    :try_end_12a
    .catch Lretrofit/RetrofitError; {:try_start_125 .. :try_end_12a} :catch_1ae
    .catch Ljava/io/IOException; {:try_start_125 .. :try_end_12a} :catch_181
    .catchall {:try_start_125 .. :try_end_12a} :catchall_17e

    .line 362
    :try_start_12a
    iget-object v9, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object v9, v9, Lretrofit/RestAdapter;->converter:Lretrofit/converter/Converter;

    invoke-interface {v9, v5, v8}, Lretrofit/converter/Converter;->fromBody(Lretrofit/mime/TypedInput;Ljava/lang/reflect/Type;)Ljava/lang/Object;

    move-result-object v9

    .line 363
    iget-object v10, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    # invokes: Lretrofit/RestAdapter;->logResponseBody(Lretrofit/mime/TypedInput;Ljava/lang/Object;)V
    invoke-static {v10, v0, v9}, Lretrofit/RestAdapter;->access$600(Lretrofit/RestAdapter;Lretrofit/mime/TypedInput;Ljava/lang/Object;)V

    .line 364
    iget-boolean v0, v2, Lretrofit/RestMethodInfo;->isSynchronous:Z
    :try_end_139
    .catch Lretrofit/converter/ConversionException; {:try_start_12a .. :try_end_139} :catch_158
    .catch Lretrofit/RetrofitError; {:try_start_12a .. :try_end_139} :catch_1ae
    .catch Ljava/io/IOException; {:try_start_12a .. :try_end_139} :catch_181
    .catchall {:try_start_12a .. :try_end_139} :catchall_17e

    if-eqz v0, :cond_147

    .line 397
    iget-boolean v0, v2, Lretrofit/RestMethodInfo;->isSynchronous:Z

    if-nez v0, :cond_146

    .line 398
    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object v0

    invoke-virtual {v0, v3}, Ljava/lang/Thread;->setName(Ljava/lang/String;)V

    :cond_146
    return-object v9

    .line 367
    :cond_147
    :try_start_147
    new-instance v0, Lretrofit/ResponseWrapper;

    invoke-direct {v0, v6, v9}, Lretrofit/ResponseWrapper;-><init>(Lretrofit/client/Response;Ljava/lang/Object;)V
    :try_end_14c
    .catch Lretrofit/converter/ConversionException; {:try_start_147 .. :try_end_14c} :catch_158
    .catch Lretrofit/RetrofitError; {:try_start_147 .. :try_end_14c} :catch_1ae
    .catch Ljava/io/IOException; {:try_start_147 .. :try_end_14c} :catch_181
    .catchall {:try_start_147 .. :try_end_14c} :catchall_17e

    .line 397
    iget-boolean v2, v2, Lretrofit/RestMethodInfo;->isSynchronous:Z

    if-nez v2, :cond_157

    .line 398
    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object v2

    invoke-virtual {v2, v3}, Ljava/lang/Thread;->setName(Ljava/lang/String;)V

    :cond_157
    return-object v0

    :catch_158
    move-exception v0

    .line 371
    :try_start_159
    invoke-virtual {v5}, Lretrofit/ExceptionCatchingTypedInput;->threwException()Z

    move-result v9

    if-eqz v9, :cond_164

    .line 372
    invoke-virtual {v5}, Lretrofit/ExceptionCatchingTypedInput;->getThrownException()Ljava/io/IOException;

    move-result-object v0

    throw v0

    .line 376
    :cond_164
    invoke-static {v6, v4}, Lretrofit/Utils;->replaceResponseBody(Lretrofit/client/Response;Lretrofit/mime/TypedInput;)Lretrofit/client/Response;

    move-result-object v4

    .line 378
    iget-object v5, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object v5, v5, Lretrofit/RestAdapter;->converter:Lretrofit/converter/Converter;

    invoke-static {v7, v4, v5, v8, v0}, Lretrofit/RetrofitError;->conversionError(Ljava/lang/String;Lretrofit/client/Response;Lretrofit/converter/Converter;Ljava/lang/reflect/Type;Lretrofit/converter/ConversionException;)Lretrofit/RetrofitError;

    move-result-object v0

    throw v0

    .line 382
    :cond_171
    invoke-static {v6}, Lretrofit/Utils;->readBodyToBytesIfNecessary(Lretrofit/client/Response;)Lretrofit/client/Response;

    move-result-object v0

    .line 383
    iget-object v4, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object v4, v4, Lretrofit/RestAdapter;->converter:Lretrofit/converter/Converter;

    invoke-static {v7, v0, v4, v8}, Lretrofit/RetrofitError;->httpError(Ljava/lang/String;Lretrofit/client/Response;Lretrofit/converter/Converter;Ljava/lang/reflect/Type;)Lretrofit/RetrofitError;

    move-result-object v0

    throw v0
    :try_end_17e
    .catch Lretrofit/RetrofitError; {:try_start_159 .. :try_end_17e} :catch_1ae
    .catch Ljava/io/IOException; {:try_start_159 .. :try_end_17e} :catch_181
    .catchall {:try_start_159 .. :try_end_17e} :catchall_17e

    :catchall_17e
    move-exception v0

    move-object v4, v7

    goto :goto_185

    :catch_181
    move-exception v0

    move-object v4, v7

    goto :goto_19a

    :catchall_184
    move-exception v0

    .line 392
    :goto_185
    :try_start_185
    iget-object v5, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object v5, v5, Lretrofit/RestAdapter;->logLevel:Lretrofit/RestAdapter$LogLevel;

    invoke-virtual {v5}, Lretrofit/RestAdapter$LogLevel;->log()Z

    move-result v5

    if-eqz v5, :cond_194

    .line 393
    iget-object v5, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    invoke-virtual {v5, v0, v4}, Lretrofit/RestAdapter;->logException(Ljava/lang/Throwable;Ljava/lang/String;)V

    .line 395
    :cond_194
    invoke-static {v4, v0}, Lretrofit/RetrofitError;->unexpectedError(Ljava/lang/String;Ljava/lang/Throwable;)Lretrofit/RetrofitError;

    move-result-object v0

    throw v0

    :catch_199
    move-exception v0

    .line 387
    :goto_19a
    iget-object v5, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object v5, v5, Lretrofit/RestAdapter;->logLevel:Lretrofit/RestAdapter$LogLevel;

    invoke-virtual {v5}, Lretrofit/RestAdapter$LogLevel;->log()Z

    move-result v5

    if-eqz v5, :cond_1a9

    .line 388
    iget-object v5, v1, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    invoke-virtual {v5, v0, v4}, Lretrofit/RestAdapter;->logException(Ljava/lang/Throwable;Ljava/lang/String;)V

    .line 390
    :cond_1a9
    invoke-static {v4, v0}, Lretrofit/RetrofitError;->networkError(Ljava/lang/String;Ljava/io/IOException;)Lretrofit/RetrofitError;

    move-result-object v0

    throw v0

    :catch_1ae
    move-exception v0

    .line 385
    throw v0
    :try_end_1b0
    .catchall {:try_start_185 .. :try_end_1b0} :catchall_1b0

    :catchall_1b0
    move-exception v0

    .line 397
    iget-boolean v2, v2, Lretrofit/RestMethodInfo;->isSynchronous:Z

    if-nez v2, :cond_1bc

    .line 398
    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object v2

    invoke-virtual {v2, v3}, Ljava/lang/Thread;->setName(Ljava/lang/String;)V

    :cond_1bc
    throw v0
.end method


# virtual methods
.method public invoke(Ljava/lang/Object;Ljava/lang/reflect/Method;[Ljava/lang/Object;)Ljava/lang/Object;
    .registers 12
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Ljava/lang/Throwable;
        }
    .end annotation

    .line 231
    invoke-virtual {p2}, Ljava/lang/reflect/Method;->getDeclaringClass()Ljava/lang/Class;

    move-result-object p1

    const-class v0, Ljava/lang/Object;

    if-ne p1, v0, :cond_d

    .line 232
    invoke-virtual {p2, p0, p3}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object p1

    return-object p1

    .line 236
    :cond_d
    iget-object p1, p0, Lretrofit/RestAdapter$RestHandler;->methodDetailsCache:Ljava/util/Map;

    invoke-static {p1, p2}, Lretrofit/RestAdapter;->getMethodInfo(Ljava/util/Map;Ljava/lang/reflect/Method;)Lretrofit/RestMethodInfo;

    move-result-object v6

    .line 238
    iget-boolean p1, v6, Lretrofit/RestMethodInfo;->isSynchronous:Z

    if-eqz p1, :cond_34

    .line 240
    :try_start_17
    iget-object p1, p0, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object p1, p1, Lretrofit/RestAdapter;->requestInterceptor:Lretrofit/RequestInterceptor;

    invoke-direct {p0, p1, v6, p3}, Lretrofit/RestAdapter$RestHandler;->invokeRequest(Lretrofit/RequestInterceptor;Lretrofit/RestMethodInfo;[Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object p1
    :try_end_1f
    .catch Lretrofit/RetrofitError; {:try_start_17 .. :try_end_1f} :catch_20

    return-object p1

    :catch_20
    move-exception p1

    .line 242
    iget-object p2, p0, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object p2, p2, Lretrofit/RestAdapter;->errorHandler:Lretrofit/ErrorHandler;

    invoke-interface {p2, p1}, Lretrofit/ErrorHandler;->handleError(Lretrofit/RetrofitError;)Ljava/lang/Throwable;

    move-result-object p2

    if-nez p2, :cond_33

    .line 244
    new-instance p2, Ljava/lang/IllegalStateException;

    const-string p3, "Error handler returned null for wrapped exception."

    invoke-direct {p2, p3, p1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V

    throw p2

    .line 247
    :cond_33
    throw p2

    .line 251
    :cond_34
    iget-object p1, p0, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object p1, p1, Lretrofit/RestAdapter;->httpExecutor:Ljava/util/concurrent/Executor;

    if-eqz p1, :cond_aa

    iget-object p1, p0, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object p1, p1, Lretrofit/RestAdapter;->callbackExecutor:Ljava/util/concurrent/Executor;

    if-eqz p1, :cond_aa

    .line 255
    iget-boolean p1, v6, Lretrofit/RestMethodInfo;->isObservable:Z

    if-eqz p1, :cond_7d

    .line 256
    iget-object p1, p0, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    # getter for: Lretrofit/RestAdapter;->rxSupport:Lretrofit/RxSupport;
    invoke-static {p1}, Lretrofit/RestAdapter;->access$000(Lretrofit/RestAdapter;)Lretrofit/RxSupport;

    move-result-object p1

    if-nez p1, :cond_6d

    .line 257
    sget-boolean p1, Lretrofit/Platform;->HAS_RX_JAVA:Z

    if-eqz p1, :cond_65

    .line 258
    iget-object p1, p0, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    new-instance p2, Lretrofit/RxSupport;

    iget-object v0, p1, Lretrofit/RestAdapter;->httpExecutor:Ljava/util/concurrent/Executor;

    iget-object v1, p0, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object v1, v1, Lretrofit/RestAdapter;->errorHandler:Lretrofit/ErrorHandler;

    iget-object v2, p0, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object v2, v2, Lretrofit/RestAdapter;->requestInterceptor:Lretrofit/RequestInterceptor;

    invoke-direct {p2, v0, v1, v2}, Lretrofit/RxSupport;-><init>(Ljava/util/concurrent/Executor;Lretrofit/ErrorHandler;Lretrofit/RequestInterceptor;)V

    # setter for: Lretrofit/RestAdapter;->rxSupport:Lretrofit/RxSupport;
    invoke-static {p1, p2}, Lretrofit/RestAdapter;->access$002(Lretrofit/RestAdapter;Lretrofit/RxSupport;)Lretrofit/RxSupport;

    goto :goto_6d

    .line 260
    :cond_65
    new-instance p1, Ljava/lang/IllegalStateException;

    const-string p2, "Observable method found but no RxJava on classpath."

    invoke-direct {p1, p2}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V

    throw p1

    .line 263
    :cond_6d
    :goto_6d
    iget-object p1, p0, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    # getter for: Lretrofit/RestAdapter;->rxSupport:Lretrofit/RxSupport;
    invoke-static {p1}, Lretrofit/RestAdapter;->access$000(Lretrofit/RestAdapter;)Lretrofit/RxSupport;

    move-result-object p1

    new-instance p2, Lretrofit/RestAdapter$RestHandler$1;

    invoke-direct {p2, p0, v6, p3}, Lretrofit/RestAdapter$RestHandler$1;-><init>(Lretrofit/RestAdapter$RestHandler;Lretrofit/RestMethodInfo;[Ljava/lang/Object;)V

    invoke-virtual {p1, p2}, Lretrofit/RxSupport;->createRequestObservable(Lretrofit/RxSupport$Invoker;)Lrx/Observable;

    move-result-object p1

    return-object p1

    .line 272
    :cond_7d
    new-instance v5, Lretrofit/RequestInterceptorTape;

    invoke-direct {v5}, Lretrofit/RequestInterceptorTape;-><init>()V

    .line 273
    iget-object p1, p0, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object p1, p1, Lretrofit/RestAdapter;->requestInterceptor:Lretrofit/RequestInterceptor;

    invoke-interface {p1, v5}, Lretrofit/RequestInterceptor;->intercept(Lretrofit/RequestInterceptor$RequestFacade;)V

    .line 275
    array-length p1, p3

    add-int/lit8 p1, p1, -0x1

    aget-object p1, p3, p1

    move-object v2, p1

    check-cast v2, Lretrofit/Callback;

    .line 276
    iget-object p1, p0, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object p1, p1, Lretrofit/RestAdapter;->httpExecutor:Ljava/util/concurrent/Executor;

    new-instance p2, Lretrofit/RestAdapter$RestHandler$2;

    iget-object v0, p0, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object v3, v0, Lretrofit/RestAdapter;->callbackExecutor:Ljava/util/concurrent/Executor;

    iget-object v0, p0, Lretrofit/RestAdapter$RestHandler;->this$0:Lretrofit/RestAdapter;

    iget-object v4, v0, Lretrofit/RestAdapter;->errorHandler:Lretrofit/ErrorHandler;

    move-object v0, p2

    move-object v1, p0

    move-object v7, p3

    invoke-direct/range {v0 .. v7}, Lretrofit/RestAdapter$RestHandler$2;-><init>(Lretrofit/RestAdapter$RestHandler;Lretrofit/Callback;Ljava/util/concurrent/Executor;Lretrofit/ErrorHandler;Lretrofit/RequestInterceptorTape;Lretrofit/RestMethodInfo;[Ljava/lang/Object;)V

    invoke-interface {p1, p2}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V

    const/4 p1, 0x0

    return-object p1

    .line 252
    :cond_aa
    new-instance p1, Ljava/lang/IllegalStateException;

    const-string p2, "Asynchronous invocation requires calling setExecutors."

    invoke-direct {p1, p2}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V

    throw p1
.end method