.class public final Lokhttp3/internal/platform/android/AndroidLog; .super Ljava/lang/Object; .source "AndroidLog.kt" # annotations .annotation runtime Lkotlin/Metadata; bv = {} d1 = { "\u0000:\n\u0002\u0018\u0002\n\u0002\u0010\u0000\n\u0002\u0010\u000e\n\u0002\u0008\u0004\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\u0008\n\u0002\u0008\u0002\n\u0002\u0010\u0003\n\u0002\u0008\u0007\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\u0008\u0002\n\u0002\u0010$\n\u0002\u0008\u0005\u0008\u00c7\u0002\u0018\u00002\u00020\u0001B\t\u0008\u0002\u00a2\u0006\u0004\u0008\u001b\u0010\u001cJ\u0010\u0010\u0004\u001a\u00020\u00022\u0006\u0010\u0003\u001a\u00020\u0002H\u0002J\u0018\u0010\u0008\u001a\u00020\u00072\u0006\u0010\u0005\u001a\u00020\u00022\u0006\u0010\u0006\u001a\u00020\u0002H\u0002J1\u0010\u0010\u001a\u00020\u00072\u0006\u0010\u0003\u001a\u00020\u00022\u0006\u0010\n\u001a\u00020\t2\u0006\u0010\u000b\u001a\u00020\u00022\u0008\u0010\r\u001a\u0004\u0018\u00010\u000cH\u0000\u00a2\u0006\u0004\u0008\u000e\u0010\u000fJ\u0006\u0010\u0011\u001a\u00020\u0007R\u0014\u0010\u0012\u001a\u00020\t8\u0002X\u0082T\u00a2\u0006\u0006\n\u0004\u0008\u0012\u0010\u0013R\u001a\u0010\u0016\u001a\u0008\u0012\u0004\u0012\u00020\u00150\u00148\u0002X\u0082\u0004\u00a2\u0006\u0006\n\u0004\u0008\u0016\u0010\u0017R \u0010\u0019\u001a\u000e\u0012\u0004\u0012\u00020\u0002\u0012\u0004\u0012\u00020\u00020\u00188\u0002X\u0082\u0004\u00a2\u0006\u0006\n\u0004\u0008\u0019\u0010\u001a\u00a8\u0006\u001d" } d2 = { "Lokhttp3/internal/platform/android/AndroidLog;", "", "", "loggerName", "loggerTag", "logger", "tag", "Lkotlin/d1;", "enableLogging", "", "logLevel", "message", "", "t", "androidLog$okhttp", "(Ljava/lang/String;ILjava/lang/String;Ljava/lang/Throwable;)V", "androidLog", "enable", "MAX_LOG_LENGTH", "I", "Ljava/util/concurrent/CopyOnWriteArraySet;", "Ljava/util/logging/Logger;", "configuredLoggers", "Ljava/util/concurrent/CopyOnWriteArraySet;", "", "knownLoggers", "Ljava/util/Map;", "", "()V", "okhttp" } k = 0x1 mv = { 0x1, 0x4, 0x0 } .end annotation .annotation build Lokhttp3/internal/SuppressSignatureCheck; .end annotation # static fields .field public static final INSTANCE:Lokhttp3/internal/platform/android/AndroidLog; .field private static final MAX_LOG_LENGTH:I = 0xfa0 .field private static final configuredLoggers:Ljava/util/concurrent/CopyOnWriteArraySet; .annotation system Ldalvik/annotation/Signature; value = { "Ljava/util/concurrent/CopyOnWriteArraySet<", "Ljava/util/logging/Logger;", ">;" } .end annotation .end field .field private static final knownLoggers:Ljava/util/Map; .annotation system Ldalvik/annotation/Signature; value = { "Ljava/util/Map<", "Ljava/lang/String;", "Ljava/lang/String;", ">;" } .end annotation .end field # direct methods .method public static constructor ()V .locals 3 .line 1 new-instance v0, Lokhttp3/internal/platform/android/AndroidLog; invoke-direct {v0}, Lokhttp3/internal/platform/android/AndroidLog;->()V sput-object v0, Lokhttp3/internal/platform/android/AndroidLog;->INSTANCE:Lokhttp3/internal/platform/android/AndroidLog; .line 2 new-instance v0, Ljava/util/concurrent/CopyOnWriteArraySet; invoke-direct {v0}, Ljava/util/concurrent/CopyOnWriteArraySet;->()V sput-object v0, Lokhttp3/internal/platform/android/AndroidLog;->configuredLoggers:Ljava/util/concurrent/CopyOnWriteArraySet; .line 3 new-instance v0, Ljava/util/LinkedHashMap; invoke-direct {v0}, Ljava/util/LinkedHashMap;->()V .line 4 const-class v1, Lokhttp3/OkHttpClient; invoke-virtual {v1}, Ljava/lang/Class;->getPackage()Ljava/lang/Package; move-result-object v1 if-eqz v1, :cond_0 invoke-virtual {v1}, Ljava/lang/Package;->getName()Ljava/lang/String; move-result-object v1 goto :goto_0 :cond_0 const/4 v1, 0x0 :goto_0 if-eqz v1, :cond_1 const-string v2, "OkHttp" .line 5 invoke-interface {v0, v1, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 6 :cond_1 const-class v1, Lokhttp3/OkHttpClient; invoke-virtual {v1}, Ljava/lang/Class;->getName()Ljava/lang/String; move-result-object v1 const-string v2, "OkHttpClient::class.java.name" invoke-static {v1, v2}, Lkotlin/jvm/internal/f0;->o(Ljava/lang/Object;Ljava/lang/String;)V const-string v2, "okhttp.OkHttpClient" invoke-interface {v0, v1, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 7 const-class v1, Lokhttp3/internal/http2/Http2; invoke-virtual {v1}, Ljava/lang/Class;->getName()Ljava/lang/String; move-result-object v1 const-string v2, "Http2::class.java.name" invoke-static {v1, v2}, Lkotlin/jvm/internal/f0;->o(Ljava/lang/Object;Ljava/lang/String;)V const-string v2, "okhttp.Http2" invoke-interface {v0, v1, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 8 const-class v1, Lokhttp3/internal/concurrent/TaskRunner; invoke-virtual {v1}, Ljava/lang/Class;->getName()Ljava/lang/String; move-result-object v1 const-string v2, "TaskRunner::class.java.name" invoke-static {v1, v2}, Lkotlin/jvm/internal/f0;->o(Ljava/lang/Object;Ljava/lang/String;)V const-string v2, "okhttp.TaskRunner" invoke-interface {v0, v1, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; const-string v1, "okhttp3.mockwebserver.MockWebServer" const-string v2, "okhttp.MockWebServer" .line 9 invoke-interface {v0, v1, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 10 invoke-static {v0}, Lkotlin/collections/w0;->D0(Ljava/util/Map;)Ljava/util/Map; move-result-object v0 sput-object v0, Lokhttp3/internal/platform/android/AndroidLog;->knownLoggers:Ljava/util/Map; return-void .end method .method private constructor ()V .locals 0 .line 1 invoke-direct {p0}, Ljava/lang/Object;->()V return-void .end method .method private final enableLogging(Ljava/lang/String;Ljava/lang/String;)V .locals 1 .line 1 invoke-static {p1}, Ljava/util/logging/Logger;->getLogger(Ljava/lang/String;)Ljava/util/logging/Logger; move-result-object p1 .line 2 sget-object v0, Lokhttp3/internal/platform/android/AndroidLog;->configuredLoggers:Ljava/util/concurrent/CopyOnWriteArraySet; invoke-virtual {v0, p1}, Ljava/util/concurrent/CopyOnWriteArraySet;->add(Ljava/lang/Object;)Z move-result v0 if-eqz v0, :cond_2 const-string v0, "logger" .line 3 invoke-static {p1, v0}, Lkotlin/jvm/internal/f0;->o(Ljava/lang/Object;Ljava/lang/String;)V const/4 v0, 0x0 invoke-virtual {p1, v0}, Ljava/util/logging/Logger;->setUseParentHandlers(Z)V const/4 v0, 0x3 .line 4 invoke-static {p2, v0}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z move-result v0 if-eqz v0, :cond_0 sget-object p2, Ljava/util/logging/Level;->FINE:Ljava/util/logging/Level; goto :goto_0 :cond_0 const/4 v0, 0x4 .line 5 invoke-static {p2, v0}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z move-result p2 if-eqz p2, :cond_1 sget-object p2, Ljava/util/logging/Level;->INFO:Ljava/util/logging/Level; goto :goto_0 .line 6 :cond_1 sget-object p2, Ljava/util/logging/Level;->WARNING:Ljava/util/logging/Level; .line 7 :goto_0 invoke-virtual {p1, p2}, Ljava/util/logging/Logger;->setLevel(Ljava/util/logging/Level;)V .line 8 sget-object p2, Lokhttp3/internal/platform/android/AndroidLogHandler;->INSTANCE:Lokhttp3/internal/platform/android/AndroidLogHandler; invoke-virtual {p1, p2}, Ljava/util/logging/Logger;->addHandler(Ljava/util/logging/Handler;)V :cond_2 return-void .end method .method private final loggerTag(Ljava/lang/String;)Ljava/lang/String; .locals 1 .line 1 sget-object v0, Lokhttp3/internal/platform/android/AndroidLog;->knownLoggers:Ljava/util/Map; invoke-interface {v0, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v0 check-cast v0, Ljava/lang/String; if-eqz v0, :cond_0 goto :goto_0 :cond_0 const/16 v0, 0x17 invoke-static {p1, v0}, Lkotlin/text/StringsKt___StringsKt;->R8(Ljava/lang/String;I)Ljava/lang/String; move-result-object v0 :goto_0 return-object v0 .end method # virtual methods .method public final androidLog$okhttp(Ljava/lang/String;ILjava/lang/String;Ljava/lang/Throwable;)V .locals 7 .param p1 # Ljava/lang/String; .annotation build Lorg/jetbrains/annotations/NotNull; .end annotation .end param .param p3 # Ljava/lang/String; .annotation build Lorg/jetbrains/annotations/NotNull; .end annotation .end param .param p4 # Ljava/lang/Throwable; .annotation build Lorg/jetbrains/annotations/Nullable; .end annotation .end param const-string v0, "loggerName" invoke-static {p1, v0}, Lkotlin/jvm/internal/f0;->p(Ljava/lang/Object;Ljava/lang/String;)V const-string v0, "message" invoke-static {p3, v0}, Lkotlin/jvm/internal/f0;->p(Ljava/lang/Object;Ljava/lang/String;)V .line 1 invoke-direct {p0, p1}, Lokhttp3/internal/platform/android/AndroidLog;->loggerTag(Ljava/lang/String;)Ljava/lang/String; move-result-object p1 .line 2 invoke-static {p1, p2}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z move-result v0 if-eqz v0, :cond_3 if-eqz p4, :cond_0 const-string v0, "\n" .line 3 invoke-static {p3, v0}, Landroid/support/v4/media/e;->a(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object p3 invoke-static {p4}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String; move-result-object p4 invoke-virtual {p3, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p3 :cond_0 const/4 p4, 0x0 .line 4 invoke-virtual {p3}, Ljava/lang/String;->length()I move-result v6 :goto_0 if-ge p4, v6, :cond_3 const/16 v1, 0xa const/4 v3, 0x0 const/4 v4, 0x4 const/4 v5, 0x0 move-object v0, p3 move v2, p4 .line 5 invoke-static/range {v0 .. v5}, Lkotlin/text/StringsKt__StringsKt;->q3(Ljava/lang/CharSequence;CIZILjava/lang/Object;)I move-result v0 const/4 v1, -0x1 if-eq v0, v1, :cond_1 goto :goto_1 :cond_1 move v0, v6 :goto_1 add-int/lit16 v1, p4, 0xfa0 .line 6 invoke-static {v0, v1}, Ljava/lang/Math;->min(II)I move-result v1 .line 7 invoke-virtual {p3, p4, v1}, Ljava/lang/String;->substring(II)Ljava/lang/String; move-result-object p4 const-string v2, "(this as java.lang.Strin\u2026ing(startIndex, endIndex)" invoke-static {p4, v2}, Lkotlin/jvm/internal/f0;->o(Ljava/lang/Object;Ljava/lang/String;)V invoke-static {p2, p1, p4}, Landroid/util/Log;->println(ILjava/lang/String;Ljava/lang/String;)I if-lt v1, v0, :cond_2 add-int/lit8 p4, v1, 0x1 goto :goto_0 :cond_2 move p4, v1 goto :goto_1 :cond_3 return-void .end method .method public final enable()V .locals 3 .line 1 sget-object v0, Lokhttp3/internal/platform/android/AndroidLog;->knownLoggers:Ljava/util/Map; invoke-interface {v0}, Ljava/util/Map;->entrySet()Ljava/util/Set; move-result-object v0 invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator; move-result-object v0 :goto_0 invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z move-result v1 if-eqz v1, :cond_0 invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v1 check-cast v1, Ljava/util/Map$Entry; invoke-interface {v1}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object; move-result-object v2 check-cast v2, Ljava/lang/String; invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object; move-result-object v1 check-cast v1, Ljava/lang/String; .line 2 invoke-direct {p0, v2, v1}, Lokhttp3/internal/platform/android/AndroidLog;->enableLogging(Ljava/lang/String;Ljava/lang/String;)V goto :goto_0 :cond_0 return-void .end method